ordering-components-external 13.0.30 → 13.0.31

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 (533) hide show
  1. package/.babelrc +22 -22
  2. package/.vscode/settings.json +3 -3
  3. package/_bundles/{7.ordering-component.05c8990567699e368292.js → 7.ordering-component.e2e1eb6df6c8a20c9636.js} +1 -1
  4. package/_bundles/{ordering-component.05c8990567699e368292.js → ordering-component.e2e1eb6df6c8a20c9636.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/PaymentOptionStripeRedirect/StripeRedirectForm/index.js +19 -19
  103. package/_modules/components/PaymentOptionStripeRedirect/index.js +30 -30
  104. package/_modules/components/PaymentOptions/index.js +27 -27
  105. package/_modules/components/PaymethodList/index.js +20 -20
  106. package/_modules/components/PhoneAutocomplete/index.js +51 -44
  107. package/_modules/components/PlaceSpot/index.js +2 -2
  108. package/_modules/components/Popup/index.js +33 -33
  109. package/_modules/components/ProductComponent/index.js +27 -27
  110. package/_modules/components/ProductForm/index.js +115 -115
  111. package/_modules/components/ProductImages/index.js +18 -18
  112. package/_modules/components/ProductIngredient/index.js +17 -17
  113. package/_modules/components/ProductOption/index.js +8 -8
  114. package/_modules/components/ProductOptionSuboption/index.js +33 -33
  115. package/_modules/components/ProductShare/index.js +20 -20
  116. package/_modules/components/ProductsList/index.js +20 -20
  117. package/_modules/components/ProductsListing/index.js +39 -39
  118. package/_modules/components/ProfessionalInfo/index.js +24 -24
  119. package/_modules/components/QueryLoginSpoonity/index.js +20 -20
  120. package/_modules/components/ReCaptcha/index.js +4 -4
  121. package/_modules/components/ResetPassword/index.js +20 -20
  122. package/_modules/components/ReviewCustomer/index.js +16 -16
  123. package/_modules/components/ReviewDriver/index.js +20 -20
  124. package/_modules/components/ReviewProduct/index.js +22 -22
  125. package/_modules/components/SearchOptions/index.js +17 -17
  126. package/_modules/components/Sessions/index.js +21 -21
  127. package/_modules/components/SignupForm/index.js +57 -57
  128. package/_modules/components/SingleBusinessCard/index.js +28 -28
  129. package/_modules/components/SingleOrderCard/index.js +20 -20
  130. package/_modules/components/SingleProductCard/index.js +18 -18
  131. package/_modules/components/SingleProfessionalCard/index.js +18 -18
  132. package/_modules/components/SmartAppBanner/index.js +8 -8
  133. package/_modules/components/StoreProductList/index.js +22 -22
  134. package/_modules/components/StripeElementsForm/CardForm/index.js +25 -25
  135. package/_modules/components/StripeElementsForm/index.js +16 -16
  136. package/_modules/components/UpsellingPage/index.js +17 -17
  137. package/_modules/components/UserFormDetails/index.js +68 -68
  138. package/_modules/components/UserVerification/index.js +16 -16
  139. package/_modules/components/WebsocketStatus/index.js +4 -4
  140. package/_modules/components/WrapperGoogleMaps/index.js +3 -3
  141. package/_modules/contexts/ApiContext/index.js +8 -8
  142. package/_modules/contexts/BillingContext/index.js +7 -7
  143. package/_modules/contexts/BusinessContext/index.js +9 -9
  144. package/_modules/contexts/ConfigContext/index.js +9 -9
  145. package/_modules/contexts/EventContext/index.js +9 -9
  146. package/_modules/contexts/LanguageContext/index.js +13 -13
  147. package/_modules/contexts/OptimizationLoadContext/index.js +8 -8
  148. package/_modules/contexts/OrderContext/index.js +62 -62
  149. package/_modules/contexts/OrderingContext/index.js +7 -7
  150. package/_modules/contexts/OrderingThemeContext/index.js +11 -11
  151. package/_modules/contexts/ProductContext/index.js +13 -13
  152. package/_modules/contexts/SessionContext/index.js +9 -9
  153. package/_modules/contexts/SiteContext/index.js +9 -9
  154. package/_modules/contexts/UtilsContext/index.js +9 -9
  155. package/_modules/contexts/WebsocketContext/index.js +9 -9
  156. package/_modules/native/src/contexts/OrderingContext/index.js +7 -7
  157. package/cypress/fixtures/example.json +4 -4
  158. package/cypress/integration/naked/BusinessProductsCategories.spec.js +9 -9
  159. package/cypress/integration/naked/PhoneAutocomplete.spec.js +22 -22
  160. package/cypress/integration/naked/activeOrders.spec.js +15 -15
  161. package/cypress/integration/naked/addressDetails.spec.js +10 -10
  162. package/cypress/integration/naked/appleLogin.spec.js +14 -14
  163. package/cypress/integration/naked/businessBasicInformation.spec.js +14 -14
  164. package/cypress/integration/naked/businessController.spec.js +9 -9
  165. package/cypress/integration/naked/businessInformation.spec.js +19 -19
  166. package/cypress/integration/naked/businessProductsSearch.spec.js +9 -9
  167. package/cypress/integration/naked/businessReviews.spec.js +16 -16
  168. package/cypress/integration/naked/businessSortControl.spec.js +9 -9
  169. package/cypress/integration/naked/businessTypeFilter.spec.js +10 -10
  170. package/cypress/integration/naked/businessesMap.spec.js +13 -13
  171. package/cypress/integration/naked/cms.spec.js +9 -9
  172. package/cypress/integration/naked/config.spec.js +34 -34
  173. package/cypress/integration/naked/driverTips.spec.js +10 -10
  174. package/cypress/integration/naked/events.spec.js +13 -13
  175. package/cypress/integration/naked/facebookLogin.spec.js +13 -13
  176. package/cypress/integration/naked/floatingButton.spec.js +13 -13
  177. package/cypress/integration/naked/forgotPassword.spec.js +20 -20
  178. package/cypress/integration/naked/googleLogin.spec.js +11 -11
  179. package/cypress/integration/naked/languageExamples.spec.js +25 -25
  180. package/cypress/integration/naked/languageSelector.spec.js +10 -10
  181. package/cypress/integration/naked/login.spec.js +38 -38
  182. package/cypress/integration/naked/logout.spec.js +15 -15
  183. package/cypress/integration/naked/mainSearch.spec.js +9 -9
  184. package/cypress/integration/naked/menuControl.spec.js +9 -9
  185. package/cypress/integration/naked/messages.spec.js +25 -25
  186. package/cypress/integration/naked/momentOption.spec.js +10 -10
  187. package/cypress/integration/naked/myOrders.spec.js +11 -11
  188. package/cypress/integration/naked/myOrdersList.spec.js +9 -9
  189. package/cypress/integration/naked/orderContextAdvanced.spec.js +23 -23
  190. package/cypress/integration/naked/orderDetails.spec.js +11 -11
  191. package/cypress/integration/naked/paymentOptionCash.spec.js +21 -21
  192. package/cypress/integration/naked/paymentOptionStripe.spec.js +11 -11
  193. package/cypress/integration/naked/paymentOptionStripeDirect.spec.js +11 -11
  194. package/cypress/integration/naked/paymentOptions.spec.js +9 -9
  195. package/cypress/integration/naked/popupExample.spec.js +17 -17
  196. package/cypress/integration/naked/productImages.spec.js +11 -11
  197. package/cypress/integration/naked/productOptionExample.spec.js +21 -21
  198. package/cypress/integration/naked/productShare.spec.js +9 -9
  199. package/cypress/integration/naked/productsList.spec.js +9 -9
  200. package/cypress/integration/naked/resetPassword.spec.js +11 -11
  201. package/cypress/integration/naked/reviewOrders.spec.js +13 -13
  202. package/cypress/integration/naked/searchOptions.spec.js +18 -18
  203. package/cypress/integration/naked/signup.spec.js +31 -31
  204. package/cypress/integration/naked/upselling.spec.js +13 -13
  205. package/cypress/integration/naked/userDetails.spec.js +12 -12
  206. package/cypress/plugins/index.js +21 -21
  207. package/cypress/support/commands.js +35 -35
  208. package/cypress/support/index.js +20 -20
  209. package/cypress.json +12 -12
  210. package/example/App.js +263 -263
  211. package/example/components/ActiveOrdersUI/index.js +72 -72
  212. package/example/components/AddressDetailsUI/index.js +101 -101
  213. package/example/components/AddressFormUI/index.js +161 -161
  214. package/example/components/AddressListUI/index.js +33 -33
  215. package/example/components/AlertPopup/index.js +10 -10
  216. package/example/components/AlertUI/index.js +49 -49
  217. package/example/components/AlertUI/style.css +5 -5
  218. package/example/components/AppleLoginUI/index.js +40 -40
  219. package/example/components/BaseComponentUI/index.js +34 -34
  220. package/example/components/BusinessBasicInformationUI/index.js +118 -118
  221. package/example/components/BusinessControllerUI/index.js +89 -89
  222. package/example/components/BusinessInformationUI/BusinessOptionUI/index.js +83 -83
  223. package/example/components/BusinessInformationUI/index.js +83 -83
  224. package/example/components/BusinessProductsCategoriesUI/index.js +42 -42
  225. package/example/components/BusinessProductsSearchUI/index.js +38 -38
  226. package/example/components/BusinessReviewsUI/index.js +77 -77
  227. package/example/components/BusinessSortControlUI/index.js +47 -47
  228. package/example/components/BusinessTypeFilterUI/index.js +53 -53
  229. package/example/components/BusinessesMapUI/index.js +57 -57
  230. package/example/components/CartUI/index.js +154 -154
  231. package/example/components/ChangeView/index.js +19 -19
  232. package/example/components/CheckoutUI/index.js +206 -206
  233. package/example/components/CmsContentUI/index.js +52 -52
  234. package/example/components/ConfigsExample/index.js +118 -118
  235. package/example/components/CouponControlUI/index.js +63 -63
  236. package/example/components/DriverTipsUI/index.js +58 -58
  237. package/example/components/FacebookLoginButtonUI/index.js +48 -48
  238. package/example/components/FloatingButtonUI/index.js +145 -145
  239. package/example/components/ForgotPasswordFormUI/index.js +93 -93
  240. package/example/components/GoogleLoginUI/index.js +30 -30
  241. package/example/components/GpsButtonUI/index.js +22 -22
  242. package/example/components/Header/index.js +18 -18
  243. package/example/components/LanguageSelectorUI/index.js +57 -57
  244. package/example/components/LanguagesExample/index.js +51 -51
  245. package/example/components/LoginFormUI/index.js +159 -159
  246. package/example/components/LogoutButtonUI/index.js +21 -21
  247. package/example/components/MainSearchUI/index.js +131 -131
  248. package/example/components/MenuControlUI/index.js +103 -103
  249. package/example/components/MessagesUI/index.js +162 -162
  250. package/example/components/ModalUI/index.js +36 -36
  251. package/example/components/ModalUI/style.css +5 -5
  252. package/example/components/MomentOptionUI/index.js +68 -68
  253. package/example/components/MyOrdersListUI/index.js +51 -51
  254. package/example/components/MyOrdersUI/index.js +52 -52
  255. package/example/components/OrderChangeUI/index.js +54 -54
  256. package/example/components/OrderDetailsUI/index.js +174 -174
  257. package/example/components/OrderReviewUI/index.js +125 -125
  258. package/example/components/OrderTypeControlUI/index.js +32 -32
  259. package/example/components/PaymentOptionCashUI/index.js +60 -60
  260. package/example/components/PaymentOptionPaypalUI/index.js +50 -50
  261. package/example/components/PaymentOptionStripeDirectUI/index.js +89 -89
  262. package/example/components/PaymentOptionStripeRedirectUI/index.js +97 -97
  263. package/example/components/PaymentOptionStripeUI/index.js +129 -129
  264. package/example/components/PaymentOptionsUI/index.js +169 -169
  265. package/example/components/PhoneAutocompleteUI/index.js +67 -67
  266. package/example/components/PhoneAutocompleteUI/styles.css +49 -49
  267. package/example/components/ProductComponentUI/index.js +113 -113
  268. package/example/components/ProductFormUI/index.js +131 -131
  269. package/example/components/ProductImagesUI/index.js +82 -82
  270. package/example/components/ProductIngredientUI/index.js +21 -21
  271. package/example/components/ProductOptionSuboptionUI/index.js +65 -65
  272. package/example/components/ProductOptionUI/index.js +31 -31
  273. package/example/components/ProductShareUI/index.js +48 -48
  274. package/example/components/ProductsListUI/index.js +108 -108
  275. package/example/components/ProductsListingUI/index.js +42 -42
  276. package/example/components/ResetPasswordUI/index.js +121 -121
  277. package/example/components/SearchOptionsUI/index.js +82 -82
  278. package/example/components/SignupFormUI/index.js +117 -117
  279. package/example/components/SingleBusinessCardUI/index.js +82 -82
  280. package/example/components/SingleOrderCardUI/index.js +52 -52
  281. package/example/components/SingleProductCardUI/index.js +47 -47
  282. package/example/components/StripeElementsFormUI/CardFormUI/index.js +51 -51
  283. package/example/components/StripeElementsFormUI/CardFormUI/style.css +118 -118
  284. package/example/components/StripeElementsFormUI/index.js +38 -38
  285. package/example/components/StripeRedirectFormUI/index.js +99 -99
  286. package/example/components/TestComponent/index.js +5 -5
  287. package/example/components/UpsellingPageUI/index.js +26 -26
  288. package/example/components/UserDetailsUI/index.js +94 -94
  289. package/example/components/UserProfileUI/index.js +156 -156
  290. package/example/views/ActiveOrders/index.js +86 -86
  291. package/example/views/AddressDetailsExample/index.js +57 -57
  292. package/example/views/AppleLoginExample/index.js +51 -51
  293. package/example/views/BaseComponentExample/index.js +35 -35
  294. package/example/views/BusinessBasicInformationExample/index.js +43 -43
  295. package/example/views/BusinessControllerExample/index.js +55 -55
  296. package/example/views/BusinessInformationExample/index.js +68 -68
  297. package/example/views/BusinessProductsCategoriesExample/index.js +50 -50
  298. package/example/views/BusinessProductsSearchExample/index.js +39 -39
  299. package/example/views/BusinessReviewsExample/index.js +43 -43
  300. package/example/views/BusinessSortControlExample/index.js +53 -53
  301. package/example/views/BusinessTypeFilterExample/index.js +53 -53
  302. package/example/views/BusinessesMapExample/index.js +57 -57
  303. package/example/views/CheckoutExample/index.js +143 -143
  304. package/example/views/CmsContentExample/index.js +44 -44
  305. package/example/views/DriverTipsExample/index.js +47 -47
  306. package/example/views/EventsExample/index.js +26 -26
  307. package/example/views/FacebookLogin/index.js +63 -63
  308. package/example/views/FloatingButtonExample/index.js +47 -47
  309. package/example/views/ForgotPassword/index.js +77 -77
  310. package/example/views/GoogleLoginExample/index.js +85 -85
  311. package/example/views/Home/index.js +200 -200
  312. package/example/views/LanguageSelectorExample/index.js +55 -55
  313. package/example/views/Login/index.js +84 -84
  314. package/example/views/MainSearchExample/index.js +43 -43
  315. package/example/views/MenuControlExample/index.js +68 -68
  316. package/example/views/MessagesExample/index.js +58 -58
  317. package/example/views/MomentOptionExample/index.js +52 -52
  318. package/example/views/MyOrdersExample/index.js +35 -35
  319. package/example/views/MyOrdersListExample/index.js +50 -50
  320. package/example/views/OrderChangeExample/index.js +46 -46
  321. package/example/views/OrderContextExample/index.js +139 -139
  322. package/example/views/OrderDetailsExample/index.js +50 -50
  323. package/example/views/OrderReviewExample/index.js +64 -64
  324. package/example/views/PaymentOptionCashExample/index.js +51 -51
  325. package/example/views/PaymentOptionPaypalExample/index.js +71 -71
  326. package/example/views/PaymentOptionStripeDirectExample/index.js +43 -43
  327. package/example/views/PaymentOptionStripeExample/index.js +47 -47
  328. package/example/views/PaymentOptionStripeRedirectExample/index.js +56 -56
  329. package/example/views/PaymentOptionsExample/index.js +47 -47
  330. package/example/views/PhoneAutocompleteExample/index.js +34 -34
  331. package/example/views/PlacesExample/index.js +94 -94
  332. package/example/views/PopupExample/index.js +78 -78
  333. package/example/views/PopupExample/style.css +18 -18
  334. package/example/views/ProductDetail/index.js +323 -323
  335. package/example/views/ProductImagesExample/index.js +43 -43
  336. package/example/views/ProductOptionExample/index.js +88 -88
  337. package/example/views/ProductShareExample/index.js +51 -51
  338. package/example/views/ProductsListExample/index.js +77 -77
  339. package/example/views/ProductsListingExample/index.js +47 -47
  340. package/example/views/ResetPasswordExample/index.js +60 -60
  341. package/example/views/SearchOptionsExample/index.js +42 -42
  342. package/example/views/SessionManager/index.js +122 -122
  343. package/example/views/Signup/index.js +64 -64
  344. package/example/views/UpsellingPageExample/index.js +35 -35
  345. package/example/views/UserDetailsExample/index.js +69 -69
  346. package/example/views/UserProfile/index.js +73 -73
  347. package/index-example.js +37 -37
  348. package/index.html +13 -13
  349. package/native/index.js +255 -255
  350. package/native/src/NativeStrategy/index.js +20 -20
  351. package/native/src/contexts/OrderingContext/index.js +85 -85
  352. package/package.json +94 -94
  353. package/src/components/AddressDetails/index.js +149 -149
  354. package/src/components/AddressForm/index.js +333 -333
  355. package/src/components/AddressList/index.js +212 -212
  356. package/src/components/Analitycs/index.js +119 -119
  357. package/src/components/AnalyticsSegment/index.js +136 -136
  358. package/src/components/AppleLogin/index.js +164 -164
  359. package/src/components/BaseComponent/index.js +52 -52
  360. package/src/components/BusinessAndProductList/index.js +981 -981
  361. package/src/components/BusinessBasicInformation/index.js +119 -119
  362. package/src/components/BusinessController/index.js +351 -351
  363. package/src/components/BusinessInformation/BusinessOption/index.js +86 -86
  364. package/src/components/BusinessInformation/index.js +93 -93
  365. package/src/components/BusinessList/index.js +670 -670
  366. package/src/components/BusinessMenuListing/index.js +99 -99
  367. package/src/components/BusinessProductsCategories/index.js +60 -60
  368. package/src/components/BusinessProductsSearch/index.js +54 -54
  369. package/src/components/BusinessReviews/index.js +187 -187
  370. package/src/components/BusinessSearchList/index.js +363 -363
  371. package/src/components/BusinessSortControl/index.js +100 -100
  372. package/src/components/BusinessTypeFilter/index.js +142 -142
  373. package/src/components/BusinessesMap/index.js +110 -110
  374. package/src/components/Cart/index.js +210 -210
  375. package/src/components/CartStoresListing/index.js +157 -157
  376. package/src/components/Checkout/index.js +618 -618
  377. package/src/components/CmsContent/index.js +97 -97
  378. package/src/components/Contacts/index.js +512 -512
  379. package/src/components/CouponControl/index.js +171 -171
  380. package/src/components/DragAndDrop/index.js +41 -41
  381. package/src/components/DriverList/index.js +112 -112
  382. package/src/components/DriverTips/index.js +141 -141
  383. package/src/components/Emitter/index.js +36 -36
  384. package/src/components/ExamineClick/index.js +40 -40
  385. package/src/components/FacebookLoginButton/index.js +214 -214
  386. package/src/components/FacebookPixel/index.js +148 -148
  387. package/src/components/FavoriteList/index.js +268 -268
  388. package/src/components/FirebaseGoogleLoginButton/index.js +93 -93
  389. package/src/components/FloatingButton/index.js +70 -70
  390. package/src/components/ForgotPasswordForm/index.js +180 -180
  391. package/src/components/GiftCard/GiftCardOrdersList/index.js +155 -155
  392. package/src/components/GiftCard/PurchaseGiftCard/index.js +123 -123
  393. package/src/components/GiftCard/RedeemGiftCard/index.js +73 -73
  394. package/src/components/GiftCard/SendGiftCard/index.js +78 -78
  395. package/src/components/GoogleAutocompleteInput/index.js +154 -154
  396. package/src/components/GoogleIdentity/index.js +144 -144
  397. package/src/components/GoogleLoginButton/index.js +276 -276
  398. package/src/components/GoogleMaps/index.js +489 -489
  399. package/src/components/GpsButton/index.js +127 -127
  400. package/src/components/LanguageSelector/index.js +163 -163
  401. package/src/components/LoginForm/index.js +521 -521
  402. package/src/components/LogoutAction/index.js +165 -165
  403. package/src/components/MainSearch/index.js +149 -149
  404. package/src/components/MapView/index.js +110 -110
  405. package/src/components/MenuControl/index.js +238 -238
  406. package/src/components/Messages/index.js +166 -166
  407. package/src/components/MomentOption/index.js +322 -322
  408. package/src/components/MultiCartCreate/index.js +70 -70
  409. package/src/components/MultiCartsPaymethodsAndWallets/index.js +201 -201
  410. package/src/components/MultiCheckout/index.js +371 -371
  411. package/src/components/MultiOrdersDetails/index.js +109 -109
  412. package/src/components/MyOrders/index.js +150 -150
  413. package/src/components/MyOrdersList/index.js +104 -104
  414. package/src/components/NewOrderNotification/index.js +30 -30
  415. package/src/components/OrderChange/index.js +128 -128
  416. package/src/components/OrderDetails/index.js +684 -684
  417. package/src/components/OrderList/index.js +781 -781
  418. package/src/components/OrderListGroups/index.js +1168 -1168
  419. package/src/components/OrderReview/index.js +180 -180
  420. package/src/components/OrderTypeControl/index.js +75 -75
  421. package/src/components/OrderVerticalList/index.js +422 -422
  422. package/src/components/OrdersControlFilters/index.js +75 -75
  423. package/src/components/OrdersDashboardComponents/Appointments/index.js +72 -72
  424. package/src/components/OrdersDashboardComponents/BusinessProductsListing/index.js +629 -629
  425. package/src/components/OrdersDashboardComponents/CheckPassword/index.js +177 -177
  426. package/src/components/OrdersDashboardComponents/CityList/index.js +98 -98
  427. package/src/components/OrdersDashboardComponents/CountryList/index.js +162 -162
  428. package/src/components/OrdersDashboardComponents/CustomOrderDetails/index.js +238 -238
  429. package/src/components/OrdersDashboardComponents/DashboardBusinessList/index.js +617 -617
  430. package/src/components/OrdersDashboardComponents/DashboardOrdersList/index.js +943 -943
  431. package/src/components/OrdersDashboardComponents/DriversList/index.js +448 -448
  432. package/src/components/OrdersDashboardComponents/ExportCSV/index.js +192 -192
  433. package/src/components/OrdersDashboardComponents/GiftCardsList/index.js +189 -189
  434. package/src/components/OrdersDashboardComponents/GoogleMapsApiKeySetting/index.js +77 -77
  435. package/src/components/OrdersDashboardComponents/LogisticInformation/index.js +97 -97
  436. package/src/components/OrdersDashboardComponents/Logistics/index.js +174 -174
  437. package/src/components/OrdersDashboardComponents/Messages/index.js +384 -384
  438. package/src/components/OrdersDashboardComponents/MetaFields/index.js +186 -186
  439. package/src/components/OrdersDashboardComponents/OrderDetails/index.js +404 -404
  440. package/src/components/OrdersDashboardComponents/OrderNotification/index.js +70 -70
  441. package/src/components/OrdersDashboardComponents/OrdersFilter/index.js +362 -362
  442. package/src/components/OrdersDashboardComponents/OrdersManage/index.js +873 -873
  443. package/src/components/OrdersDashboardComponents/PointsWalletLevels/index.js +123 -123
  444. package/src/components/OrdersDashboardComponents/ReviewCustomer/index.js +113 -113
  445. package/src/components/OrdersDashboardComponents/Schedule/index.js +315 -315
  446. package/src/components/OrdersDashboardComponents/SettingsList/index.js +298 -298
  447. package/src/components/OrdersDashboardComponents/UserFormDetails/index.js +463 -463
  448. package/src/components/OrdersDashboardComponents/UsersList/index.js +944 -944
  449. package/src/components/OrdersDashboardComponents/WebsocketStatus/index.js +77 -77
  450. package/src/components/OrdersDashboardComponents/index.js +57 -57
  451. package/src/components/PageBanner/index.js +107 -107
  452. package/src/components/PaymentOptionCash/index.js +74 -74
  453. package/src/components/PaymentOptionPaypal/index.js +146 -146
  454. package/src/components/PaymentOptionSquare/index.js +336 -336
  455. package/src/components/PaymentOptionStripe/index.js +289 -289
  456. package/src/components/PaymentOptionStripeDirect/index.js +116 -116
  457. package/src/components/PaymentOptionStripeRedirect/StripeRedirectForm/index.js +71 -71
  458. package/src/components/PaymentOptionStripeRedirect/index.js +122 -122
  459. package/src/components/PaymentOptionWallet/index.js +185 -185
  460. package/src/components/PaymentOptions/index.js +248 -248
  461. package/src/components/PaymethodList/index.js +119 -119
  462. package/src/components/PhoneAutocomplete/index.js +311 -308
  463. package/src/components/PlaceSpot/index.js +176 -176
  464. package/src/components/Popup/index.js +169 -169
  465. package/src/components/ProductComponent/index.js +269 -269
  466. package/src/components/ProductForm/index.js +1090 -1090
  467. package/src/components/ProductImages/index.js +64 -64
  468. package/src/components/ProductIngredient/index.js +72 -72
  469. package/src/components/ProductOption/index.js +42 -42
  470. package/src/components/ProductOptionSuboption/index.js +180 -180
  471. package/src/components/ProductShare/index.js +97 -97
  472. package/src/components/ProductsList/index.js +74 -74
  473. package/src/components/ProductsListing/index.js +166 -166
  474. package/src/components/ProfessionalInfo/index.js +156 -156
  475. package/src/components/PromotionsController/index.js +123 -123
  476. package/src/components/QueryLoginSpoonity/index.js +159 -159
  477. package/src/components/ReCaptcha/index.js +53 -53
  478. package/src/components/ResetPassword/index.js +111 -111
  479. package/src/components/ReviewCustomer/index.js +117 -117
  480. package/src/components/ReviewDriver/index.js +157 -157
  481. package/src/components/ReviewProduct/index.js +162 -162
  482. package/src/components/SearchOptions/index.js +69 -69
  483. package/src/components/Sessions/index.js +217 -217
  484. package/src/components/SignupForm/index.js +547 -547
  485. package/src/components/SingleBusinessCard/index.js +80 -80
  486. package/src/components/SingleOrderCard/index.js +160 -160
  487. package/src/components/SingleProductCard/index.js +130 -130
  488. package/src/components/SingleProfessionalCard/index.js +121 -121
  489. package/src/components/SmartAppBanner/index.js +71 -71
  490. package/src/components/StoreProductList/index.js +303 -303
  491. package/src/components/StripeElementsForm/CardForm/index.js +248 -248
  492. package/src/components/StripeElementsForm/index.js +78 -78
  493. package/src/components/UpsellingPage/index.js +120 -120
  494. package/src/components/UserFormDetails/index.js +688 -688
  495. package/src/components/UserVerification/index.js +242 -242
  496. package/src/components/WalletList/index.js +160 -160
  497. package/src/components/WebsocketStatus/index.js +80 -80
  498. package/src/components/WrapperGoogleMaps/index.js +67 -67
  499. package/src/constants/code-numbers.js +218 -218
  500. package/src/constants/timezones.js +427 -427
  501. package/src/contexts/ApiContext/index.js +59 -59
  502. package/src/contexts/BillingContext/index.js +28 -28
  503. package/src/contexts/BusinessContext/index.js +71 -71
  504. package/src/contexts/ConfigContext/index.js +215 -215
  505. package/src/contexts/CustomerContext/index.js +69 -69
  506. package/src/contexts/EventContext/index.js +31 -31
  507. package/src/contexts/LanguageContext/index.js +144 -144
  508. package/src/contexts/OptimizationLoadContext/index.js +95 -95
  509. package/src/contexts/OrderContext/index.js +1448 -1448
  510. package/src/contexts/OrderingContext/index.js +86 -86
  511. package/src/contexts/OrderingThemeContext/index.js +107 -107
  512. package/src/contexts/ProductContext/index.js +62 -62
  513. package/src/contexts/SessionContext/index.js +172 -172
  514. package/src/contexts/SiteContext/index.js +79 -79
  515. package/src/contexts/ToastContext/index.js +42 -42
  516. package/src/contexts/UtilsContext/index.js +352 -352
  517. package/src/contexts/ValidationsFieldsContext/index.js +65 -65
  518. package/src/contexts/WebsocketContext/index.js +91 -91
  519. package/src/contexts/WebsocketContext/socket.js +92 -92
  520. package/src/index.js +369 -369
  521. package/src/utils/index.js +32 -32
  522. package/src/webStrategy/index.js +18 -18
  523. package/webpack.dev.js +41 -41
  524. package/webpack.prod.js +64 -64
  525. /package/_bundles/{0.ordering-component.05c8990567699e368292.js → 0.ordering-component.e2e1eb6df6c8a20c9636.js} +0 -0
  526. /package/_bundles/{1.ordering-component.05c8990567699e368292.js → 1.ordering-component.e2e1eb6df6c8a20c9636.js} +0 -0
  527. /package/_bundles/{2.ordering-component.05c8990567699e368292.js → 2.ordering-component.e2e1eb6df6c8a20c9636.js} +0 -0
  528. /package/_bundles/{4.ordering-component.05c8990567699e368292.js → 4.ordering-component.e2e1eb6df6c8a20c9636.js} +0 -0
  529. /package/_bundles/{5.ordering-component.05c8990567699e368292.js → 5.ordering-component.e2e1eb6df6c8a20c9636.js} +0 -0
  530. /package/_bundles/{6.ordering-component.05c8990567699e368292.js → 6.ordering-component.e2e1eb6df6c8a20c9636.js} +0 -0
  531. /package/_bundles/{7.ordering-component.05c8990567699e368292.js.LICENSE.txt → 7.ordering-component.e2e1eb6df6c8a20c9636.js.LICENSE.txt} +0 -0
  532. /package/_bundles/{8.ordering-component.05c8990567699e368292.js → 8.ordering-component.e2e1eb6df6c8a20c9636.js} +0 -0
  533. /package/_bundles/{ordering-component.05c8990567699e368292.js.LICENSE.txt → ordering-component.e2e1eb6df6c8a20c9636.js.LICENSE.txt} +0 -0
@@ -1,781 +1,781 @@
1
- import React, { useEffect, useState } from 'react'
2
- import PropTypes, { object, number } from 'prop-types'
3
-
4
- import { useSession } from '../../contexts/SessionContext'
5
- import { useApi } from '../../contexts/ApiContext'
6
- import { useWebsocket } from '../../contexts/WebsocketContext'
7
- import { ToastType, useToast } from '../../contexts/ToastContext'
8
- import { useLanguage } from '../../contexts/LanguageContext'
9
- import { useOrder } from '../../contexts/OrderContext'
10
- import { useEvent } from '../../contexts/EventContext'
11
- import dayjs from 'dayjs'
12
-
13
- export const OrderList = props => {
14
- const {
15
- UIComponent,
16
- orders,
17
- orderIds,
18
- orderStatus,
19
- orderBy,
20
- orderDirection,
21
- useDefualtSessionManager,
22
- paginationSettings,
23
- asDashboard,
24
- customArray,
25
- userCustomerId,
26
- activeOrders,
27
- isDynamicSort,
28
- businessId,
29
- franchiseId,
30
- businessesSearchList,
31
- setIsEmptyBusinesses,
32
- businessOrderIds,
33
- setBusinessOrderIds,
34
- propsToFetchBusiness,
35
- isBusiness,
36
- noGiftCardOrders,
37
- propsToFetch,
38
- handleRedirectToCheckout,
39
- isCustomerMode
40
- } = props
41
-
42
- const [ordering] = useApi()
43
- const socket = useWebsocket()
44
- const [orderState, { reorder }] = useOrder()
45
- const [session] = useSession()
46
- const [events] = useEvent()
47
- const [, { showToast }] = useToast()
48
- const [, t] = useLanguage()
49
- const [orderList, setOrderList] = useState({
50
- loading: !orders,
51
- error: null,
52
- orders: []
53
- })
54
- const [pagination, setPagination] = useState({
55
- currentPage: (paginationSettings.controlType === 'pages' && paginationSettings.initialPage && paginationSettings.initialPage >= 1) ? paginationSettings.initialPage - 1 : 0,
56
- pageSize: paginationSettings.pageSize ?? 10,
57
- total: null
58
- })
59
- const [messages, setMessages] = useState({ loading: false, error: null, messages: [] })
60
- const [updateOtherStatus, setUpdateOtherStatus] = useState([])
61
- const [sortBy, setSortBy] = useState({ param: orderBy, direction: orderDirection })
62
- const [reorderState, setReorderState] = useState({ loading: false, result: [], error: null })
63
- const [products, setProducts] = useState([])
64
- const [professionals, setProfessionals] = useState([])
65
- const [businesses, setBusinesses] = useState({ loading: false, result: [], error: null })
66
-
67
- const profileMessage = props.profileMessages
68
- const accessToken = useDefualtSessionManager ? session.token : props.accessToken
69
- const requestsState = {}
70
- const isValidMoment = (date, format) => dayjs.utc(date, format).format(format) === date
71
-
72
- const handleReorder = async (value) => {
73
- const orderId = Array.isArray(value) ? value : [value]
74
- if (!orderId?.length) return
75
-
76
- try {
77
- setReorderState({ ...reorderState, loading: true })
78
- const disableLoading = isCustomerMode
79
- const fetchOrders = async (ids) => {
80
- const promises = ids.map(async id => {
81
- const res = await reorder(id, ids?.length > 1, { disableLoading })
82
- return res
83
- })
84
- const data = await Promise.all(promises)
85
- return data
86
- }
87
-
88
- const reordersArray = await fetchOrders(orderId)
89
-
90
- const error = reordersArray.length && reordersArray.every(obj => obj.error) && reordersArray[0]?.result?.[0]
91
- const result = reordersArray.length && reordersArray.map(obj => (obj.result?.[0] ?? obj.result)).filter(o => typeof o !== 'string')
92
-
93
- const choosedOrder = orderList.orders.find(_order => _order?.id === orderId[0])
94
- const _businessId = choosedOrder?.business_id ?? choosedOrder?.original?.business_id
95
- const _businessData = await ordering.businesses(_businessId).select(['slug']).get()
96
- const _businessSlug = await _businessData?.content?.result?.slug
97
- const orderResult = { orderId: orderId[0], business_id: _businessId, business: { slug: _businessSlug } }
98
- if (result[0].uuid) {
99
- handleRedirectToCheckout(result[0].uuid)
100
- }
101
-
102
- setReorderState({
103
- ...reorderState,
104
- loading: false,
105
- error,
106
- result: error ? orderResult : { ...(result[0]), orderId: orderId[0] }
107
- })
108
- } catch (err) {
109
- setReorderState({
110
- ...reorderState,
111
- loading: false,
112
- error: true,
113
- result: [err?.message]
114
- })
115
- }
116
- }
117
-
118
- const getOrders = async (page, otherStatus = [], pageSize = paginationSettings.pageSize) => {
119
- const options = {
120
- query: {
121
- orderBy: `${sortBy.direction === 'desc' ? '-' : ''}${sortBy.param}`,
122
- page: page,
123
- page_size: pageSize
124
- }
125
- }
126
- if (orderIds || orderStatus) {
127
- options.query.where = []
128
- if (orderIds) {
129
- options.query.where.push({ attribute: 'id', value: orderIds })
130
- }
131
- if (orderStatus) {
132
- const searchByStatus = otherStatus?.length > 0 ? otherStatus : orderStatus
133
- options.query.where.push({ attribute: 'status', value: searchByStatus })
134
- }
135
- }
136
- if (userCustomerId) {
137
- options.query.where.push({ attribute: 'customer_id', value: parseInt(userCustomerId, 10) })
138
- }
139
- if (businessId) {
140
- options.query.where.push({ attribute: 'business_id', value: parseInt(businessId, 10) })
141
- }
142
- if (franchiseId) {
143
- options.query.where.push({ attribute: 'ref_business', conditions: [{ attribute: 'franchise_id', value: parseInt(franchiseId, 10) }] })
144
- }
145
- if (noGiftCardOrders) {
146
- options.query.where.push({
147
- attribute: 'products',
148
- conditions: [{
149
- attribute: 'type',
150
- value: {
151
- condition: '=',
152
- value: 'item'
153
- }
154
- }]
155
- })
156
- }
157
-
158
- const source = {}
159
- requestsState.orders = source
160
- options.cancelToken = source
161
- const functionFetch = asDashboard
162
- ? ordering.setAccessToken(accessToken).orders().asDashboard().select(propsToFetch)
163
- : ordering.setAccessToken(accessToken).orders().select(propsToFetch)
164
- return await functionFetch.get(options)
165
- }
166
-
167
- const loadOrders = async (
168
- isNextPage,
169
- searchByOtherStatus,
170
- keepOrders = false,
171
- getFirstOrder
172
- ) => {
173
- if (
174
- pagination?.currentPage === pagination?.totalPages &&
175
- pagination?.total !== null &&
176
- !getFirstOrder
177
- ) {
178
- return
179
- }
180
-
181
- const pageSize = keepOrders
182
- ? paginationSettings.pageSize * pagination.currentPage
183
- : paginationSettings.pageSize
184
- if (!session.token) {
185
- setOrderList({
186
- ...orderList,
187
- loading: false
188
- })
189
- return
190
- }
191
- try {
192
- setOrderList({
193
- ...orderList,
194
- loading: true
195
- })
196
- if (isBusiness) {
197
- setBusinesses({
198
- ...businesses,
199
- loading: true
200
- })
201
- }
202
- const nextPage = !isNextPage ? pagination.currentPage + 1 : 1
203
- const response = await getOrders(getFirstOrder && !asDashboard ? 0 : nextPage, searchByOtherStatus, pageSize)
204
-
205
- if (searchByOtherStatus) {
206
- setOrderList({
207
- loading: false,
208
- orders: response.content.error
209
- ? []
210
- : [...response.content.result, ...orderList.orders],
211
- error: response.content.error ? response.content.result : null
212
- })
213
- } else {
214
- setOrderList({
215
- loading: false,
216
- orders: response.content.error ? [] : response.content.result,
217
- error: response.content.error ? response.content.result : null
218
- })
219
- }
220
- setProfessionals([...response.content.result, ...orderList.orders]
221
- .reduce((previousValue, currentValue) => previousValue.concat(currentValue?.products?.[0]?.calendar_event?.professional), [])
222
- .filter((professional, i, hash) => professional && hash?.map(_professional => _professional?.id)?.indexOf(professional?.id) === i)
223
- )
224
- const businessIds = [...response.content.result, ...orderList.orders].map(order => order.business_id)
225
- setBusinessOrderIds && setBusinessOrderIds(businessIds)
226
- setProducts(
227
- [...response.content.result, ...orderList.orders]
228
- ?.filter(order => !businessesSearchList || businessesSearchList?.businesses?.some(business => order?.business_id === business?.id))
229
- ?.map(order => order?.products?.map(product => ({ ...product, business: order?.business, businessId: order?.business_id })))
230
- ?.flat()
231
- ?.filter((product, i, hash) => hash.map(_product => _product?.product_id).indexOf(product?.product_id) === i)
232
- )
233
- if (isBusiness) {
234
- getBusinesses(businessIds)
235
- }
236
-
237
- if (!response.content.error) {
238
- setPagination({
239
- currentPage: keepOrders
240
- ? pagination.currentPage
241
- : response.content.pagination.current_page,
242
- pageSize: response.content.pagination.page_size,
243
- totalPages: keepOrders
244
- ? pagination.totalPages
245
- : response.content.pagination.total_pages,
246
- total: keepOrders
247
- ? pagination.total
248
- : response.content.pagination.total,
249
- from: keepOrders ? 1 : response.content.pagination.from,
250
- to: keepOrders ? pagination.to : response.content.pagination.to
251
- })
252
- }
253
- } catch (err) {
254
- if (err.constructor.name !== 'Cancel') {
255
- setOrderList({ ...orderList, loading: false, error: [err.message] })
256
- setBusinesses({
257
- ...businesses,
258
- loading: false
259
- })
260
- }
261
- }
262
- }
263
-
264
- const handleUpdateOrderList = (orderId, changes) => {
265
- const updatedOrders = orderList?.orders.map(order => {
266
- if (order?.id === orderId) {
267
- return {
268
- ...order,
269
- ...changes
270
- }
271
- }
272
- return order
273
- })
274
- setOrderList({
275
- ...orderList,
276
- orders: updatedOrders
277
- })
278
- }
279
-
280
- const loadMessages = async (orderId) => {
281
- try {
282
- setMessages({ ...messages, loading: true })
283
- const url = `${ordering.root}/orders/${orderId}/messages?mode=dashboard`
284
-
285
- const response = await fetch(url, {
286
- method: 'GET',
287
- headers: {
288
- 'Content-Type': 'application/json',
289
- Authorization: `Bearer ${accessToken}`,
290
- 'X-App-X': ordering.appId,
291
- 'X-Socket-Id-X': socket?.getId()
292
- }
293
- })
294
- const { error, result } = await response.json()
295
- if (!error) {
296
- setMessages({
297
- messages: result,
298
- loading: false,
299
- error: null
300
- })
301
- } else {
302
- setMessages({
303
- ...messages,
304
- loading: false,
305
- error: result
306
- })
307
- }
308
- } catch (err) {
309
- setMessages({ ...messages, loading: false, error: [err.message] })
310
- }
311
- }
312
-
313
- const getBusinesses = async (businessIds) => {
314
- try {
315
- const parameters = {
316
- location: `${orderState.options?.address?.location?.lat},${orderState.options?.address?.location?.lng}`
317
- }
318
-
319
- if (orderState.options?.moment && isValidMoment(orderState.options?.moment, 'YYYY-MM-DD HH:mm:ss')) {
320
- const moment = dayjs.utc(orderState.options?.moment, 'YYYY-MM-DD HH:mm:ss').local().unix()
321
- parameters.timestamp = moment
322
- }
323
-
324
- let where = null
325
- const conditions = []
326
-
327
- if (businessIds) {
328
- conditions.push({
329
- attribute: typeof businessIds === 'string' ? 'slug' : 'id',
330
- value: businessIds
331
- })
332
- }
333
-
334
- if (conditions.length) {
335
- where = {
336
- conditions,
337
- conector: 'AND'
338
- }
339
- }
340
-
341
- const source = {}
342
- requestsState.businesses = source
343
-
344
- const fetchEndpoint = ordering.businesses().select(propsToFetchBusiness).parameters(parameters).where(where)
345
-
346
- const { content: { error, result } } = await fetchEndpoint.get({ cancelToken: source })
347
- if (!error) {
348
- setBusinesses({
349
- result,
350
- error: null,
351
- loading: false
352
- })
353
- }
354
- } catch (err) {
355
- if (err.constructor.name !== 'Cancel') {
356
- setBusinesses({
357
- ...businesses,
358
- err: err.message,
359
- loading: false
360
- })
361
- }
362
- }
363
- }
364
-
365
- // Function to update professional list
366
- const handleUpdateProfessionals = (id, changes) => {
367
- const updateProfessionals = professionals.map(professional => {
368
- if (professional?.id === id) {
369
- return {
370
- ...professional,
371
- ...changes
372
- }
373
- }
374
- return professional
375
- })
376
- setProfessionals(updateProfessionals)
377
- }
378
-
379
- useEffect(() => {
380
- if (orders || customArray) {
381
- setOrderList({
382
- ...orderList,
383
- orders: orders?.lenght > 0 ? orders : customArray || [],
384
- loading: false
385
- })
386
- } else if (!businessesSearchList) {
387
- loadOrders(false, false, false, true)
388
- }
389
-
390
- return () => {
391
- if (requestsState.orders) {
392
- requestsState.orders.cancel()
393
- }
394
- }
395
- }, [isBusiness])
396
-
397
- useEffect(() => {
398
- if (orderList.loading || isCustomerMode || !socket?.socket) return
399
- const handleUpdateOrder = (order) => {
400
- const found = orderList.orders.find(_order => _order.id === order.id)
401
- let orders = []
402
- if (found) {
403
- showToast(ToastType.Info, t('SPECIFIC_ORDER_UPDATED', 'Your order number _NUMBER_ has updated').replace('_NUMBER_', order.id), 1000)
404
- orders = orderList.orders.filter(_order => {
405
- if (_order.id === order.id && _order?.driver?.id !== order?.driver?.id && session?.user?.level === 4) {
406
- return false
407
- }
408
-
409
- if (_order.id === order.id) {
410
- delete order.total
411
- delete order.subtotal
412
- Object.assign(_order, order)
413
- }
414
-
415
- const valid = orderStatus.length === 0 || orderStatus.includes(parseInt(_order.status)) || updateOtherStatus.length === 0 || updateOtherStatus.includes(parseInt(_order.status))
416
- if (!valid) {
417
- pagination.total--
418
- setPagination({
419
- ...pagination
420
- })
421
- }
422
- return valid
423
- })
424
- } else {
425
- orders = [order, ...orderList.orders]
426
- pagination.total++
427
- setPagination({
428
- ...pagination
429
- })
430
- }
431
- setOrderList({
432
- ...orderList,
433
- orders,
434
- loading: false
435
- })
436
- }
437
-
438
- const handleAddNewOrder = (order) => {
439
- showToast(ToastType.Info, t('SPECIFIC_ORDER_ORDERED', 'Order _NUMBER_ has been ordered').replace('_NUMBER_', order.id))
440
- const newOrder = [order, ...orderList.orders]
441
- setOrderList({
442
- ...orderList,
443
- orders: newOrder,
444
- loading: false
445
- })
446
- }
447
-
448
- const ordersRoom = !props.isAsCustomer && session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
449
- socket.join(ordersRoom)
450
- if (!socket?.socket?._callbacks?.$orders_register || socket?.socket?._callbacks?.$orders_register?.find(func => func?.name !== 'handleAddNewOrder')) {
451
- socket.on('orders_register', handleAddNewOrder)
452
- }
453
- if (!socket?.socket?._callbacks?.$update_order || socket?.socket?._callbacks?.$update_order?.find(func => func?.name !== 'handleUpdateOrder')) {
454
- socket.on('update_order', handleUpdateOrder)
455
- }
456
- return () => {
457
- socket.off('update_order', handleUpdateOrder)
458
- socket.off('orders_register', handleAddNewOrder)
459
- }
460
- }, [orderList.loading, socket?.socket, session, isCustomerMode])
461
-
462
- useEffect(() => {
463
- if (!session.user || isCustomerMode) return
464
- socket.on('disconnect', (reason) => {
465
- const ordersRoom = !props.isAsCustomer && session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
466
- socket.join(ordersRoom)
467
- })
468
- const ordersRoom = !props.isAsCustomer && session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
469
- socket.join(ordersRoom)
470
- return () => {
471
- socket.leave(ordersRoom)
472
- }
473
- }, [socket, session, userCustomerId, isCustomerMode])
474
-
475
- const loadMoreOrders = async (searchByOtherStatus) => {
476
- setOrderList({ ...orderList, loading: true })
477
- try {
478
- const response = await getOrders(pagination.currentPage + 1, searchByOtherStatus)
479
- setOrderList({
480
- loading: false,
481
- orders: response.content.error ? orderList.orders : orderList.orders.concat(response.content.result),
482
- error: response.content.error ? response.content.result : null
483
- })
484
- if (!response.content.error) {
485
- setPagination({
486
- currentPage: response.content.pagination.current_page,
487
- pageSize: response.content.pagination.page_size,
488
- totalPages: response.content.pagination.total_pages,
489
- total: response.content.pagination.total,
490
- from: response.content.pagination.from,
491
- to: response.content.pagination.to
492
- })
493
- }
494
- } catch (err) {
495
- if (err.constructor.name !== 'Cancel') {
496
- setOrderList({ ...orderList, loading: false, error: [err.message] })
497
- }
498
- }
499
- }
500
-
501
- const goToPage = async page => {
502
- setOrderList({ ...orderList, loading: true })
503
- try {
504
- const response = await getOrders(page)
505
- setOrderList({
506
- loading: false,
507
- orders: response.content.error ? [] : response.content.result,
508
- error: response.content.error ? response.content.result : null
509
- })
510
- if (!response.content.error) {
511
- setPagination({
512
- currentPage: response.content.pagination.current_page,
513
- pageSize: response.content.pagination.page_size,
514
- totalPages: response.content.pagination.total_pages,
515
- total: response.content.pagination.total,
516
- from: response.content.pagination.from,
517
- to: response.content.pagination.to
518
- })
519
- }
520
- } catch (err) {
521
- if (err.constructor.name !== 'Cancel') {
522
- setOrderList({ ...orderList, loading: false, error: [err.message] })
523
- }
524
- }
525
- }
526
-
527
- const sortOrders = (orders, sortBy = 'desc') => {
528
- const ordersSorted = orders.sort((a, b) => {
529
- if (sortBy === 'desc') {
530
- return b.id - a.id
531
- }
532
- return a.id - b.id
533
- })
534
-
535
- return ordersSorted
536
- }
537
-
538
- const handleUpdateProducts = (productId, changes) => {
539
- const updatedProducts = products?.map(product => {
540
- if (product?.product_id === productId) {
541
- return {
542
- ...product,
543
- ...changes
544
- }
545
- }
546
- return product
547
- })
548
- setProducts(updatedProducts)
549
- }
550
-
551
- const handleUpdateBusinesses = (businessId, changes) => {
552
- const updatedBusiness = businesses?.result?.map(business => {
553
- if (business?.id === businessId) {
554
- return {
555
- ...business,
556
- ...changes
557
- }
558
- }
559
- return business
560
- })
561
- setBusinesses({
562
- ...businesses,
563
- result: updatedBusiness
564
- })
565
- }
566
-
567
- const getPage = async (page, pageSize) => {
568
- setOrderList({ ...orderList, loading: true })
569
- try {
570
- const response = await getOrders(page, pageSize)
571
- setOrderList({
572
- loading: false,
573
- orders: response.content.error ? orderList.orders : response.content.result,
574
- error: response.content.error ? response.content.result : null
575
- })
576
- if (!response.content.error) {
577
- setPagination({
578
- currentPage: response.content.pagination.current_page,
579
- pageSize: response.content.pagination.page_size,
580
- totalPages: response.content.pagination.total_pages,
581
- total: response.content.pagination.total,
582
- from: response.content.pagination.from,
583
- to: response.content.pagination.to
584
- })
585
- }
586
- } catch (err) {
587
- if (err.constructor.name !== 'Cancel') {
588
- setOrderList({ ...orderList, loading: false, error: [err.message] })
589
- }
590
- }
591
- }
592
-
593
- useEffect(() => {
594
- if (profileMessage) return
595
- if (!orderList.loading && orderBy !== 'last_direct_message_at') {
596
- const ordersSorted = orderList.orders.sort((a, b) => {
597
- if (activeOrders) {
598
- return dayjs(b.created_at).unix() - dayjs(a.created_at).unix()
599
- }
600
- return dayjs(a.created_at).unix() - dayjs(b.created_at).unix()
601
- })
602
- setOrderList({
603
- ...orderList,
604
- orders: ordersSorted
605
- })
606
- }
607
- }, [orderList.loading, orderBy])
608
-
609
- /**
610
- * This effect is used to reload orders with dynamic params, using `isDynamicSort` as validation
611
- */
612
- useEffect(() => {
613
- if (isDynamicSort) {
614
- loadOrders(true, [])
615
- }
616
- }, [sortBy])
617
-
618
- useEffect(() => {
619
- if (businessesSearchList && !businessesSearchList?.loading) {
620
- loadOrders(false, false, false, true)
621
- }
622
- }, [businessesSearchList, businessId])
623
-
624
- useEffect(() => {
625
- setIsEmptyBusinesses && setIsEmptyBusinesses(businessOrderIds?.length === 0)
626
- }, [businessOrderIds])
627
-
628
- useEffect(() => {
629
- const handleOrderMessageRead = (orderId) => {
630
- const updatedOrders = orderList.orders.map(order => {
631
- if (order.id === orderId) {
632
- return { ...order, unread_count: 0 }
633
- }
634
- return order
635
- })
636
- setOrderList({
637
- ...orderList,
638
- orders: updatedOrders
639
- })
640
- }
641
- events.on('order_message_read', handleOrderMessageRead)
642
- return () => {
643
- events.off('order_message_read', handleOrderMessageRead)
644
- }
645
- }, [orderList.orders])
646
-
647
- return (
648
- <>
649
- {UIComponent && (
650
- <UIComponent
651
- {...props}
652
- sortOrders={sortOrders}
653
- setSortBy={setSortBy}
654
- orderList={orderList}
655
- pagination={pagination}
656
- loadMoreOrders={loadMoreOrders}
657
- goToPage={goToPage}
658
- loadOrders={loadOrders}
659
- loadMessages={loadMessages}
660
- messages={messages}
661
- setMessages={setMessages}
662
- setUpdateOtherStatus={setUpdateOtherStatus}
663
- handleReorder={handleReorder}
664
- reorderState={reorderState}
665
- businessOrderIds={businessOrderIds}
666
- products={products}
667
- handleUpdateOrderList={handleUpdateOrderList}
668
- handleUpdateProducts={handleUpdateProducts}
669
- handleUpdateBusinesses={handleUpdateBusinesses}
670
- businesses={businesses}
671
- professionals={professionals}
672
- handleUpdateProfessionals={handleUpdateProfessionals}
673
- getPage={getPage}
674
- />
675
- )}
676
- </>
677
- )
678
- }
679
-
680
- OrderList.propTypes = {
681
- /**
682
- * UI Component, this must be containt all graphic elements and use parent props
683
- */
684
- UIComponent: PropTypes.elementType,
685
- /**
686
- * Function to get order that was clicked
687
- * @param {Object} order Order that was clicked
688
- */
689
- onOrderClick: PropTypes.func,
690
- /**
691
- * Enable/Disable default session manager
692
- * Save user and token with default session manager
693
- */
694
- useDefualtSessionManager: PropTypes.bool,
695
- /**
696
- * Access token to update user
697
- * Is required when `useDefualtSessionManager` is false
698
- */
699
- accessToken: (props, propName) => {
700
- if (props[propName] !== undefined && typeof props[propName] !== 'string') {
701
- return new Error(
702
- `Invalid prop \`${propName}\` of type \`${typeof props[
703
- propName
704
- ]}\` supplied to \`UserProfile\`, expected \`object\`.`
705
- )
706
- }
707
- if (props[propName] === undefined && !props.useDefualtSessionManager) {
708
- return new Error(
709
- `Invalid prop \`${propName}\` is required when \`useDefualtSessionManager\` is false.`
710
- )
711
- }
712
- },
713
- /**
714
- * Array of orders
715
- * This is used of first option to show list
716
- */
717
- orders: PropTypes.arrayOf(object),
718
- /**
719
- * Array of id of orders
720
- * Get a list of orders by ids form Ordering API
721
- */
722
- orderIds: PropTypes.arrayOf(number),
723
- /**
724
- * Array of id of orders
725
- * Get a list of orders by status form Ordering API
726
- * This can be use together `orderIds` option but not has effect with `orders` option
727
- */
728
- orderStatus: PropTypes.arrayOf(number),
729
- /**
730
- * Order orders by some attribute. Default by `id`.
731
- */
732
- orderBy: PropTypes.string,
733
- /**
734
- * Order direction ascendent (asc) or descendent (desc). Default is `desc`.
735
- */
736
- orderDirection: PropTypes.oneOf(['asc', 'desc']),
737
- /**
738
- * Pagination settings
739
- * You can set the pageSize, initialPage and controlType can be by pages or infinity
740
- */
741
- paginationSettings: PropTypes.exact({
742
- /**
743
- * initialPage only work with control type `pages`
744
- */
745
- initialPage: PropTypes.number,
746
- pageSize: PropTypes.number,
747
- controlType: PropTypes.oneOf(['infinity', 'pages'])
748
- }),
749
- /**
750
- * Components types before Facebook login button
751
- * Array of type components, the parent props will pass to these components
752
- */
753
- beforeComponents: PropTypes.arrayOf(PropTypes.elementType),
754
- /**
755
- * Components types after Facebook login button
756
- * Array of type components, the parent props will pass to these components
757
- */
758
- afterComponents: PropTypes.arrayOf(PropTypes.elementType),
759
- /**
760
- * Elements before Facebook login button
761
- * Array of HTML/Components elements, these components will not get the parent props
762
- */
763
- beforeElements: PropTypes.arrayOf(PropTypes.element),
764
- /**
765
- * Elements after Facebook login button
766
- * Array of HTML/Components elements, these components will not get the parent props
767
- */
768
- afterElements: PropTypes.arrayOf(PropTypes.element)
769
- }
770
-
771
- OrderList.defaultProps = {
772
- orderBy: 'id',
773
- orderDirection: 'desc',
774
- paginationSettings: { initialPage: 1, pageSize: 10, controlType: 'infinity' },
775
- beforeComponents: [],
776
- afterComponents: [],
777
- beforeElements: [],
778
- afterElements: [],
779
- isAsCustomer: false,
780
- propsToFetchBusiness: ['id', 'name', 'header', 'logo', 'location', 'schedule', 'open', 'ribbon', 'delivery_price', 'distance', 'delivery_time', 'pickup_time', 'reviews', 'featured', 'offers', 'food', 'laundry', 'alcohol', 'groceries', 'slug', 'city', 'city_id']
781
- }
1
+ import React, { useEffect, useState } from 'react'
2
+ import PropTypes, { object, number } from 'prop-types'
3
+
4
+ import { useSession } from '../../contexts/SessionContext'
5
+ import { useApi } from '../../contexts/ApiContext'
6
+ import { useWebsocket } from '../../contexts/WebsocketContext'
7
+ import { ToastType, useToast } from '../../contexts/ToastContext'
8
+ import { useLanguage } from '../../contexts/LanguageContext'
9
+ import { useOrder } from '../../contexts/OrderContext'
10
+ import { useEvent } from '../../contexts/EventContext'
11
+ import dayjs from 'dayjs'
12
+
13
+ export const OrderList = props => {
14
+ const {
15
+ UIComponent,
16
+ orders,
17
+ orderIds,
18
+ orderStatus,
19
+ orderBy,
20
+ orderDirection,
21
+ useDefualtSessionManager,
22
+ paginationSettings,
23
+ asDashboard,
24
+ customArray,
25
+ userCustomerId,
26
+ activeOrders,
27
+ isDynamicSort,
28
+ businessId,
29
+ franchiseId,
30
+ businessesSearchList,
31
+ setIsEmptyBusinesses,
32
+ businessOrderIds,
33
+ setBusinessOrderIds,
34
+ propsToFetchBusiness,
35
+ isBusiness,
36
+ noGiftCardOrders,
37
+ propsToFetch,
38
+ handleRedirectToCheckout,
39
+ isCustomerMode
40
+ } = props
41
+
42
+ const [ordering] = useApi()
43
+ const socket = useWebsocket()
44
+ const [orderState, { reorder }] = useOrder()
45
+ const [session] = useSession()
46
+ const [events] = useEvent()
47
+ const [, { showToast }] = useToast()
48
+ const [, t] = useLanguage()
49
+ const [orderList, setOrderList] = useState({
50
+ loading: !orders,
51
+ error: null,
52
+ orders: []
53
+ })
54
+ const [pagination, setPagination] = useState({
55
+ currentPage: (paginationSettings.controlType === 'pages' && paginationSettings.initialPage && paginationSettings.initialPage >= 1) ? paginationSettings.initialPage - 1 : 0,
56
+ pageSize: paginationSettings.pageSize ?? 10,
57
+ total: null
58
+ })
59
+ const [messages, setMessages] = useState({ loading: false, error: null, messages: [] })
60
+ const [updateOtherStatus, setUpdateOtherStatus] = useState([])
61
+ const [sortBy, setSortBy] = useState({ param: orderBy, direction: orderDirection })
62
+ const [reorderState, setReorderState] = useState({ loading: false, result: [], error: null })
63
+ const [products, setProducts] = useState([])
64
+ const [professionals, setProfessionals] = useState([])
65
+ const [businesses, setBusinesses] = useState({ loading: false, result: [], error: null })
66
+
67
+ const profileMessage = props.profileMessages
68
+ const accessToken = useDefualtSessionManager ? session.token : props.accessToken
69
+ const requestsState = {}
70
+ const isValidMoment = (date, format) => dayjs.utc(date, format).format(format) === date
71
+
72
+ const handleReorder = async (value) => {
73
+ const orderId = Array.isArray(value) ? value : [value]
74
+ if (!orderId?.length) return
75
+
76
+ try {
77
+ setReorderState({ ...reorderState, loading: true })
78
+ const disableLoading = isCustomerMode
79
+ const fetchOrders = async (ids) => {
80
+ const promises = ids.map(async id => {
81
+ const res = await reorder(id, ids?.length > 1, { disableLoading })
82
+ return res
83
+ })
84
+ const data = await Promise.all(promises)
85
+ return data
86
+ }
87
+
88
+ const reordersArray = await fetchOrders(orderId)
89
+
90
+ const error = reordersArray.length && reordersArray.every(obj => obj.error) && reordersArray[0]?.result?.[0]
91
+ const result = reordersArray.length && reordersArray.map(obj => (obj.result?.[0] ?? obj.result)).filter(o => typeof o !== 'string')
92
+
93
+ const choosedOrder = orderList.orders.find(_order => _order?.id === orderId[0])
94
+ const _businessId = choosedOrder?.business_id ?? choosedOrder?.original?.business_id
95
+ const _businessData = await ordering.businesses(_businessId).select(['slug']).get()
96
+ const _businessSlug = await _businessData?.content?.result?.slug
97
+ const orderResult = { orderId: orderId[0], business_id: _businessId, business: { slug: _businessSlug } }
98
+ if (result[0].uuid) {
99
+ handleRedirectToCheckout(result[0].uuid)
100
+ }
101
+
102
+ setReorderState({
103
+ ...reorderState,
104
+ loading: false,
105
+ error,
106
+ result: error ? orderResult : { ...(result[0]), orderId: orderId[0] }
107
+ })
108
+ } catch (err) {
109
+ setReorderState({
110
+ ...reorderState,
111
+ loading: false,
112
+ error: true,
113
+ result: [err?.message]
114
+ })
115
+ }
116
+ }
117
+
118
+ const getOrders = async (page, otherStatus = [], pageSize = paginationSettings.pageSize) => {
119
+ const options = {
120
+ query: {
121
+ orderBy: `${sortBy.direction === 'desc' ? '-' : ''}${sortBy.param}`,
122
+ page: page,
123
+ page_size: pageSize
124
+ }
125
+ }
126
+ if (orderIds || orderStatus) {
127
+ options.query.where = []
128
+ if (orderIds) {
129
+ options.query.where.push({ attribute: 'id', value: orderIds })
130
+ }
131
+ if (orderStatus) {
132
+ const searchByStatus = otherStatus?.length > 0 ? otherStatus : orderStatus
133
+ options.query.where.push({ attribute: 'status', value: searchByStatus })
134
+ }
135
+ }
136
+ if (userCustomerId) {
137
+ options.query.where.push({ attribute: 'customer_id', value: parseInt(userCustomerId, 10) })
138
+ }
139
+ if (businessId) {
140
+ options.query.where.push({ attribute: 'business_id', value: parseInt(businessId, 10) })
141
+ }
142
+ if (franchiseId) {
143
+ options.query.where.push({ attribute: 'ref_business', conditions: [{ attribute: 'franchise_id', value: parseInt(franchiseId, 10) }] })
144
+ }
145
+ if (noGiftCardOrders) {
146
+ options.query.where.push({
147
+ attribute: 'products',
148
+ conditions: [{
149
+ attribute: 'type',
150
+ value: {
151
+ condition: '=',
152
+ value: 'item'
153
+ }
154
+ }]
155
+ })
156
+ }
157
+
158
+ const source = {}
159
+ requestsState.orders = source
160
+ options.cancelToken = source
161
+ const functionFetch = asDashboard
162
+ ? ordering.setAccessToken(accessToken).orders().asDashboard().select(propsToFetch)
163
+ : ordering.setAccessToken(accessToken).orders().select(propsToFetch)
164
+ return await functionFetch.get(options)
165
+ }
166
+
167
+ const loadOrders = async (
168
+ isNextPage,
169
+ searchByOtherStatus,
170
+ keepOrders = false,
171
+ getFirstOrder
172
+ ) => {
173
+ if (
174
+ pagination?.currentPage === pagination?.totalPages &&
175
+ pagination?.total !== null &&
176
+ !getFirstOrder
177
+ ) {
178
+ return
179
+ }
180
+
181
+ const pageSize = keepOrders
182
+ ? paginationSettings.pageSize * pagination.currentPage
183
+ : paginationSettings.pageSize
184
+ if (!session.token) {
185
+ setOrderList({
186
+ ...orderList,
187
+ loading: false
188
+ })
189
+ return
190
+ }
191
+ try {
192
+ setOrderList({
193
+ ...orderList,
194
+ loading: true
195
+ })
196
+ if (isBusiness) {
197
+ setBusinesses({
198
+ ...businesses,
199
+ loading: true
200
+ })
201
+ }
202
+ const nextPage = !isNextPage ? pagination.currentPage + 1 : 1
203
+ const response = await getOrders(getFirstOrder && !asDashboard ? 0 : nextPage, searchByOtherStatus, pageSize)
204
+
205
+ if (searchByOtherStatus) {
206
+ setOrderList({
207
+ loading: false,
208
+ orders: response.content.error
209
+ ? []
210
+ : [...response.content.result, ...orderList.orders],
211
+ error: response.content.error ? response.content.result : null
212
+ })
213
+ } else {
214
+ setOrderList({
215
+ loading: false,
216
+ orders: response.content.error ? [] : response.content.result,
217
+ error: response.content.error ? response.content.result : null
218
+ })
219
+ }
220
+ setProfessionals([...response.content.result, ...orderList.orders]
221
+ .reduce((previousValue, currentValue) => previousValue.concat(currentValue?.products?.[0]?.calendar_event?.professional), [])
222
+ .filter((professional, i, hash) => professional && hash?.map(_professional => _professional?.id)?.indexOf(professional?.id) === i)
223
+ )
224
+ const businessIds = [...response.content.result, ...orderList.orders].map(order => order.business_id)
225
+ setBusinessOrderIds && setBusinessOrderIds(businessIds)
226
+ setProducts(
227
+ [...response.content.result, ...orderList.orders]
228
+ ?.filter(order => !businessesSearchList || businessesSearchList?.businesses?.some(business => order?.business_id === business?.id))
229
+ ?.map(order => order?.products?.map(product => ({ ...product, business: order?.business, businessId: order?.business_id })))
230
+ ?.flat()
231
+ ?.filter((product, i, hash) => hash.map(_product => _product?.product_id).indexOf(product?.product_id) === i)
232
+ )
233
+ if (isBusiness) {
234
+ getBusinesses(businessIds)
235
+ }
236
+
237
+ if (!response.content.error) {
238
+ setPagination({
239
+ currentPage: keepOrders
240
+ ? pagination.currentPage
241
+ : response.content.pagination.current_page,
242
+ pageSize: response.content.pagination.page_size,
243
+ totalPages: keepOrders
244
+ ? pagination.totalPages
245
+ : response.content.pagination.total_pages,
246
+ total: keepOrders
247
+ ? pagination.total
248
+ : response.content.pagination.total,
249
+ from: keepOrders ? 1 : response.content.pagination.from,
250
+ to: keepOrders ? pagination.to : response.content.pagination.to
251
+ })
252
+ }
253
+ } catch (err) {
254
+ if (err.constructor.name !== 'Cancel') {
255
+ setOrderList({ ...orderList, loading: false, error: [err.message] })
256
+ setBusinesses({
257
+ ...businesses,
258
+ loading: false
259
+ })
260
+ }
261
+ }
262
+ }
263
+
264
+ const handleUpdateOrderList = (orderId, changes) => {
265
+ const updatedOrders = orderList?.orders.map(order => {
266
+ if (order?.id === orderId) {
267
+ return {
268
+ ...order,
269
+ ...changes
270
+ }
271
+ }
272
+ return order
273
+ })
274
+ setOrderList({
275
+ ...orderList,
276
+ orders: updatedOrders
277
+ })
278
+ }
279
+
280
+ const loadMessages = async (orderId) => {
281
+ try {
282
+ setMessages({ ...messages, loading: true })
283
+ const url = `${ordering.root}/orders/${orderId}/messages?mode=dashboard`
284
+
285
+ const response = await fetch(url, {
286
+ method: 'GET',
287
+ headers: {
288
+ 'Content-Type': 'application/json',
289
+ Authorization: `Bearer ${accessToken}`,
290
+ 'X-App-X': ordering.appId,
291
+ 'X-Socket-Id-X': socket?.getId()
292
+ }
293
+ })
294
+ const { error, result } = await response.json()
295
+ if (!error) {
296
+ setMessages({
297
+ messages: result,
298
+ loading: false,
299
+ error: null
300
+ })
301
+ } else {
302
+ setMessages({
303
+ ...messages,
304
+ loading: false,
305
+ error: result
306
+ })
307
+ }
308
+ } catch (err) {
309
+ setMessages({ ...messages, loading: false, error: [err.message] })
310
+ }
311
+ }
312
+
313
+ const getBusinesses = async (businessIds) => {
314
+ try {
315
+ const parameters = {
316
+ location: `${orderState.options?.address?.location?.lat},${orderState.options?.address?.location?.lng}`
317
+ }
318
+
319
+ if (orderState.options?.moment && isValidMoment(orderState.options?.moment, 'YYYY-MM-DD HH:mm:ss')) {
320
+ const moment = dayjs.utc(orderState.options?.moment, 'YYYY-MM-DD HH:mm:ss').local().unix()
321
+ parameters.timestamp = moment
322
+ }
323
+
324
+ let where = null
325
+ const conditions = []
326
+
327
+ if (businessIds) {
328
+ conditions.push({
329
+ attribute: typeof businessIds === 'string' ? 'slug' : 'id',
330
+ value: businessIds
331
+ })
332
+ }
333
+
334
+ if (conditions.length) {
335
+ where = {
336
+ conditions,
337
+ conector: 'AND'
338
+ }
339
+ }
340
+
341
+ const source = {}
342
+ requestsState.businesses = source
343
+
344
+ const fetchEndpoint = ordering.businesses().select(propsToFetchBusiness).parameters(parameters).where(where)
345
+
346
+ const { content: { error, result } } = await fetchEndpoint.get({ cancelToken: source })
347
+ if (!error) {
348
+ setBusinesses({
349
+ result,
350
+ error: null,
351
+ loading: false
352
+ })
353
+ }
354
+ } catch (err) {
355
+ if (err.constructor.name !== 'Cancel') {
356
+ setBusinesses({
357
+ ...businesses,
358
+ err: err.message,
359
+ loading: false
360
+ })
361
+ }
362
+ }
363
+ }
364
+
365
+ // Function to update professional list
366
+ const handleUpdateProfessionals = (id, changes) => {
367
+ const updateProfessionals = professionals.map(professional => {
368
+ if (professional?.id === id) {
369
+ return {
370
+ ...professional,
371
+ ...changes
372
+ }
373
+ }
374
+ return professional
375
+ })
376
+ setProfessionals(updateProfessionals)
377
+ }
378
+
379
+ useEffect(() => {
380
+ if (orders || customArray) {
381
+ setOrderList({
382
+ ...orderList,
383
+ orders: orders?.lenght > 0 ? orders : customArray || [],
384
+ loading: false
385
+ })
386
+ } else if (!businessesSearchList) {
387
+ loadOrders(false, false, false, true)
388
+ }
389
+
390
+ return () => {
391
+ if (requestsState.orders) {
392
+ requestsState.orders.cancel()
393
+ }
394
+ }
395
+ }, [isBusiness])
396
+
397
+ useEffect(() => {
398
+ if (orderList.loading || isCustomerMode || !socket?.socket) return
399
+ const handleUpdateOrder = (order) => {
400
+ const found = orderList.orders.find(_order => _order.id === order.id)
401
+ let orders = []
402
+ if (found) {
403
+ showToast(ToastType.Info, t('SPECIFIC_ORDER_UPDATED', 'Your order number _NUMBER_ has updated').replace('_NUMBER_', order.id), 1000)
404
+ orders = orderList.orders.filter(_order => {
405
+ if (_order.id === order.id && _order?.driver?.id !== order?.driver?.id && session?.user?.level === 4) {
406
+ return false
407
+ }
408
+
409
+ if (_order.id === order.id) {
410
+ delete order.total
411
+ delete order.subtotal
412
+ Object.assign(_order, order)
413
+ }
414
+
415
+ const valid = orderStatus.length === 0 || orderStatus.includes(parseInt(_order.status)) || updateOtherStatus.length === 0 || updateOtherStatus.includes(parseInt(_order.status))
416
+ if (!valid) {
417
+ pagination.total--
418
+ setPagination({
419
+ ...pagination
420
+ })
421
+ }
422
+ return valid
423
+ })
424
+ } else {
425
+ orders = [order, ...orderList.orders]
426
+ pagination.total++
427
+ setPagination({
428
+ ...pagination
429
+ })
430
+ }
431
+ setOrderList({
432
+ ...orderList,
433
+ orders,
434
+ loading: false
435
+ })
436
+ }
437
+
438
+ const handleAddNewOrder = (order) => {
439
+ showToast(ToastType.Info, t('SPECIFIC_ORDER_ORDERED', 'Order _NUMBER_ has been ordered').replace('_NUMBER_', order.id))
440
+ const newOrder = [order, ...orderList.orders]
441
+ setOrderList({
442
+ ...orderList,
443
+ orders: newOrder,
444
+ loading: false
445
+ })
446
+ }
447
+
448
+ const ordersRoom = !props.isAsCustomer && session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
449
+ socket.join(ordersRoom)
450
+ if (!socket?.socket?._callbacks?.$orders_register || socket?.socket?._callbacks?.$orders_register?.find(func => func?.name !== 'handleAddNewOrder')) {
451
+ socket.on('orders_register', handleAddNewOrder)
452
+ }
453
+ if (!socket?.socket?._callbacks?.$update_order || socket?.socket?._callbacks?.$update_order?.find(func => func?.name !== 'handleUpdateOrder')) {
454
+ socket.on('update_order', handleUpdateOrder)
455
+ }
456
+ return () => {
457
+ socket.off('update_order', handleUpdateOrder)
458
+ socket.off('orders_register', handleAddNewOrder)
459
+ }
460
+ }, [orderList.loading, socket?.socket, session, isCustomerMode])
461
+
462
+ useEffect(() => {
463
+ if (!session.user || isCustomerMode) return
464
+ socket.on('disconnect', (reason) => {
465
+ const ordersRoom = !props.isAsCustomer && session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
466
+ socket.join(ordersRoom)
467
+ })
468
+ const ordersRoom = !props.isAsCustomer && session?.user?.level === 0 ? 'orders' : `orders_${session?.user?.id}`
469
+ socket.join(ordersRoom)
470
+ return () => {
471
+ socket.leave(ordersRoom)
472
+ }
473
+ }, [socket, session, userCustomerId, isCustomerMode])
474
+
475
+ const loadMoreOrders = async (searchByOtherStatus) => {
476
+ setOrderList({ ...orderList, loading: true })
477
+ try {
478
+ const response = await getOrders(pagination.currentPage + 1, searchByOtherStatus)
479
+ setOrderList({
480
+ loading: false,
481
+ orders: response.content.error ? orderList.orders : orderList.orders.concat(response.content.result),
482
+ error: response.content.error ? response.content.result : null
483
+ })
484
+ if (!response.content.error) {
485
+ setPagination({
486
+ currentPage: response.content.pagination.current_page,
487
+ pageSize: response.content.pagination.page_size,
488
+ totalPages: response.content.pagination.total_pages,
489
+ total: response.content.pagination.total,
490
+ from: response.content.pagination.from,
491
+ to: response.content.pagination.to
492
+ })
493
+ }
494
+ } catch (err) {
495
+ if (err.constructor.name !== 'Cancel') {
496
+ setOrderList({ ...orderList, loading: false, error: [err.message] })
497
+ }
498
+ }
499
+ }
500
+
501
+ const goToPage = async page => {
502
+ setOrderList({ ...orderList, loading: true })
503
+ try {
504
+ const response = await getOrders(page)
505
+ setOrderList({
506
+ loading: false,
507
+ orders: response.content.error ? [] : response.content.result,
508
+ error: response.content.error ? response.content.result : null
509
+ })
510
+ if (!response.content.error) {
511
+ setPagination({
512
+ currentPage: response.content.pagination.current_page,
513
+ pageSize: response.content.pagination.page_size,
514
+ totalPages: response.content.pagination.total_pages,
515
+ total: response.content.pagination.total,
516
+ from: response.content.pagination.from,
517
+ to: response.content.pagination.to
518
+ })
519
+ }
520
+ } catch (err) {
521
+ if (err.constructor.name !== 'Cancel') {
522
+ setOrderList({ ...orderList, loading: false, error: [err.message] })
523
+ }
524
+ }
525
+ }
526
+
527
+ const sortOrders = (orders, sortBy = 'desc') => {
528
+ const ordersSorted = orders.sort((a, b) => {
529
+ if (sortBy === 'desc') {
530
+ return b.id - a.id
531
+ }
532
+ return a.id - b.id
533
+ })
534
+
535
+ return ordersSorted
536
+ }
537
+
538
+ const handleUpdateProducts = (productId, changes) => {
539
+ const updatedProducts = products?.map(product => {
540
+ if (product?.product_id === productId) {
541
+ return {
542
+ ...product,
543
+ ...changes
544
+ }
545
+ }
546
+ return product
547
+ })
548
+ setProducts(updatedProducts)
549
+ }
550
+
551
+ const handleUpdateBusinesses = (businessId, changes) => {
552
+ const updatedBusiness = businesses?.result?.map(business => {
553
+ if (business?.id === businessId) {
554
+ return {
555
+ ...business,
556
+ ...changes
557
+ }
558
+ }
559
+ return business
560
+ })
561
+ setBusinesses({
562
+ ...businesses,
563
+ result: updatedBusiness
564
+ })
565
+ }
566
+
567
+ const getPage = async (page, pageSize) => {
568
+ setOrderList({ ...orderList, loading: true })
569
+ try {
570
+ const response = await getOrders(page, pageSize)
571
+ setOrderList({
572
+ loading: false,
573
+ orders: response.content.error ? orderList.orders : response.content.result,
574
+ error: response.content.error ? response.content.result : null
575
+ })
576
+ if (!response.content.error) {
577
+ setPagination({
578
+ currentPage: response.content.pagination.current_page,
579
+ pageSize: response.content.pagination.page_size,
580
+ totalPages: response.content.pagination.total_pages,
581
+ total: response.content.pagination.total,
582
+ from: response.content.pagination.from,
583
+ to: response.content.pagination.to
584
+ })
585
+ }
586
+ } catch (err) {
587
+ if (err.constructor.name !== 'Cancel') {
588
+ setOrderList({ ...orderList, loading: false, error: [err.message] })
589
+ }
590
+ }
591
+ }
592
+
593
+ useEffect(() => {
594
+ if (profileMessage) return
595
+ if (!orderList.loading && orderBy !== 'last_direct_message_at') {
596
+ const ordersSorted = orderList.orders.sort((a, b) => {
597
+ if (activeOrders) {
598
+ return dayjs(b.created_at).unix() - dayjs(a.created_at).unix()
599
+ }
600
+ return dayjs(a.created_at).unix() - dayjs(b.created_at).unix()
601
+ })
602
+ setOrderList({
603
+ ...orderList,
604
+ orders: ordersSorted
605
+ })
606
+ }
607
+ }, [orderList.loading, orderBy])
608
+
609
+ /**
610
+ * This effect is used to reload orders with dynamic params, using `isDynamicSort` as validation
611
+ */
612
+ useEffect(() => {
613
+ if (isDynamicSort) {
614
+ loadOrders(true, [])
615
+ }
616
+ }, [sortBy])
617
+
618
+ useEffect(() => {
619
+ if (businessesSearchList && !businessesSearchList?.loading) {
620
+ loadOrders(false, false, false, true)
621
+ }
622
+ }, [businessesSearchList, businessId])
623
+
624
+ useEffect(() => {
625
+ setIsEmptyBusinesses && setIsEmptyBusinesses(businessOrderIds?.length === 0)
626
+ }, [businessOrderIds])
627
+
628
+ useEffect(() => {
629
+ const handleOrderMessageRead = (orderId) => {
630
+ const updatedOrders = orderList.orders.map(order => {
631
+ if (order.id === orderId) {
632
+ return { ...order, unread_count: 0 }
633
+ }
634
+ return order
635
+ })
636
+ setOrderList({
637
+ ...orderList,
638
+ orders: updatedOrders
639
+ })
640
+ }
641
+ events.on('order_message_read', handleOrderMessageRead)
642
+ return () => {
643
+ events.off('order_message_read', handleOrderMessageRead)
644
+ }
645
+ }, [orderList.orders])
646
+
647
+ return (
648
+ <>
649
+ {UIComponent && (
650
+ <UIComponent
651
+ {...props}
652
+ sortOrders={sortOrders}
653
+ setSortBy={setSortBy}
654
+ orderList={orderList}
655
+ pagination={pagination}
656
+ loadMoreOrders={loadMoreOrders}
657
+ goToPage={goToPage}
658
+ loadOrders={loadOrders}
659
+ loadMessages={loadMessages}
660
+ messages={messages}
661
+ setMessages={setMessages}
662
+ setUpdateOtherStatus={setUpdateOtherStatus}
663
+ handleReorder={handleReorder}
664
+ reorderState={reorderState}
665
+ businessOrderIds={businessOrderIds}
666
+ products={products}
667
+ handleUpdateOrderList={handleUpdateOrderList}
668
+ handleUpdateProducts={handleUpdateProducts}
669
+ handleUpdateBusinesses={handleUpdateBusinesses}
670
+ businesses={businesses}
671
+ professionals={professionals}
672
+ handleUpdateProfessionals={handleUpdateProfessionals}
673
+ getPage={getPage}
674
+ />
675
+ )}
676
+ </>
677
+ )
678
+ }
679
+
680
+ OrderList.propTypes = {
681
+ /**
682
+ * UI Component, this must be containt all graphic elements and use parent props
683
+ */
684
+ UIComponent: PropTypes.elementType,
685
+ /**
686
+ * Function to get order that was clicked
687
+ * @param {Object} order Order that was clicked
688
+ */
689
+ onOrderClick: PropTypes.func,
690
+ /**
691
+ * Enable/Disable default session manager
692
+ * Save user and token with default session manager
693
+ */
694
+ useDefualtSessionManager: PropTypes.bool,
695
+ /**
696
+ * Access token to update user
697
+ * Is required when `useDefualtSessionManager` is false
698
+ */
699
+ accessToken: (props, propName) => {
700
+ if (props[propName] !== undefined && typeof props[propName] !== 'string') {
701
+ return new Error(
702
+ `Invalid prop \`${propName}\` of type \`${typeof props[
703
+ propName
704
+ ]}\` supplied to \`UserProfile\`, expected \`object\`.`
705
+ )
706
+ }
707
+ if (props[propName] === undefined && !props.useDefualtSessionManager) {
708
+ return new Error(
709
+ `Invalid prop \`${propName}\` is required when \`useDefualtSessionManager\` is false.`
710
+ )
711
+ }
712
+ },
713
+ /**
714
+ * Array of orders
715
+ * This is used of first option to show list
716
+ */
717
+ orders: PropTypes.arrayOf(object),
718
+ /**
719
+ * Array of id of orders
720
+ * Get a list of orders by ids form Ordering API
721
+ */
722
+ orderIds: PropTypes.arrayOf(number),
723
+ /**
724
+ * Array of id of orders
725
+ * Get a list of orders by status form Ordering API
726
+ * This can be use together `orderIds` option but not has effect with `orders` option
727
+ */
728
+ orderStatus: PropTypes.arrayOf(number),
729
+ /**
730
+ * Order orders by some attribute. Default by `id`.
731
+ */
732
+ orderBy: PropTypes.string,
733
+ /**
734
+ * Order direction ascendent (asc) or descendent (desc). Default is `desc`.
735
+ */
736
+ orderDirection: PropTypes.oneOf(['asc', 'desc']),
737
+ /**
738
+ * Pagination settings
739
+ * You can set the pageSize, initialPage and controlType can be by pages or infinity
740
+ */
741
+ paginationSettings: PropTypes.exact({
742
+ /**
743
+ * initialPage only work with control type `pages`
744
+ */
745
+ initialPage: PropTypes.number,
746
+ pageSize: PropTypes.number,
747
+ controlType: PropTypes.oneOf(['infinity', 'pages'])
748
+ }),
749
+ /**
750
+ * Components types before Facebook login button
751
+ * Array of type components, the parent props will pass to these components
752
+ */
753
+ beforeComponents: PropTypes.arrayOf(PropTypes.elementType),
754
+ /**
755
+ * Components types after Facebook login button
756
+ * Array of type components, the parent props will pass to these components
757
+ */
758
+ afterComponents: PropTypes.arrayOf(PropTypes.elementType),
759
+ /**
760
+ * Elements before Facebook login button
761
+ * Array of HTML/Components elements, these components will not get the parent props
762
+ */
763
+ beforeElements: PropTypes.arrayOf(PropTypes.element),
764
+ /**
765
+ * Elements after Facebook login button
766
+ * Array of HTML/Components elements, these components will not get the parent props
767
+ */
768
+ afterElements: PropTypes.arrayOf(PropTypes.element)
769
+ }
770
+
771
+ OrderList.defaultProps = {
772
+ orderBy: 'id',
773
+ orderDirection: 'desc',
774
+ paginationSettings: { initialPage: 1, pageSize: 10, controlType: 'infinity' },
775
+ beforeComponents: [],
776
+ afterComponents: [],
777
+ beforeElements: [],
778
+ afterElements: [],
779
+ isAsCustomer: false,
780
+ propsToFetchBusiness: ['id', 'name', 'header', 'logo', 'location', 'schedule', 'open', 'ribbon', 'delivery_price', 'distance', 'delivery_time', 'pickup_time', 'reviews', 'featured', 'offers', 'food', 'laundry', 'alcohol', 'groceries', 'slug', 'city', 'city_id']
781
+ }