ordering-components-external 13.0.32 → 13.0.34

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (533) hide show
  1. package/.babelrc +22 -22
  2. package/.vscode/settings.json +3 -3
  3. package/_bundles/{7.ordering-component.47bc345f9be0615530cf.js → 7.ordering-component.3760baa5b9906f197b42.js} +1 -1
  4. package/_bundles/{ordering-component.47bc345f9be0615530cf.js → ordering-component.3760baa5b9906f197b42.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 +45 -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 +69 -69
  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 -310
  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.47bc345f9be0615530cf.js → 0.ordering-component.3760baa5b9906f197b42.js} +0 -0
  526. /package/_bundles/{1.ordering-component.47bc345f9be0615530cf.js → 1.ordering-component.3760baa5b9906f197b42.js} +0 -0
  527. /package/_bundles/{2.ordering-component.47bc345f9be0615530cf.js → 2.ordering-component.3760baa5b9906f197b42.js} +0 -0
  528. /package/_bundles/{4.ordering-component.47bc345f9be0615530cf.js → 4.ordering-component.3760baa5b9906f197b42.js} +0 -0
  529. /package/_bundles/{5.ordering-component.47bc345f9be0615530cf.js → 5.ordering-component.3760baa5b9906f197b42.js} +0 -0
  530. /package/_bundles/{6.ordering-component.47bc345f9be0615530cf.js → 6.ordering-component.3760baa5b9906f197b42.js} +0 -0
  531. /package/_bundles/{7.ordering-component.47bc345f9be0615530cf.js.LICENSE.txt → 7.ordering-component.3760baa5b9906f197b42.js.LICENSE.txt} +0 -0
  532. /package/_bundles/{8.ordering-component.47bc345f9be0615530cf.js → 8.ordering-component.3760baa5b9906f197b42.js} +0 -0
  533. /package/_bundles/{ordering-component.47bc345f9be0615530cf.js.LICENSE.txt → ordering-component.3760baa5b9906f197b42.js.LICENSE.txt} +0 -0
@@ -1,684 +1,684 @@
1
- import React, { useEffect, useState } from 'react'
2
- import PropTypes from 'prop-types'
3
- import { useSession } from '../../contexts/SessionContext'
4
- import { useApi } from '../../contexts/ApiContext'
5
- import { useWebsocket } from '../../contexts/WebsocketContext'
6
- import { useToast, ToastType } from '../../contexts/ToastContext'
7
- import { useLanguage } from '../../contexts/LanguageContext'
8
- import { useEvent } from '../../contexts/EventContext'
9
- import { useOrder } from '../../contexts/OrderContext'
10
-
11
- export const OrderDetails = (props) => {
12
- const {
13
- orderId,
14
- orderAssingId,
15
- hashKey,
16
- UIComponent,
17
- userCustomerId,
18
- isFetchDrivers,
19
- driverAndBusinessId,
20
- sendCustomMessage,
21
- isDisabledOrdersRoom,
22
- isDriverNotification
23
- } = props
24
-
25
- const [{ user, token, loading }] = useSession()
26
- const accessToken = props.accessToken || token
27
- const [ordering] = useApi()
28
- const [, { showToast }] = useToast()
29
- const [, t] = useLanguage()
30
- const [events] = useEvent()
31
- const [{ carts }, { reorder, clearCart }] = useOrder()
32
-
33
- const [orderState, setOrderState] = useState({ order: props.order ?? null, businessData: {}, loading: !props.order, error: null })
34
- const [drivers, setDrivers] = useState({ drivers: [], loadingDriver: false, error: null })
35
- const [messageErrors, setMessageErrors] = useState({ status: null, loading: false, error: null })
36
- const [messages, setMessages] = useState({ loading: true, error: null, messages: [] })
37
- const socket = useWebsocket()
38
- const [driverLocation, setDriverLocation] = useState(props.order?.driver?.location || orderState.order?.driver?.location || null)
39
- const [messagesReadList, setMessagesReadList] = useState([])
40
- const [driverUpdateLocation, setDriverUpdateLocation] = useState({ loading: false, error: null, newLocation: null })
41
- const [forceUpdate, setForceUpdate] = useState(null)
42
- const [reorderState, setReorderState] = useState({ loading: false, result: [], error: null })
43
- const [cartState, setCartState] = useState({ loading: false, error: null })
44
- /**
45
- * Method to accept or reject a logistic order
46
- */
47
-
48
- const handleClickLogisticOrder = async (status, orderId, orders) => {
49
- try {
50
- const response = await fetch(`${ordering.root}/drivers/${user?.id}/assign_requests/${orderId}`, {
51
- method: 'PUT',
52
- headers: { 'Content-Type': 'application/json', Authorization: `Bearer ${accessToken}` },
53
- body: JSON.stringify({
54
- status,
55
- user_id: user?.id
56
- })
57
- })
58
- const { result, error } = await response.json()
59
- if (!error) {
60
- if (status === 1) {
61
- showToast(
62
- ToastType.Success,
63
- t('SPECIFIC_ORDER_ACCEPTED', 'Your accepted the order number _NUMBER_').replace('_NUMBER_', orders?.id)
64
- )
65
- } else {
66
- showToast(
67
- ToastType.Info,
68
- t('SPECIFIC_ORDER_REJECTED', 'Your rejected the order number _NUMBER_').replace('_NUMBER_', orders?.id)
69
- )
70
- }
71
- return
72
- }
73
- showToast(ToastType.Error, result)
74
- } catch (err) {
75
- showToast(ToastType.Error, err.message)
76
- }
77
- }
78
-
79
- const propsToFetch = ['header', 'slug']
80
-
81
- const deliveryMessages = {
82
- delivery: {
83
- text: 'outside delivery area, insert reasons to force update',
84
- value: 11
85
- },
86
- pickup: {
87
- text: 'outside pickup area, insert reasons to force update',
88
- value: 9
89
- }
90
- }
91
-
92
- const requestsState = {}
93
-
94
- /**
95
- * Method to format a price number
96
- * @param {Number} price
97
- */
98
- const formatPrice = price => price && `$ ${price.toFixed(2)}`
99
-
100
- /**
101
- * Method to Load message for first time
102
- */
103
- const loadMessages = async () => {
104
- try {
105
- setMessages({ ...messages, loading: true })
106
- const url = (userCustomerId || driverAndBusinessId)
107
- ? `${ordering.root}/orders/${orderState.order?.id}/messages?mode=dashboard`
108
- : `${ordering.root}/orders/${orderState.order?.id}/messages`
109
- const response = await fetch(url, {
110
- method: 'GET',
111
- headers: {
112
- 'Content-Type': 'application/json',
113
- Authorization: `Bearer ${accessToken}`,
114
- 'X-App-X': ordering.appId,
115
- 'X-Socket-Id-X': socket?.getId()
116
- }
117
- })
118
- const { error, result } = await response.json()
119
- if (!error) {
120
- setMessages({
121
- messages: result,
122
- loading: false,
123
- error: null
124
- })
125
- } else {
126
- setMessages({
127
- ...messages,
128
- loading: false,
129
- error: result
130
- })
131
- }
132
- } catch (error) {
133
- setMessages({ ...messages, loading: false, error: [error.Messages] })
134
- }
135
- }
136
-
137
- /**
138
- * Method to send a message
139
- * @param {string} spot
140
- */
141
- const sendMessage = async (spot) => {
142
- if (sendCustomMessage) {
143
- return sendCustomMessage(spot)
144
- }
145
- try {
146
- setMessageErrors({
147
- ...messageErrors,
148
- loading: true
149
- })
150
- const { status } = await fetch(`${ordering.root}/orders/${orderState.order?.id}/messages`, {
151
- method: 'post',
152
- headers: {
153
- Authorization: `Bearer ${token}`,
154
- 'Content-Type': 'application/json',
155
- 'X-App-X': ordering.appId,
156
- 'X-Socket-Id-X': socket?.getId()
157
- },
158
- body: JSON.stringify({
159
- can_see: '0,2,3',
160
- comment: `I am on the parking number: ${spot}`,
161
- order_id: orderState.order?.id,
162
- type: 2
163
- })
164
- })
165
- setMessageErrors({
166
- ...messageErrors,
167
- loading: false,
168
- status
169
- })
170
- } catch (e) {
171
- setMessageErrors({
172
- ...messageErrors,
173
- loading: false,
174
- error: [e.message]
175
- })
176
- }
177
- }
178
-
179
- /**
180
- * Method to update differents orders status
181
- */
182
- const handleChangeOrderStatus = async (status, isAcceptOrReject = {}, options) => {
183
- const dataToSave = options?.dataToSave
184
- if (dataToSave) {
185
- const order = Object.assign(orderState.order, { ...dataToSave, oldStatus: orderState.order?.status })
186
- setOrderState({ ...orderState, order })
187
- return order
188
- }
189
-
190
- try {
191
- const bodyToSend = Object.keys(isAcceptOrReject || {}).length > 0 ? isAcceptOrReject : { status }
192
- setOrderState({ ...orderState, loading: true })
193
- const { content: { result, error } } = await ordering.setAccessToken(token).orders(orderState.order?.id ?? orderId).save(bodyToSend)
194
-
195
- if (!error) {
196
- setOrderState({
197
- ...orderState,
198
- order: Object.assign(orderState.order, result),
199
- loading: false
200
- })
201
- return Object.assign(orderState.order, result)
202
- }
203
- if (error) {
204
- const selected = result.includes(deliveryMessages.delivery.text) ? deliveryMessages.delivery
205
- : result.includes(deliveryMessages.pickup.text)
206
- ? deliveryMessages.pickup
207
- : null
208
- if (selected) {
209
- setForceUpdate(null)
210
- setOrderState({ ...orderState, loading: false })
211
- setForceUpdate(selected.value)
212
- } else {
213
- const message = Array.isArray(result) ? result[0] : typeof result === 'string' ? result : 'INTERNAL_ERROR'
214
- const defaultMessage = message !== 'INTERNAL_ERROR' ? message : t('INTERNAL_ERROR', 'Internal Error')
215
-
216
- setOrderState({ ...orderState, error: [defaultMessage], loading: false })
217
- }
218
- return null
219
- }
220
- } catch (err) {
221
- setOrderState({ ...orderState, loading: false, error: [err?.message || t('NETWORK_ERROR', 'Network Error')] })
222
- return null
223
- }
224
- }
225
-
226
- const updateDriverPosition = async (newLocation = {}) => {
227
- try {
228
- setDriverLocation({ ...driverUpdateLocation, loading: true })
229
- const { content: { error, result } } = await ordering.setAccessToken(token).users(user?.id).driverLocations().save(newLocation)
230
- if (error) {
231
- setDriverUpdateLocation({ ...driverUpdateLocation, loading: false, error: [result[0] || result || t('ERROR_UPDATING_POSITION', 'Error updating position')] })
232
- } else {
233
- setDriverUpdateLocation({ ...driverUpdateLocation, loading: false, newLocation: { ...newLocation, ...result } })
234
- }
235
- } catch (error) {
236
- setDriverUpdateLocation({ ...driverUpdateLocation, loading: false, error: [error?.message || t('NETWORK_ERROR', 'Network Error')] })
237
- }
238
- }
239
-
240
- /**
241
- * Method to assign a driver for order
242
- */
243
- const handleAssignDriver = async (driverId) => {
244
- try {
245
- const bodyToSend = { driver_id: driverId }
246
- setOrderState({ ...orderState, loading: true })
247
- const { content: { error, result } } = await ordering
248
- .setAccessToken(token)
249
- .orders(orderState?.order?.id ?? orderId)
250
- .save(bodyToSend)
251
-
252
- setOrderState({
253
- ...orderState,
254
- loading: false,
255
- order: Object.assign(orderState.order, result),
256
- error: error ? result : null
257
- })
258
- } catch (e) {
259
- setOrderState({
260
- ...orderState,
261
- loading: false,
262
- error: e?.message ? drivers.error?.push(e?.message) : ['ERROR']
263
- })
264
- }
265
- }
266
-
267
- /**
268
- * handler send message with spot info
269
- * @param {number} param0
270
- */
271
- const handlerSubmitSpotNumber = ({ spot }) => {
272
- sendMessage(spot)
273
- }
274
-
275
- /**
276
- * Method to get order from API
277
- */
278
- const getOrder = async () => {
279
- const source = {}
280
- requestsState.order = source
281
- requestsState.business = source
282
- const options = {}
283
- if (hashKey) {
284
- options.headers = {
285
- 'X-uuid-access-X': hashKey
286
- }
287
- }
288
- if (userCustomerId || driverAndBusinessId) {
289
- options.query = {
290
- mode: 'dashboard'
291
- }
292
- }
293
-
294
- try {
295
- let result, error
296
- if (orderAssingId) {
297
- const response = await fetch(`${ordering.root}/drivers/${user.id}/assign_requests/${orderAssingId}`, {
298
- headers: {
299
- Authorization: `Bearer ${token}`,
300
- 'Content-Type': 'application/json',
301
- 'X-App-X': ordering.appId,
302
- 'X-Socket-Id-X': socket?.getId()
303
- }
304
- })
305
- const res = await response.json()
306
- result = res.result
307
- error = res.error
308
- } else {
309
- const { content } = await ordering.setAccessToken(token).orders(orderId).get({ ...options, cancelToken: source })
310
- result = content.result
311
- error = content.error
312
- }
313
- const order = error ? null : result?.order || result
314
- let err = error ? Array.isArray(result) ? result[0] : result : null
315
- let businessData = null
316
- if (err) {
317
- setOrderState({
318
- ...orderState,
319
- loading: false,
320
- error: [err ?? 'ERROR']
321
- })
322
- return
323
- }
324
- try {
325
- const { content } = await ordering.setAccessToken(token).businesses(order?.business_id).select(propsToFetch).get({ cancelToken: source })
326
- businessData = content.result
327
- content.error && (err = content.result[0])
328
- } catch (e) {
329
- err = [e.message ?? 'ERROR']
330
- }
331
-
332
- if (isFetchDrivers) {
333
- getDrivers(order?.id ?? orderId)
334
- }
335
-
336
- setOrderState({
337
- ...orderState,
338
- loading: false,
339
- order,
340
- businessData,
341
- error: err
342
- })
343
- } catch (e) {
344
- setOrderState({
345
- ...orderState,
346
- loading: false,
347
- error: [e.message ?? 'ERROR']
348
- })
349
- }
350
- }
351
-
352
- const readMessages = async () => {
353
- const messageId = messages?.messages[messages?.messages?.length - 1]?.id
354
- if (!messageId) return
355
- try {
356
- const response = await fetch(`${ordering.root}/orders/${orderState.order?.id}/messages/${messageId}/read?order_id=${orderId}&order_message_id=${messageId}`, {
357
- method: 'GET',
358
- headers: {
359
- Authorization: `Bearer ${token}`,
360
- 'Content-Type': 'application/json',
361
- 'X-App-X': ordering.appId,
362
- 'X-Socket-Id-X': socket?.getId()
363
- }
364
- })
365
- const { result } = await response.json()
366
-
367
- setMessagesReadList(result)
368
- events.emit('order_message_read', orderState.order?.id)
369
- } catch (e) {
370
- console.log(e.message)
371
- }
372
- }
373
-
374
- const getDrivers = async (orderId) => {
375
- try {
376
- setDrivers({ ...drivers, loadingDriver: true })
377
- const { content: { error, result } } = await ordering
378
- .setAccessToken(token)
379
- .controls(orderId)
380
- .get()
381
-
382
- setDrivers({
383
- ...drivers,
384
- loadingDriver: false,
385
- drivers: result.drivers,
386
- error: error ? result : null
387
- })
388
- } catch (e) {
389
- setDrivers({
390
- ...drivers,
391
- loadingDriver: false,
392
- error: e?.message ? drivers.error?.push(e?.message) : ['ERROR']
393
- })
394
- }
395
- }
396
-
397
- const handleReorder = async (orderId) => {
398
- if (!orderId) return
399
- try {
400
- setReorderState({
401
- ...reorderState,
402
- loading: true
403
- })
404
- const { error, result } = await reorder(orderId)
405
- if (!error) {
406
- setReorderState({
407
- ...reorderState,
408
- loading: false,
409
- result: result
410
- })
411
- } else {
412
- setReorderState({
413
- ...reorderState,
414
- loading: false,
415
- error: true,
416
- result: result
417
- })
418
- }
419
- } catch (err) {
420
- setReorderState({
421
- ...reorderState,
422
- loading: false,
423
- error: true,
424
- result: [err?.message]
425
- })
426
- }
427
- }
428
-
429
- /**
430
- * Method to remove products from cart
431
- */
432
- const handleRemoveCart = async () => {
433
- const uuid = carts[`businessId:${orderState?.order.business_id}`]?.uuid
434
- if (!uuid) return
435
- try {
436
- setCartState({
437
- ...cartState,
438
- loading: true
439
- })
440
- const content = await clearCart(uuid)
441
- if (!content?.error) {
442
- handleReorder(orderState?.order?.id)
443
- setCartState({
444
- loading: false,
445
- error: null
446
- })
447
- } else {
448
- setCartState({
449
- loading: false,
450
- error: content?.result
451
- })
452
- }
453
- } catch (error) {
454
- setCartState({
455
- loading: false,
456
- error: [error.message]
457
- })
458
- }
459
- }
460
-
461
- /**
462
- * Method to get room socket
463
- * @param {String} roomType drivers, orders
464
- * @returns socket room
465
- */
466
- const getRoom = (roomType) => !token
467
- ? {
468
- room: roomType,
469
- project: ordering.project,
470
- role: 'public',
471
- user_id: hashKey
472
- }
473
- : roomType === 'orders'
474
- ? user?.level === 0 ? 'orders' : `orders_${userCustomerId || user?.id}`
475
- : `drivers_${orderState.order?.driver_id}`
476
-
477
- useEffect(() => {
478
- !orderState.loading && loadMessages()
479
- }, [orderState?.order?.id, orderState?.order?.status, orderState.loading])
480
-
481
- useEffect(() => {
482
- if (props.order && !isDriverNotification) {
483
- setOrderState({
484
- ...orderState,
485
- loading: false,
486
- order: props.order
487
- })
488
- if (isFetchDrivers) {
489
- getDrivers(props.order?.id ?? orderId)
490
- }
491
- } else if (!orderState.order && !isDriverNotification) {
492
- getOrder()
493
- }
494
-
495
- return () => {
496
- if (requestsState.orders) {
497
- requestsState.orders.cancel()
498
- }
499
- if (requestsState.business) {
500
- requestsState.business.cancel()
501
- }
502
- }
503
- }, [props.order, orderState.order?.id])
504
-
505
- useEffect(() => {
506
- if (orderId && isDriverNotification) {
507
- getOrder()
508
- }
509
- }, [orderId, isDriverNotification])
510
-
511
- useEffect(() => {
512
- if (orderState.loading || loading || !socket?.socket) return
513
- const handleUpdateOrderDetails = (order) => {
514
- if (order?.id !== orderState.order?.id) return
515
- showToast(ToastType.Info, t('UPDATING_ORDER', 'Updating order...'), 1000)
516
- delete order.total
517
- delete order.subtotal
518
- setOrderState({
519
- ...orderState,
520
- order: Object.assign(orderState.order, order)
521
- })
522
- events.emit('order_updated', Object.assign(orderState.order, order))
523
- }
524
- const handleTrackingDriver = (props) => {
525
- const location = props.location
526
- const driverId = props.driver_id
527
- if (driverId !== orderState?.order?.driver_id) return
528
- const newLocation = location ?? { lat: -37.9722342, lng: 144.7729561 }
529
- setDriverLocation(newLocation)
530
- setOrderState({
531
- ...orderState,
532
- order: {
533
- ...orderState.order,
534
- driver: {
535
- ...orderState.order?.driver,
536
- location: newLocation
537
- }
538
- }
539
- })
540
- }
541
-
542
- if (!isDisabledOrdersRoom) socket.join(getRoom('orders'))
543
- if (orderState.order?.driver_id) {
544
- socket.join(getRoom('drivers'))
545
- }
546
- socket.socket.on('connect', () => {
547
- if (!isDisabledOrdersRoom) socket.join(getRoom('orders'))
548
- if (orderState.order?.driver_id) {
549
- socket.join(getRoom('drivers'))
550
- }
551
- })
552
- socket.on('tracking_driver', handleTrackingDriver)
553
- if (!socket?.socket?._callbacks?.$update_order || socket?.socket?._callbacks?.$update_order?.find(func => func?.name !== 'handleUpdateOrderDetails')) {
554
- socket.on('update_order', handleUpdateOrderDetails)
555
- }
556
- return () => {
557
- if (!isDisabledOrdersRoom) socket.leave(getRoom('orders'))
558
- socket.off('update_order', handleUpdateOrderDetails)
559
- socket.off('tracking_driver', handleTrackingDriver)
560
- }
561
- }, [orderState?.loading, socket?.socket, loading, userCustomerId, orderState.order?.driver_id, orderState.order?.id, hashKey])
562
-
563
- useEffect(() => {
564
- if (messages.loading) return
565
- const handleNewMessage = (message) => {
566
- const actualChat = messages?.messages?.find(_message => _message?.order_id === message?.order?.id)
567
- const found = messages.messages.find(_message => _message.id === message.id)
568
- if (!found && actualChat) {
569
- setMessages({
570
- ...messages,
571
- messages: [...messages.messages, message]
572
- })
573
- }
574
- }
575
- socket.on('message', handleNewMessage)
576
- return () => {
577
- socket.off('message', handleNewMessage)
578
- }
579
- }, [messages, socket, orderState.order?.status, userCustomerId])
580
-
581
- useEffect(() => {
582
- if (!socket?.socket) return
583
- const messagesOrdersRoom = user?.level === 0 ? 'messages_orders' : `messages_orders_${userCustomerId || user?.id}`
584
- socket.join(messagesOrdersRoom)
585
- socket.socket.on('connect', () => {
586
- socket.join(messagesOrdersRoom)
587
- })
588
- return () => {
589
- // neccesary refactor
590
- if (!isDisabledOrdersRoom) socket.leave(messagesOrdersRoom)
591
- }
592
- }, [socket?.socket, userCustomerId])
593
-
594
- useEffect(() => {
595
- const handleCustomerReviewed = (review) => {
596
- setOrderState({
597
- ...orderState,
598
- order: { ...orderState.order, user_review: review }
599
- })
600
- }
601
- events.on('customer_reviewed', handleCustomerReviewed)
602
- return () => {
603
- events.off('customer_reviewed', handleCustomerReviewed)
604
- }
605
- }, [orderState])
606
-
607
- return (
608
- <>
609
- {UIComponent && (
610
- <UIComponent
611
- {...props}
612
- order={orderState}
613
- updateDriverPosition={updateDriverPosition}
614
- driverLocation={driverLocation}
615
- messageErrors={messageErrors}
616
- formatPrice={formatPrice}
617
- handleAssignDriver={handleAssignDriver}
618
- handlerSubmit={handlerSubmitSpotNumber}
619
- handleChangeOrderStatus={handleChangeOrderStatus}
620
- messages={messages}
621
- drivers={drivers}
622
- setMessages={setMessages}
623
- readMessages={readMessages}
624
- messagesReadList={messagesReadList}
625
- driverUpdateLocation={driverUpdateLocation}
626
- setDriverUpdateLocation={setDriverUpdateLocation}
627
- forceUpdate={forceUpdate}
628
- getOrder={getOrder}
629
- reorderState={reorderState}
630
- handleReorder={handleReorder}
631
- handleRemoveCart={handleRemoveCart}
632
- cartState={cartState}
633
- handleClickLogisticOrder={handleClickLogisticOrder}
634
- loadMessages={loadMessages}
635
- />
636
- )}
637
- </>
638
- )
639
- }
640
-
641
- OrderDetails.propTypes = {
642
- /**
643
- * UI Component, this must be containt all graphic elements and use parent props
644
- */
645
- UIComponent: PropTypes.elementType,
646
- /**
647
- * This must be contains orderId to fetch
648
- */
649
- orderId: PropTypes.oneOfType([
650
- PropTypes.number,
651
- PropTypes.string
652
- ]),
653
- /**
654
- * Order, this must be contains an object with all order info
655
- */
656
- order: PropTypes.object,
657
- /**
658
- * Components types before order details
659
- * Array of type components, the parent props will pass to these components
660
- */
661
- beforeComponents: PropTypes.arrayOf(PropTypes.elementType),
662
- /**
663
- * Components types after order details
664
- * Array of type components, the parent props will pass to these components
665
- */
666
- afterComponents: PropTypes.arrayOf(PropTypes.elementType),
667
- /**
668
- * Elements before order details
669
- * Array of HTML/Components elements, these components will not get the parent props
670
- */
671
- beforeElements: PropTypes.arrayOf(PropTypes.element),
672
- /**
673
- * Elements after order details
674
- * Array of HTML/Components elements, these components will not get the parent props
675
- */
676
- afterElements: PropTypes.arrayOf(PropTypes.element)
677
- }
678
-
679
- OrderDetails.defaultProps = {
680
- beforeComponents: [],
681
- afterComponents: [],
682
- beforeElements: [],
683
- afterElements: []
684
- }
1
+ import React, { useEffect, useState } from 'react'
2
+ import PropTypes from 'prop-types'
3
+ import { useSession } from '../../contexts/SessionContext'
4
+ import { useApi } from '../../contexts/ApiContext'
5
+ import { useWebsocket } from '../../contexts/WebsocketContext'
6
+ import { useToast, ToastType } from '../../contexts/ToastContext'
7
+ import { useLanguage } from '../../contexts/LanguageContext'
8
+ import { useEvent } from '../../contexts/EventContext'
9
+ import { useOrder } from '../../contexts/OrderContext'
10
+
11
+ export const OrderDetails = (props) => {
12
+ const {
13
+ orderId,
14
+ orderAssingId,
15
+ hashKey,
16
+ UIComponent,
17
+ userCustomerId,
18
+ isFetchDrivers,
19
+ driverAndBusinessId,
20
+ sendCustomMessage,
21
+ isDisabledOrdersRoom,
22
+ isDriverNotification
23
+ } = props
24
+
25
+ const [{ user, token, loading }] = useSession()
26
+ const accessToken = props.accessToken || token
27
+ const [ordering] = useApi()
28
+ const [, { showToast }] = useToast()
29
+ const [, t] = useLanguage()
30
+ const [events] = useEvent()
31
+ const [{ carts }, { reorder, clearCart }] = useOrder()
32
+
33
+ const [orderState, setOrderState] = useState({ order: props.order ?? null, businessData: {}, loading: !props.order, error: null })
34
+ const [drivers, setDrivers] = useState({ drivers: [], loadingDriver: false, error: null })
35
+ const [messageErrors, setMessageErrors] = useState({ status: null, loading: false, error: null })
36
+ const [messages, setMessages] = useState({ loading: true, error: null, messages: [] })
37
+ const socket = useWebsocket()
38
+ const [driverLocation, setDriverLocation] = useState(props.order?.driver?.location || orderState.order?.driver?.location || null)
39
+ const [messagesReadList, setMessagesReadList] = useState([])
40
+ const [driverUpdateLocation, setDriverUpdateLocation] = useState({ loading: false, error: null, newLocation: null })
41
+ const [forceUpdate, setForceUpdate] = useState(null)
42
+ const [reorderState, setReorderState] = useState({ loading: false, result: [], error: null })
43
+ const [cartState, setCartState] = useState({ loading: false, error: null })
44
+ /**
45
+ * Method to accept or reject a logistic order
46
+ */
47
+
48
+ const handleClickLogisticOrder = async (status, orderId, orders) => {
49
+ try {
50
+ const response = await fetch(`${ordering.root}/drivers/${user?.id}/assign_requests/${orderId}`, {
51
+ method: 'PUT',
52
+ headers: { 'Content-Type': 'application/json', Authorization: `Bearer ${accessToken}` },
53
+ body: JSON.stringify({
54
+ status,
55
+ user_id: user?.id
56
+ })
57
+ })
58
+ const { result, error } = await response.json()
59
+ if (!error) {
60
+ if (status === 1) {
61
+ showToast(
62
+ ToastType.Success,
63
+ t('SPECIFIC_ORDER_ACCEPTED', 'Your accepted the order number _NUMBER_').replace('_NUMBER_', orders?.id)
64
+ )
65
+ } else {
66
+ showToast(
67
+ ToastType.Info,
68
+ t('SPECIFIC_ORDER_REJECTED', 'Your rejected the order number _NUMBER_').replace('_NUMBER_', orders?.id)
69
+ )
70
+ }
71
+ return
72
+ }
73
+ showToast(ToastType.Error, result)
74
+ } catch (err) {
75
+ showToast(ToastType.Error, err.message)
76
+ }
77
+ }
78
+
79
+ const propsToFetch = ['header', 'slug']
80
+
81
+ const deliveryMessages = {
82
+ delivery: {
83
+ text: 'outside delivery area, insert reasons to force update',
84
+ value: 11
85
+ },
86
+ pickup: {
87
+ text: 'outside pickup area, insert reasons to force update',
88
+ value: 9
89
+ }
90
+ }
91
+
92
+ const requestsState = {}
93
+
94
+ /**
95
+ * Method to format a price number
96
+ * @param {Number} price
97
+ */
98
+ const formatPrice = price => price && `$ ${price.toFixed(2)}`
99
+
100
+ /**
101
+ * Method to Load message for first time
102
+ */
103
+ const loadMessages = async () => {
104
+ try {
105
+ setMessages({ ...messages, loading: true })
106
+ const url = (userCustomerId || driverAndBusinessId)
107
+ ? `${ordering.root}/orders/${orderState.order?.id}/messages?mode=dashboard`
108
+ : `${ordering.root}/orders/${orderState.order?.id}/messages`
109
+ const response = await fetch(url, {
110
+ method: 'GET',
111
+ headers: {
112
+ 'Content-Type': 'application/json',
113
+ Authorization: `Bearer ${accessToken}`,
114
+ 'X-App-X': ordering.appId,
115
+ 'X-Socket-Id-X': socket?.getId()
116
+ }
117
+ })
118
+ const { error, result } = await response.json()
119
+ if (!error) {
120
+ setMessages({
121
+ messages: result,
122
+ loading: false,
123
+ error: null
124
+ })
125
+ } else {
126
+ setMessages({
127
+ ...messages,
128
+ loading: false,
129
+ error: result
130
+ })
131
+ }
132
+ } catch (error) {
133
+ setMessages({ ...messages, loading: false, error: [error.Messages] })
134
+ }
135
+ }
136
+
137
+ /**
138
+ * Method to send a message
139
+ * @param {string} spot
140
+ */
141
+ const sendMessage = async (spot) => {
142
+ if (sendCustomMessage) {
143
+ return sendCustomMessage(spot)
144
+ }
145
+ try {
146
+ setMessageErrors({
147
+ ...messageErrors,
148
+ loading: true
149
+ })
150
+ const { status } = await fetch(`${ordering.root}/orders/${orderState.order?.id}/messages`, {
151
+ method: 'post',
152
+ headers: {
153
+ Authorization: `Bearer ${token}`,
154
+ 'Content-Type': 'application/json',
155
+ 'X-App-X': ordering.appId,
156
+ 'X-Socket-Id-X': socket?.getId()
157
+ },
158
+ body: JSON.stringify({
159
+ can_see: '0,2,3',
160
+ comment: `I am on the parking number: ${spot}`,
161
+ order_id: orderState.order?.id,
162
+ type: 2
163
+ })
164
+ })
165
+ setMessageErrors({
166
+ ...messageErrors,
167
+ loading: false,
168
+ status
169
+ })
170
+ } catch (e) {
171
+ setMessageErrors({
172
+ ...messageErrors,
173
+ loading: false,
174
+ error: [e.message]
175
+ })
176
+ }
177
+ }
178
+
179
+ /**
180
+ * Method to update differents orders status
181
+ */
182
+ const handleChangeOrderStatus = async (status, isAcceptOrReject = {}, options) => {
183
+ const dataToSave = options?.dataToSave
184
+ if (dataToSave) {
185
+ const order = Object.assign(orderState.order, { ...dataToSave, oldStatus: orderState.order?.status })
186
+ setOrderState({ ...orderState, order })
187
+ return order
188
+ }
189
+
190
+ try {
191
+ const bodyToSend = Object.keys(isAcceptOrReject || {}).length > 0 ? isAcceptOrReject : { status }
192
+ setOrderState({ ...orderState, loading: true })
193
+ const { content: { result, error } } = await ordering.setAccessToken(token).orders(orderState.order?.id ?? orderId).save(bodyToSend)
194
+
195
+ if (!error) {
196
+ setOrderState({
197
+ ...orderState,
198
+ order: Object.assign(orderState.order, result),
199
+ loading: false
200
+ })
201
+ return Object.assign(orderState.order, result)
202
+ }
203
+ if (error) {
204
+ const selected = result.includes(deliveryMessages.delivery.text) ? deliveryMessages.delivery
205
+ : result.includes(deliveryMessages.pickup.text)
206
+ ? deliveryMessages.pickup
207
+ : null
208
+ if (selected) {
209
+ setForceUpdate(null)
210
+ setOrderState({ ...orderState, loading: false })
211
+ setForceUpdate(selected.value)
212
+ } else {
213
+ const message = Array.isArray(result) ? result[0] : typeof result === 'string' ? result : 'INTERNAL_ERROR'
214
+ const defaultMessage = message !== 'INTERNAL_ERROR' ? message : t('INTERNAL_ERROR', 'Internal Error')
215
+
216
+ setOrderState({ ...orderState, error: [defaultMessage], loading: false })
217
+ }
218
+ return null
219
+ }
220
+ } catch (err) {
221
+ setOrderState({ ...orderState, loading: false, error: [err?.message || t('NETWORK_ERROR', 'Network Error')] })
222
+ return null
223
+ }
224
+ }
225
+
226
+ const updateDriverPosition = async (newLocation = {}) => {
227
+ try {
228
+ setDriverLocation({ ...driverUpdateLocation, loading: true })
229
+ const { content: { error, result } } = await ordering.setAccessToken(token).users(user?.id).driverLocations().save(newLocation)
230
+ if (error) {
231
+ setDriverUpdateLocation({ ...driverUpdateLocation, loading: false, error: [result[0] || result || t('ERROR_UPDATING_POSITION', 'Error updating position')] })
232
+ } else {
233
+ setDriverUpdateLocation({ ...driverUpdateLocation, loading: false, newLocation: { ...newLocation, ...result } })
234
+ }
235
+ } catch (error) {
236
+ setDriverUpdateLocation({ ...driverUpdateLocation, loading: false, error: [error?.message || t('NETWORK_ERROR', 'Network Error')] })
237
+ }
238
+ }
239
+
240
+ /**
241
+ * Method to assign a driver for order
242
+ */
243
+ const handleAssignDriver = async (driverId) => {
244
+ try {
245
+ const bodyToSend = { driver_id: driverId }
246
+ setOrderState({ ...orderState, loading: true })
247
+ const { content: { error, result } } = await ordering
248
+ .setAccessToken(token)
249
+ .orders(orderState?.order?.id ?? orderId)
250
+ .save(bodyToSend)
251
+
252
+ setOrderState({
253
+ ...orderState,
254
+ loading: false,
255
+ order: Object.assign(orderState.order, result),
256
+ error: error ? result : null
257
+ })
258
+ } catch (e) {
259
+ setOrderState({
260
+ ...orderState,
261
+ loading: false,
262
+ error: e?.message ? drivers.error?.push(e?.message) : ['ERROR']
263
+ })
264
+ }
265
+ }
266
+
267
+ /**
268
+ * handler send message with spot info
269
+ * @param {number} param0
270
+ */
271
+ const handlerSubmitSpotNumber = ({ spot }) => {
272
+ sendMessage(spot)
273
+ }
274
+
275
+ /**
276
+ * Method to get order from API
277
+ */
278
+ const getOrder = async () => {
279
+ const source = {}
280
+ requestsState.order = source
281
+ requestsState.business = source
282
+ const options = {}
283
+ if (hashKey) {
284
+ options.headers = {
285
+ 'X-uuid-access-X': hashKey
286
+ }
287
+ }
288
+ if (userCustomerId || driverAndBusinessId) {
289
+ options.query = {
290
+ mode: 'dashboard'
291
+ }
292
+ }
293
+
294
+ try {
295
+ let result, error
296
+ if (orderAssingId) {
297
+ const response = await fetch(`${ordering.root}/drivers/${user.id}/assign_requests/${orderAssingId}`, {
298
+ headers: {
299
+ Authorization: `Bearer ${token}`,
300
+ 'Content-Type': 'application/json',
301
+ 'X-App-X': ordering.appId,
302
+ 'X-Socket-Id-X': socket?.getId()
303
+ }
304
+ })
305
+ const res = await response.json()
306
+ result = res.result
307
+ error = res.error
308
+ } else {
309
+ const { content } = await ordering.setAccessToken(token).orders(orderId).get({ ...options, cancelToken: source })
310
+ result = content.result
311
+ error = content.error
312
+ }
313
+ const order = error ? null : result?.order || result
314
+ let err = error ? Array.isArray(result) ? result[0] : result : null
315
+ let businessData = null
316
+ if (err) {
317
+ setOrderState({
318
+ ...orderState,
319
+ loading: false,
320
+ error: [err ?? 'ERROR']
321
+ })
322
+ return
323
+ }
324
+ try {
325
+ const { content } = await ordering.setAccessToken(token).businesses(order?.business_id).select(propsToFetch).get({ cancelToken: source })
326
+ businessData = content.result
327
+ content.error && (err = content.result[0])
328
+ } catch (e) {
329
+ err = [e.message ?? 'ERROR']
330
+ }
331
+
332
+ if (isFetchDrivers) {
333
+ getDrivers(order?.id ?? orderId)
334
+ }
335
+
336
+ setOrderState({
337
+ ...orderState,
338
+ loading: false,
339
+ order,
340
+ businessData,
341
+ error: err
342
+ })
343
+ } catch (e) {
344
+ setOrderState({
345
+ ...orderState,
346
+ loading: false,
347
+ error: [e.message ?? 'ERROR']
348
+ })
349
+ }
350
+ }
351
+
352
+ const readMessages = async () => {
353
+ const messageId = messages?.messages[messages?.messages?.length - 1]?.id
354
+ if (!messageId) return
355
+ try {
356
+ const response = await fetch(`${ordering.root}/orders/${orderState.order?.id}/messages/${messageId}/read?order_id=${orderId}&order_message_id=${messageId}`, {
357
+ method: 'GET',
358
+ headers: {
359
+ Authorization: `Bearer ${token}`,
360
+ 'Content-Type': 'application/json',
361
+ 'X-App-X': ordering.appId,
362
+ 'X-Socket-Id-X': socket?.getId()
363
+ }
364
+ })
365
+ const { result } = await response.json()
366
+
367
+ setMessagesReadList(result)
368
+ events.emit('order_message_read', orderState.order?.id)
369
+ } catch (e) {
370
+ console.log(e.message)
371
+ }
372
+ }
373
+
374
+ const getDrivers = async (orderId) => {
375
+ try {
376
+ setDrivers({ ...drivers, loadingDriver: true })
377
+ const { content: { error, result } } = await ordering
378
+ .setAccessToken(token)
379
+ .controls(orderId)
380
+ .get()
381
+
382
+ setDrivers({
383
+ ...drivers,
384
+ loadingDriver: false,
385
+ drivers: result.drivers,
386
+ error: error ? result : null
387
+ })
388
+ } catch (e) {
389
+ setDrivers({
390
+ ...drivers,
391
+ loadingDriver: false,
392
+ error: e?.message ? drivers.error?.push(e?.message) : ['ERROR']
393
+ })
394
+ }
395
+ }
396
+
397
+ const handleReorder = async (orderId) => {
398
+ if (!orderId) return
399
+ try {
400
+ setReorderState({
401
+ ...reorderState,
402
+ loading: true
403
+ })
404
+ const { error, result } = await reorder(orderId)
405
+ if (!error) {
406
+ setReorderState({
407
+ ...reorderState,
408
+ loading: false,
409
+ result: result
410
+ })
411
+ } else {
412
+ setReorderState({
413
+ ...reorderState,
414
+ loading: false,
415
+ error: true,
416
+ result: result
417
+ })
418
+ }
419
+ } catch (err) {
420
+ setReorderState({
421
+ ...reorderState,
422
+ loading: false,
423
+ error: true,
424
+ result: [err?.message]
425
+ })
426
+ }
427
+ }
428
+
429
+ /**
430
+ * Method to remove products from cart
431
+ */
432
+ const handleRemoveCart = async () => {
433
+ const uuid = carts[`businessId:${orderState?.order.business_id}`]?.uuid
434
+ if (!uuid) return
435
+ try {
436
+ setCartState({
437
+ ...cartState,
438
+ loading: true
439
+ })
440
+ const content = await clearCart(uuid)
441
+ if (!content?.error) {
442
+ handleReorder(orderState?.order?.id)
443
+ setCartState({
444
+ loading: false,
445
+ error: null
446
+ })
447
+ } else {
448
+ setCartState({
449
+ loading: false,
450
+ error: content?.result
451
+ })
452
+ }
453
+ } catch (error) {
454
+ setCartState({
455
+ loading: false,
456
+ error: [error.message]
457
+ })
458
+ }
459
+ }
460
+
461
+ /**
462
+ * Method to get room socket
463
+ * @param {String} roomType drivers, orders
464
+ * @returns socket room
465
+ */
466
+ const getRoom = (roomType) => !token
467
+ ? {
468
+ room: roomType,
469
+ project: ordering.project,
470
+ role: 'public',
471
+ user_id: hashKey
472
+ }
473
+ : roomType === 'orders'
474
+ ? user?.level === 0 ? 'orders' : `orders_${userCustomerId || user?.id}`
475
+ : `drivers_${orderState.order?.driver_id}`
476
+
477
+ useEffect(() => {
478
+ !orderState.loading && loadMessages()
479
+ }, [orderState?.order?.id, orderState?.order?.status, orderState.loading])
480
+
481
+ useEffect(() => {
482
+ if (props.order && !isDriverNotification) {
483
+ setOrderState({
484
+ ...orderState,
485
+ loading: false,
486
+ order: props.order
487
+ })
488
+ if (isFetchDrivers) {
489
+ getDrivers(props.order?.id ?? orderId)
490
+ }
491
+ } else if (!orderState.order && !isDriverNotification) {
492
+ getOrder()
493
+ }
494
+
495
+ return () => {
496
+ if (requestsState.orders) {
497
+ requestsState.orders.cancel()
498
+ }
499
+ if (requestsState.business) {
500
+ requestsState.business.cancel()
501
+ }
502
+ }
503
+ }, [props.order, orderState.order?.id])
504
+
505
+ useEffect(() => {
506
+ if (orderId && isDriverNotification) {
507
+ getOrder()
508
+ }
509
+ }, [orderId, isDriverNotification])
510
+
511
+ useEffect(() => {
512
+ if (orderState.loading || loading || !socket?.socket) return
513
+ const handleUpdateOrderDetails = (order) => {
514
+ if (order?.id !== orderState.order?.id) return
515
+ showToast(ToastType.Info, t('UPDATING_ORDER', 'Updating order...'), 1000)
516
+ delete order.total
517
+ delete order.subtotal
518
+ setOrderState({
519
+ ...orderState,
520
+ order: Object.assign(orderState.order, order)
521
+ })
522
+ events.emit('order_updated', Object.assign(orderState.order, order))
523
+ }
524
+ const handleTrackingDriver = (props) => {
525
+ const location = props.location
526
+ const driverId = props.driver_id
527
+ if (driverId !== orderState?.order?.driver_id) return
528
+ const newLocation = location ?? { lat: -37.9722342, lng: 144.7729561 }
529
+ setDriverLocation(newLocation)
530
+ setOrderState({
531
+ ...orderState,
532
+ order: {
533
+ ...orderState.order,
534
+ driver: {
535
+ ...orderState.order?.driver,
536
+ location: newLocation
537
+ }
538
+ }
539
+ })
540
+ }
541
+
542
+ if (!isDisabledOrdersRoom) socket.join(getRoom('orders'))
543
+ if (orderState.order?.driver_id) {
544
+ socket.join(getRoom('drivers'))
545
+ }
546
+ socket.socket.on('connect', () => {
547
+ if (!isDisabledOrdersRoom) socket.join(getRoom('orders'))
548
+ if (orderState.order?.driver_id) {
549
+ socket.join(getRoom('drivers'))
550
+ }
551
+ })
552
+ socket.on('tracking_driver', handleTrackingDriver)
553
+ if (!socket?.socket?._callbacks?.$update_order || socket?.socket?._callbacks?.$update_order?.find(func => func?.name !== 'handleUpdateOrderDetails')) {
554
+ socket.on('update_order', handleUpdateOrderDetails)
555
+ }
556
+ return () => {
557
+ if (!isDisabledOrdersRoom) socket.leave(getRoom('orders'))
558
+ socket.off('update_order', handleUpdateOrderDetails)
559
+ socket.off('tracking_driver', handleTrackingDriver)
560
+ }
561
+ }, [orderState?.loading, socket?.socket, loading, userCustomerId, orderState.order?.driver_id, orderState.order?.id, hashKey])
562
+
563
+ useEffect(() => {
564
+ if (messages.loading) return
565
+ const handleNewMessage = (message) => {
566
+ const actualChat = messages?.messages?.find(_message => _message?.order_id === message?.order?.id)
567
+ const found = messages.messages.find(_message => _message.id === message.id)
568
+ if (!found && actualChat) {
569
+ setMessages({
570
+ ...messages,
571
+ messages: [...messages.messages, message]
572
+ })
573
+ }
574
+ }
575
+ socket.on('message', handleNewMessage)
576
+ return () => {
577
+ socket.off('message', handleNewMessage)
578
+ }
579
+ }, [messages, socket, orderState.order?.status, userCustomerId])
580
+
581
+ useEffect(() => {
582
+ if (!socket?.socket) return
583
+ const messagesOrdersRoom = user?.level === 0 ? 'messages_orders' : `messages_orders_${userCustomerId || user?.id}`
584
+ socket.join(messagesOrdersRoom)
585
+ socket.socket.on('connect', () => {
586
+ socket.join(messagesOrdersRoom)
587
+ })
588
+ return () => {
589
+ // neccesary refactor
590
+ if (!isDisabledOrdersRoom) socket.leave(messagesOrdersRoom)
591
+ }
592
+ }, [socket?.socket, userCustomerId])
593
+
594
+ useEffect(() => {
595
+ const handleCustomerReviewed = (review) => {
596
+ setOrderState({
597
+ ...orderState,
598
+ order: { ...orderState.order, user_review: review }
599
+ })
600
+ }
601
+ events.on('customer_reviewed', handleCustomerReviewed)
602
+ return () => {
603
+ events.off('customer_reviewed', handleCustomerReviewed)
604
+ }
605
+ }, [orderState])
606
+
607
+ return (
608
+ <>
609
+ {UIComponent && (
610
+ <UIComponent
611
+ {...props}
612
+ order={orderState}
613
+ updateDriverPosition={updateDriverPosition}
614
+ driverLocation={driverLocation}
615
+ messageErrors={messageErrors}
616
+ formatPrice={formatPrice}
617
+ handleAssignDriver={handleAssignDriver}
618
+ handlerSubmit={handlerSubmitSpotNumber}
619
+ handleChangeOrderStatus={handleChangeOrderStatus}
620
+ messages={messages}
621
+ drivers={drivers}
622
+ setMessages={setMessages}
623
+ readMessages={readMessages}
624
+ messagesReadList={messagesReadList}
625
+ driverUpdateLocation={driverUpdateLocation}
626
+ setDriverUpdateLocation={setDriverUpdateLocation}
627
+ forceUpdate={forceUpdate}
628
+ getOrder={getOrder}
629
+ reorderState={reorderState}
630
+ handleReorder={handleReorder}
631
+ handleRemoveCart={handleRemoveCart}
632
+ cartState={cartState}
633
+ handleClickLogisticOrder={handleClickLogisticOrder}
634
+ loadMessages={loadMessages}
635
+ />
636
+ )}
637
+ </>
638
+ )
639
+ }
640
+
641
+ OrderDetails.propTypes = {
642
+ /**
643
+ * UI Component, this must be containt all graphic elements and use parent props
644
+ */
645
+ UIComponent: PropTypes.elementType,
646
+ /**
647
+ * This must be contains orderId to fetch
648
+ */
649
+ orderId: PropTypes.oneOfType([
650
+ PropTypes.number,
651
+ PropTypes.string
652
+ ]),
653
+ /**
654
+ * Order, this must be contains an object with all order info
655
+ */
656
+ order: PropTypes.object,
657
+ /**
658
+ * Components types before order details
659
+ * Array of type components, the parent props will pass to these components
660
+ */
661
+ beforeComponents: PropTypes.arrayOf(PropTypes.elementType),
662
+ /**
663
+ * Components types after order details
664
+ * Array of type components, the parent props will pass to these components
665
+ */
666
+ afterComponents: PropTypes.arrayOf(PropTypes.elementType),
667
+ /**
668
+ * Elements before order details
669
+ * Array of HTML/Components elements, these components will not get the parent props
670
+ */
671
+ beforeElements: PropTypes.arrayOf(PropTypes.element),
672
+ /**
673
+ * Elements after order details
674
+ * Array of HTML/Components elements, these components will not get the parent props
675
+ */
676
+ afterElements: PropTypes.arrayOf(PropTypes.element)
677
+ }
678
+
679
+ OrderDetails.defaultProps = {
680
+ beforeComponents: [],
681
+ afterComponents: [],
682
+ beforeElements: [],
683
+ afterElements: []
684
+ }