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,688 +1,688 @@
1
- import React, { useState, useEffect } from 'react'
2
- import PropTypes from 'prop-types'
3
- import { useSession } from '../../contexts/SessionContext'
4
- import { useApi } from '../../contexts/ApiContext'
5
- import { useCustomer } from '../../contexts/CustomerContext'
6
- import { useValidationFields as useValidationsFieldsController } from '../../contexts/ValidationsFieldsContext'
7
- import { useWebsocket } from '../../contexts/WebsocketContext'
8
- import parsePhoneNumber from 'libphonenumber-js'
9
- const CONDITIONAL_CODES = ['1787']
10
-
11
- /**
12
- * Component to manage user form details behavior without UI component
13
- */
14
- export const UserFormDetails = (props) => {
15
- const {
16
- UIComponent,
17
- useSessionUser,
18
- refreshSessionUser,
19
- useDefualtSessionManager,
20
- userId,
21
- user,
22
- useValidationFields,
23
- handleButtonUpdateClick,
24
- handleSuccessUpdate,
25
- isCustomerMode,
26
- isSuccess,
27
- onClose,
28
- dontToggleEditMode,
29
- isOrderTypeValidationField,
30
- checkoutFields
31
- } = props
32
-
33
- const [ordering] = useApi()
34
- const socket = useWebsocket()
35
- const [session, { changeUser }] = useSession()
36
- const [customer, { setUserCustomer }] = useCustomer()
37
- const [validationFields] = useValidationsFieldsController()
38
- const [isEdit, setIsEdit] = useState(!!props?.isEdit)
39
- const [userState, setUserState] = useState({ loading: false, loadingDriver: false, result: { error: false } })
40
- const [formState, setFormState] = useState({ loading: false, changes: {}, result: { error: false } })
41
- const [notificationsGroup, setNotificationsGroup] = useState({ loading: false, changes: {}, result: { error: false } })
42
- const [singleNotifications, setSingleNotifications] = useState({ loading: false, changes: {}, result: { error: false } })
43
- const [verifyPhoneState, setVerifyPhoneState] = useState({ loading: false, result: { error: false } })
44
- const [removeAccountState, setAccountState] = useState({ loading: false, error: null, result: null })
45
-
46
- const requestsState = {}
47
- const accessToken = useDefualtSessionManager ? session.token : props.accessToken
48
-
49
- useEffect(() => {
50
- if ((userId || (useSessionUser && refreshSessionUser)) && !session.loading && !props.userData) {
51
- setUserState({ ...userState, loading: true })
52
- const source = {}
53
- requestsState.user = source
54
- ordering.setAccessToken(accessToken).users((useSessionUser && refreshSessionUser) ? session.user.id : userId).get({ cancelToken: source }).then((response) => {
55
- setUserState({ loading: false, loadingDriver: false, result: response.content })
56
- if (response.content.result) {
57
- if (!isCustomerMode) {
58
- changeUser({
59
- ...session.user,
60
- ...response.content.result
61
- })
62
- } else {
63
- setUserCustomer({
64
- ...customer.user,
65
- ...response.content.result
66
- }, true)
67
- }
68
- }
69
- }).catch((err) => {
70
- if (err.constructor.name !== 'Cancel') {
71
- setUserState({
72
- loadingDriver: false,
73
- loading: false,
74
- result: {
75
- error: true,
76
- result: err.message
77
- }
78
- })
79
- }
80
- })
81
- } else {
82
- setUserState({
83
- loading: false,
84
- loadingDriver: false,
85
- result: {
86
- error: false,
87
- result: (useSessionUser && !refreshSessionUser) ? session.user : user
88
- }
89
- })
90
- }
91
-
92
- return () => {
93
- if (requestsState.user) {
94
- requestsState.user.cancel()
95
- }
96
- }
97
- }, [session.loading, isSuccess])
98
-
99
- /**
100
- * Clean formState
101
- */
102
- const cleanFormState = (values) => setFormState({ ...formState, ...values })
103
-
104
- /**
105
- * Default fuction for user profile workflow
106
- */
107
- const handleUpdateClick = async (changes, isImage, image) => {
108
- if (handleButtonUpdateClick) {
109
- return handleButtonUpdateClick(userState.result.result, formState.changes)
110
- }
111
- try {
112
- let response
113
- setFormState({ ...formState, loading: true })
114
- const _changes = { ...formState.changes, ...(changes ?? {}) }
115
-
116
- if (!_changes?.country_code && _changes?.country_phone_code && _changes?.cellphone) {
117
- const parsedNumber = parsePhoneNumber(`+${_changes?.country_phone_code}${_changes?.cellphone}`)
118
- _changes.country_code = parsedNumber.country
119
- }
120
-
121
- if (CONDITIONAL_CODES.includes(_changes?.country_phone_code)) {
122
- if (_changes?.country_code === 'PR') {
123
- _changes.cellphone = `787${_changes.cellphone}`
124
- _changes.country_phone_code = '1'
125
- }
126
- }
127
-
128
- formState.changes = _changes
129
-
130
- if (isImage) {
131
- response = await ordering.users(props?.userData?.id || userState.result.result.id).save({ photo: image || formState.changes.photo }, {
132
- accessToken: accessToken
133
- })
134
-
135
- const { photo, ...changes } = formState.changes
136
-
137
- setFormState({
138
- ...formState,
139
- changes: response.content.error ? formState.changes : changes,
140
- result: response.content,
141
- loading: false
142
- })
143
- } else {
144
- let _changes = formState.changes
145
- if (props?.userData?.guest_id || userState.result.result?.guest_id) {
146
- if (formState.changes.email) {
147
- _changes = {
148
- ..._changes,
149
- guest_email: formState.changes.email
150
- }
151
- }
152
- if (formState.changes.cellphone) {
153
- _changes = {
154
- ..._changes,
155
- guest_cellphone: formState.changes.cellphone
156
- }
157
- }
158
-
159
- delete _changes.email
160
- delete _changes.cellphone
161
- }
162
- response = await ordering.users(props?.userData?.id || userState.result.result.id).save(_changes, {
163
- accessToken: accessToken
164
- })
165
- setFormState({
166
- ...formState,
167
- changes: response.content.error ? formState.changes : {},
168
- result: response.content,
169
- loading: false
170
- })
171
- }
172
-
173
- if (!response.content.error) {
174
- setUserState({
175
- ...userState,
176
- loadingDriver: false,
177
- result: {
178
- ...userState.result,
179
- ...response.content
180
- }
181
- })
182
- if (!isCustomerMode) {
183
- changeUser({
184
- ...session.user,
185
- ...response.content.result
186
- })
187
- } else {
188
- setUserCustomer({
189
- ...customer.user,
190
- ...response.content.result
191
- }, changes?.setCustomerInLocal ?? true)
192
- }
193
-
194
- if (handleSuccessUpdate) {
195
- handleSuccessUpdate(response.content.result)
196
- }
197
-
198
- onClose && onClose()
199
-
200
- if (!image && !dontToggleEditMode) {
201
- setIsEdit(!isEdit)
202
- }
203
- }
204
- } catch (err) {
205
- setFormState({
206
- ...formState,
207
- result: {
208
- error: true,
209
- result: err.message
210
- },
211
- loading: false
212
- })
213
- }
214
- }
215
-
216
- /**
217
- * Update credential data
218
- * @param {EventTarget} e Related HTML event
219
- */
220
- const handleChangeInput = (e, isMany) => {
221
- let currentChanges = {}
222
- if (isMany) {
223
- Object.values(e).map(obj => {
224
- currentChanges = {
225
- ...currentChanges,
226
- [obj.name]: obj.value
227
- }
228
- })
229
- } else {
230
- currentChanges = {
231
- [e.target.name]: e.target.value
232
- }
233
- }
234
-
235
- setFormState({
236
- ...formState,
237
- changes: { ...formState.changes, ...currentChanges }
238
- })
239
- }
240
-
241
- /**
242
- * Update user photo data
243
- * @param {File} file Image to change user photo
244
- */
245
- const handlechangeImage = (file) => {
246
- const reader = new window.FileReader()
247
- reader.readAsDataURL(file)
248
- reader.onload = () => {
249
- setFormState({
250
- ...formState,
251
- changes: {
252
- ...formState.changes,
253
- photo: reader.result
254
- }
255
- })
256
- }
257
- reader.onerror = error => console.log(error)
258
- }
259
-
260
- /**
261
- * Check if field should be show
262
- * @param {string} fieldName Field name
263
- */
264
- const showField = (fieldName) => {
265
- return !useValidationFields ||
266
- (!validationFields.loading && !validationFields.fields?.checkout?.[fieldName]) ||
267
- (!validationFields.loading && validationFields.fields?.checkout?.[fieldName] &&
268
- validationFields.fields?.checkout?.[fieldName]?.enabled)
269
- }
270
-
271
- /**
272
- * Check if field is required
273
- * @param {string} fieldName Field name
274
- */
275
- const isRequiredField = (fieldName) => {
276
- let checkoutRequiredFields = null
277
- if (isOrderTypeValidationField) {
278
- checkoutRequiredFields = session?.user?.guest_id
279
- ? checkoutFields?.filter(field => field?.enabled && field?.required_with_guest)?.map(field => field?.validation_field?.code)
280
- : checkoutFields?.filter(field => field?.enabled && field?.required)?.map(field => field?.validation_field?.code)
281
- }
282
- return isOrderTypeValidationField
283
- ? checkoutRequiredFields?.includes(fieldName)
284
- : (useValidationFields &&
285
- !validationFields.loading &&
286
- validationFields.fields?.checkout?.[fieldName] &&
287
- validationFields.fields?.checkout?.[fieldName]?.enabled &&
288
- validationFields.fields?.checkout?.[fieldName]?.required)
289
- }
290
-
291
- const handleToggleAvalaibleStatusDriver = async (newValue) => {
292
- try {
293
- setUserState({ ...userState, loadingDriver: true })
294
- const response = await ordering
295
- .users(session?.user?.id)
296
- .save(
297
- { available: newValue },
298
- {
299
- accessToken: accessToken
300
- }
301
- )
302
-
303
- if (response.content.error) {
304
- setUserState({
305
- ...userState,
306
- loadingDriver: false,
307
- result: { ...userState.result, error: response.content.result }
308
- })
309
- }
310
-
311
- if (!response.content.error) {
312
- setUserState({
313
- ...userState,
314
- loadingDriver: false,
315
- result: { ...response.content }
316
- })
317
- changeUser({
318
- ...session.user,
319
- ...response.content.result
320
- })
321
- }
322
- } catch (err) {
323
- if (err.constructor.name !== 'Cancel') {
324
- setUserState({
325
- ...userState,
326
- loadingDriver: false,
327
- result: {
328
- error: true,
329
- result: err.message
330
- }
331
- })
332
- }
333
- }
334
- }
335
-
336
- /**
337
- * function to send verify code with twilio
338
- * @param {Object} values object with cellphone and country code values
339
- */
340
- const sendVerifyPhoneCode = async (values) => {
341
- const body = {
342
- cellphone: values.cellphone,
343
- country_phone_code: parseInt(values.country_phone_code)
344
- }
345
- try {
346
- setVerifyPhoneState({ ...verifyPhoneState, loading: true })
347
- const response = await fetch(`${ordering.root}/auth/sms/twilio/verify`, {
348
- method: 'POST',
349
- headers: {
350
- 'Content-Type': 'application/json',
351
- 'X-App-X': ordering.appId,
352
- 'X-Socket-Id-X': socket?.getId()
353
- },
354
- body: JSON.stringify(body)
355
- })
356
- const res = await response.json()
357
- setVerifyPhoneState({
358
- ...verifyPhoneState,
359
- loading: false,
360
- result: res
361
- })
362
- } catch (error) {
363
- setVerifyPhoneState({
364
- ...verifyPhoneState,
365
- loading: false,
366
- result: {
367
- error: error.message
368
- }
369
- })
370
- }
371
- }
372
-
373
- const updatePromotions = async (change, setState, state) => {
374
- try {
375
- const response = await ordering.users(props?.userData?.id || userState.result.result.id).save(change, {
376
- accessToken: accessToken
377
- })
378
- setState({
379
- ...state,
380
- changes: response.content.error ? change : {},
381
- result: response.content,
382
- loading: false
383
- })
384
-
385
- if (!response.content.error) {
386
- setUserState({
387
- ...userState,
388
- loadingDriver: false,
389
- result: {
390
- ...userState.result,
391
- ...response.content
392
- }
393
- })
394
- if (!isCustomerMode) {
395
- changeUser({
396
- ...session.user,
397
- ...response.content.result
398
- })
399
- } else {
400
- setUserCustomer({
401
- ...customer.user,
402
- ...response.content.result
403
- }, change?.setCustomerInLocal ?? true)
404
- }
405
-
406
- if (handleSuccessUpdate) {
407
- handleSuccessUpdate(response.content.result)
408
- }
409
- }
410
- } catch (err) {
411
- setState({
412
- ...state,
413
- result: {
414
- error: true,
415
- result: err.message
416
- },
417
- loading: false
418
- })
419
- }
420
- }
421
-
422
- const handleChangePromotions = (enabled, isSingle = false) => {
423
- const _changes = {
424
- settings: {
425
- email: {
426
- newsletter: !isSingle ? enabled : enabled?.email,
427
- promotions: !isSingle ? enabled : enabled?.email
428
- },
429
- notification: {
430
- newsletter: !isSingle ? enabled : enabled?.notification,
431
- promotions: !isSingle ? enabled : enabled?.notification
432
- },
433
- sms: {
434
- newsletter: !isSingle ? enabled : enabled?.sms,
435
- promotions: !isSingle ? enabled : enabled?.sms
436
- }
437
- }
438
- }
439
-
440
- const state = {
441
- changes: {
442
- ...[isSingle ? singleNotifications : notificationsGroup]?.changes,
443
- ..._changes
444
- },
445
- loading: true
446
- }
447
- if (isSingle) {
448
- setSingleNotifications({ ...singleNotifications, ...state })
449
- return
450
- }
451
- setNotificationsGroup({ ...notificationsGroup, ...state })
452
- }
453
-
454
- const handleChangeNotifications = (value) => {
455
- setFormState({
456
- ...formState,
457
- changes: {
458
- ...formState?.changes,
459
- settings: { email: { newsletter: value?.email, promotions: value?.email }, notification: { newsletter: value?.notification, promotions: value?.notification }, sms: { newsletter: value?.sms, promotions: value?.sms } }
460
- }
461
- })
462
- }
463
-
464
- const handleRemoveAccount = async (userId) => {
465
- const idToDelete = userId ?? session.user.id
466
- try {
467
- setAccountState({ ...removeAccountState, loading: true })
468
- const response = await fetch(`${ordering.root}/users/${idToDelete}`, {
469
- method: 'DELETE',
470
- headers: {
471
- 'Content-Type': 'application/json',
472
- Authorization: `Bearer ${accessToken}`,
473
- 'X-App-X': ordering.appId,
474
- 'X-Socket-Id-X': socket?.getId()
475
- }
476
- })
477
- const res = await response.json()
478
- setAccountState({
479
- ...removeAccountState,
480
- loading: false,
481
- result: res?.result,
482
- error: res?.error
483
- })
484
- } catch (error) {
485
- setAccountState({
486
- ...removeAccountState,
487
- loading: false,
488
- error: error.message
489
- })
490
- }
491
- }
492
-
493
- useEffect(() => {
494
- updatePromotions(
495
- singleNotifications?.loading ? singleNotifications?.changes : notificationsGroup?.changes,
496
- singleNotifications?.loading ? setSingleNotifications : setNotificationsGroup,
497
- singleNotifications?.loading ? singleNotifications : notificationsGroup
498
- )
499
- }, [notificationsGroup?.loading, singleNotifications?.loading])
500
-
501
- useEffect(() => {
502
- const handleUpdateDriver = (data) => {
503
- const changes = {}
504
- data.changes?.map(change => (
505
- changes[change.attribute] = change.new
506
- ))
507
- setUserState({
508
- ...userState,
509
- loadingDriver: false,
510
- result: {
511
- ...userState?.result,
512
- ...changes
513
- }
514
- })
515
- changeUser({
516
- ...session.user,
517
- ...changes
518
- })
519
- }
520
-
521
- socket.on('drivers_changes', handleUpdateDriver)
522
- return () => {
523
- socket.off('drivers_changes', handleUpdateDriver)
524
- }
525
- }, [socket?.socket])
526
-
527
- return (
528
- <>
529
- {UIComponent && (
530
- <UIComponent
531
- {...props}
532
- isEdit={isEdit}
533
- cleanFormState={cleanFormState}
534
- formState={formState}
535
- userState={userState}
536
- removeAccountState={removeAccountState}
537
- validationFields={validationFields}
538
- showField={showField}
539
- singleNotifications={singleNotifications}
540
- notificationsGroup={notificationsGroup}
541
- setFormState={setFormState}
542
- isRequiredField={isRequiredField}
543
- handleChangeInput={handleChangeInput}
544
- handleButtonUpdateClick={handleUpdateClick}
545
- handlechangeImage={handlechangeImage}
546
- toggleIsEdit={() => setIsEdit(!isEdit)}
547
- handleToggleAvalaibleStatusDriver={handleToggleAvalaibleStatusDriver}
548
- handleSendVerifyCode={sendVerifyPhoneCode}
549
- verifyPhoneState={verifyPhoneState}
550
- handleChangePromotions={handleChangePromotions}
551
- handleRemoveAccount={handleRemoveAccount}
552
- handleChangeNotifications={handleChangeNotifications}
553
- />
554
- )}
555
- </>
556
- )
557
- }
558
-
559
- UserFormDetails.propTypes = {
560
- /**
561
- * UI Component, this must be containt all graphic elements and use parent props
562
- */
563
- UIComponent: PropTypes.elementType,
564
- /**
565
- * Use session user to details
566
- */
567
- useSessionUser: (props, propName) => {
568
- if (props[propName] !== undefined && typeof props[propName] !== 'boolean') {
569
- return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`boolean\`.`)
570
- }
571
- if (props.user === undefined && props.userId === undefined && !props[propName]) {
572
- return new Error(`Invalid prop \`${propName}\` must be true when \`user\` and \`userId\` is not present.`)
573
- }
574
- if (props[propName] && (props.user !== undefined || props.userId !== undefined)) {
575
- return new Error(`Invalid prop \`${propName}\` must be without \`userId\` and \`user\`.`)
576
- }
577
- },
578
- /**
579
- * Refresh session user data from Ordering API
580
- */
581
- refreshSessionUser: PropTypes.bool,
582
- /**
583
- * User ID
584
- * If you provide the user id the component get user form Ordering API
585
- */
586
- userId: (props, propName) => {
587
- if (props[propName] !== undefined && typeof props[propName] !== 'number') {
588
- return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`number\`.`)
589
- }
590
- if (props.user === undefined && !props.useSessionUser && !props[propName]) {
591
- return new Error(`Invalid prop \`${propName}\` must be true when \`user\` and \`useSessionUser\` is not present.`)
592
- }
593
- if (props[propName] && (props.useSessionUser || props.user !== undefined)) {
594
- return new Error(`Invalid prop \`${propName}\` must be without \`useSessionUser\` and \`user\`.`)
595
- }
596
- },
597
- /**
598
- * User object
599
- * If you provide user object the component not get user form Ordering API
600
- */
601
- user: (props, propName) => {
602
- if (props[propName] !== undefined && typeof props[propName] !== 'object') {
603
- return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`object\`.`)
604
- }
605
- if (props.userId === undefined && !props.useSessionUser && !props[propName]) {
606
- return new Error(`Invalid prop \`${propName}\` must be true when \`useSessionUser\` and \`userId\` is not present.`)
607
- }
608
- if (props[propName] && (props.useSessionUser || props.userId !== undefined)) {
609
- return new Error(`Invalid prop \`${propName}\` must be without \`useSessionUser\` and \`userId\`.`)
610
- }
611
- },
612
- /**
613
- * Function to change default user details behavior
614
- * @param {Object} user Current user data
615
- * @param {Object} changes Current form changes
616
- */
617
- handleButtonUpdateClick: PropTypes.func,
618
- /**
619
- * Function to get user update success event
620
- * @param {Object} user User with session data
621
- */
622
- handleSuccessUpdate: PropTypes.func,
623
- /**
624
- * Enable to get validation fields to show/hide fields from Ordering API
625
- */
626
- useValidationFields: PropTypes.bool,
627
- /**
628
- * Type of validation field to apply and get from API
629
- */
630
- validationFieldsType: PropTypes.string,
631
- /**
632
- * Enable/Disable default session manager
633
- * Save user and token with default session manager
634
- */
635
- useDefualtSessionManager: PropTypes.bool,
636
- /**
637
- * Access token to update user
638
- * Is required when `useDefualtSessionManager` is false
639
- */
640
- accessToken: (props, propName) => {
641
- if (props[propName] !== undefined && typeof props[propName] !== 'string') {
642
- return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`object\`.`)
643
- }
644
- if (props[propName] === undefined && !props.useDefualtSessionManager) {
645
- return new Error(`Invalid prop \`${propName}\` is required when \`useDefualtSessionManager\` is false.`)
646
- }
647
- },
648
- /**
649
- * Components types before user details form
650
- * Array of type components, the parent props will pass to these components
651
- */
652
- beforeComponents: PropTypes.arrayOf(PropTypes.elementType),
653
- /**
654
- * Components types after user details form
655
- * Array of type components, the parent props will pass to these components
656
- */
657
- afterComponents: PropTypes.arrayOf(PropTypes.elementType),
658
- /**
659
- * Elements before user details form
660
- * Array of HTML/Components elements, these components will not get the parent props
661
- */
662
- beforeElements: PropTypes.arrayOf(PropTypes.element),
663
- /**
664
- * Elements after user details form
665
- * Array of HTML/Components elements, these components will not get the parent props
666
- */
667
- afterElements: PropTypes.arrayOf(PropTypes.element),
668
- /**
669
- * Url to login page
670
- * Url to create element link to login page
671
- */
672
- linkToLogin: PropTypes.string,
673
- /**
674
- * Element to custom link to login
675
- * You can provide de link element as react router Link or your custom Anchor to login page
676
- */
677
- elementLinkToLogin: PropTypes.element
678
- }
679
-
680
- UserFormDetails.defaultProps = {
681
- useValidationFields: false,
682
- validationFieldsType: 'checkout',
683
- useDefualtSessionManager: true,
684
- beforeComponents: [],
685
- afterComponents: [],
686
- beforeElements: [],
687
- afterElements: []
688
- }
1
+ import React, { useState, useEffect } from 'react'
2
+ import PropTypes from 'prop-types'
3
+ import { useSession } from '../../contexts/SessionContext'
4
+ import { useApi } from '../../contexts/ApiContext'
5
+ import { useCustomer } from '../../contexts/CustomerContext'
6
+ import { useValidationFields as useValidationsFieldsController } from '../../contexts/ValidationsFieldsContext'
7
+ import { useWebsocket } from '../../contexts/WebsocketContext'
8
+ import parsePhoneNumber from 'libphonenumber-js'
9
+ const CONDITIONAL_CODES = ['1787']
10
+
11
+ /**
12
+ * Component to manage user form details behavior without UI component
13
+ */
14
+ export const UserFormDetails = (props) => {
15
+ const {
16
+ UIComponent,
17
+ useSessionUser,
18
+ refreshSessionUser,
19
+ useDefualtSessionManager,
20
+ userId,
21
+ user,
22
+ useValidationFields,
23
+ handleButtonUpdateClick,
24
+ handleSuccessUpdate,
25
+ isCustomerMode,
26
+ isSuccess,
27
+ onClose,
28
+ dontToggleEditMode,
29
+ isOrderTypeValidationField,
30
+ checkoutFields
31
+ } = props
32
+
33
+ const [ordering] = useApi()
34
+ const socket = useWebsocket()
35
+ const [session, { changeUser }] = useSession()
36
+ const [customer, { setUserCustomer }] = useCustomer()
37
+ const [validationFields] = useValidationsFieldsController()
38
+ const [isEdit, setIsEdit] = useState(!!props?.isEdit)
39
+ const [userState, setUserState] = useState({ loading: false, loadingDriver: false, result: { error: false } })
40
+ const [formState, setFormState] = useState({ loading: false, changes: {}, result: { error: false } })
41
+ const [notificationsGroup, setNotificationsGroup] = useState({ loading: false, changes: {}, result: { error: false } })
42
+ const [singleNotifications, setSingleNotifications] = useState({ loading: false, changes: {}, result: { error: false } })
43
+ const [verifyPhoneState, setVerifyPhoneState] = useState({ loading: false, result: { error: false } })
44
+ const [removeAccountState, setAccountState] = useState({ loading: false, error: null, result: null })
45
+
46
+ const requestsState = {}
47
+ const accessToken = useDefualtSessionManager ? session.token : props.accessToken
48
+
49
+ useEffect(() => {
50
+ if ((userId || (useSessionUser && refreshSessionUser)) && !session.loading && !props.userData) {
51
+ setUserState({ ...userState, loading: true })
52
+ const source = {}
53
+ requestsState.user = source
54
+ ordering.setAccessToken(accessToken).users((useSessionUser && refreshSessionUser) ? session.user.id : userId).get({ cancelToken: source }).then((response) => {
55
+ setUserState({ loading: false, loadingDriver: false, result: response.content })
56
+ if (response.content.result) {
57
+ if (!isCustomerMode) {
58
+ changeUser({
59
+ ...session.user,
60
+ ...response.content.result
61
+ })
62
+ } else {
63
+ setUserCustomer({
64
+ ...customer.user,
65
+ ...response.content.result
66
+ }, true)
67
+ }
68
+ }
69
+ }).catch((err) => {
70
+ if (err.constructor.name !== 'Cancel') {
71
+ setUserState({
72
+ loadingDriver: false,
73
+ loading: false,
74
+ result: {
75
+ error: true,
76
+ result: err.message
77
+ }
78
+ })
79
+ }
80
+ })
81
+ } else {
82
+ setUserState({
83
+ loading: false,
84
+ loadingDriver: false,
85
+ result: {
86
+ error: false,
87
+ result: (useSessionUser && !refreshSessionUser) ? session.user : user
88
+ }
89
+ })
90
+ }
91
+
92
+ return () => {
93
+ if (requestsState.user) {
94
+ requestsState.user.cancel()
95
+ }
96
+ }
97
+ }, [session.loading, isSuccess])
98
+
99
+ /**
100
+ * Clean formState
101
+ */
102
+ const cleanFormState = (values) => setFormState({ ...formState, ...values })
103
+
104
+ /**
105
+ * Default fuction for user profile workflow
106
+ */
107
+ const handleUpdateClick = async (changes, isImage, image) => {
108
+ if (handleButtonUpdateClick) {
109
+ return handleButtonUpdateClick(userState.result.result, formState.changes)
110
+ }
111
+ try {
112
+ let response
113
+ setFormState({ ...formState, loading: true })
114
+ const _changes = { ...formState.changes, ...(changes ?? {}) }
115
+
116
+ if (!_changes?.country_code && _changes?.country_phone_code && _changes?.cellphone) {
117
+ const parsedNumber = parsePhoneNumber(`+${_changes?.country_phone_code}${_changes?.cellphone}`)
118
+ _changes.country_code = parsedNumber.country
119
+ }
120
+
121
+ if (CONDITIONAL_CODES.includes(_changes?.country_phone_code)) {
122
+ if (_changes?.country_code === 'PR') {
123
+ _changes.cellphone = `787${_changes.cellphone}`
124
+ _changes.country_phone_code = '1'
125
+ }
126
+ }
127
+
128
+ formState.changes = _changes
129
+
130
+ if (isImage) {
131
+ response = await ordering.users(props?.userData?.id || userState.result.result.id).save({ photo: image || formState.changes.photo }, {
132
+ accessToken: accessToken
133
+ })
134
+
135
+ const { photo, ...changes } = formState.changes
136
+
137
+ setFormState({
138
+ ...formState,
139
+ changes: response.content.error ? formState.changes : changes,
140
+ result: response.content,
141
+ loading: false
142
+ })
143
+ } else {
144
+ let _changes = formState.changes
145
+ if (props?.userData?.guest_id || userState.result.result?.guest_id) {
146
+ if (formState.changes.email) {
147
+ _changes = {
148
+ ..._changes,
149
+ guest_email: formState.changes.email
150
+ }
151
+ }
152
+ if (formState.changes.cellphone) {
153
+ _changes = {
154
+ ..._changes,
155
+ guest_cellphone: formState.changes.cellphone
156
+ }
157
+ }
158
+
159
+ delete _changes.email
160
+ delete _changes.cellphone
161
+ }
162
+ response = await ordering.users(props?.userData?.id || userState.result.result.id).save(_changes, {
163
+ accessToken: accessToken
164
+ })
165
+ setFormState({
166
+ ...formState,
167
+ changes: response.content.error ? formState.changes : {},
168
+ result: response.content,
169
+ loading: false
170
+ })
171
+ }
172
+
173
+ if (!response.content.error) {
174
+ setUserState({
175
+ ...userState,
176
+ loadingDriver: false,
177
+ result: {
178
+ ...userState.result,
179
+ ...response.content
180
+ }
181
+ })
182
+ if (!isCustomerMode) {
183
+ changeUser({
184
+ ...session.user,
185
+ ...response.content.result
186
+ })
187
+ } else {
188
+ setUserCustomer({
189
+ ...customer.user,
190
+ ...response.content.result
191
+ }, changes?.setCustomerInLocal ?? true)
192
+ }
193
+
194
+ if (handleSuccessUpdate) {
195
+ handleSuccessUpdate(response.content.result)
196
+ }
197
+
198
+ onClose && onClose()
199
+
200
+ if (!image && !dontToggleEditMode) {
201
+ setIsEdit(!isEdit)
202
+ }
203
+ }
204
+ } catch (err) {
205
+ setFormState({
206
+ ...formState,
207
+ result: {
208
+ error: true,
209
+ result: err.message
210
+ },
211
+ loading: false
212
+ })
213
+ }
214
+ }
215
+
216
+ /**
217
+ * Update credential data
218
+ * @param {EventTarget} e Related HTML event
219
+ */
220
+ const handleChangeInput = (e, isMany) => {
221
+ let currentChanges = {}
222
+ if (isMany) {
223
+ Object.values(e).map(obj => {
224
+ currentChanges = {
225
+ ...currentChanges,
226
+ [obj.name]: obj.value
227
+ }
228
+ })
229
+ } else {
230
+ currentChanges = {
231
+ [e.target.name]: e.target.value
232
+ }
233
+ }
234
+
235
+ setFormState({
236
+ ...formState,
237
+ changes: { ...formState.changes, ...currentChanges }
238
+ })
239
+ }
240
+
241
+ /**
242
+ * Update user photo data
243
+ * @param {File} file Image to change user photo
244
+ */
245
+ const handlechangeImage = (file) => {
246
+ const reader = new window.FileReader()
247
+ reader.readAsDataURL(file)
248
+ reader.onload = () => {
249
+ setFormState({
250
+ ...formState,
251
+ changes: {
252
+ ...formState.changes,
253
+ photo: reader.result
254
+ }
255
+ })
256
+ }
257
+ reader.onerror = error => console.log(error)
258
+ }
259
+
260
+ /**
261
+ * Check if field should be show
262
+ * @param {string} fieldName Field name
263
+ */
264
+ const showField = (fieldName) => {
265
+ return !useValidationFields ||
266
+ (!validationFields.loading && !validationFields.fields?.checkout?.[fieldName]) ||
267
+ (!validationFields.loading && validationFields.fields?.checkout?.[fieldName] &&
268
+ validationFields.fields?.checkout?.[fieldName]?.enabled)
269
+ }
270
+
271
+ /**
272
+ * Check if field is required
273
+ * @param {string} fieldName Field name
274
+ */
275
+ const isRequiredField = (fieldName) => {
276
+ let checkoutRequiredFields = null
277
+ if (isOrderTypeValidationField) {
278
+ checkoutRequiredFields = session?.user?.guest_id
279
+ ? checkoutFields?.filter(field => field?.enabled && field?.required_with_guest)?.map(field => field?.validation_field?.code)
280
+ : checkoutFields?.filter(field => field?.enabled && field?.required)?.map(field => field?.validation_field?.code)
281
+ }
282
+ return isOrderTypeValidationField
283
+ ? checkoutRequiredFields?.includes(fieldName)
284
+ : (useValidationFields &&
285
+ !validationFields.loading &&
286
+ validationFields.fields?.checkout?.[fieldName] &&
287
+ validationFields.fields?.checkout?.[fieldName]?.enabled &&
288
+ validationFields.fields?.checkout?.[fieldName]?.required)
289
+ }
290
+
291
+ const handleToggleAvalaibleStatusDriver = async (newValue) => {
292
+ try {
293
+ setUserState({ ...userState, loadingDriver: true })
294
+ const response = await ordering
295
+ .users(session?.user?.id)
296
+ .save(
297
+ { available: newValue },
298
+ {
299
+ accessToken: accessToken
300
+ }
301
+ )
302
+
303
+ if (response.content.error) {
304
+ setUserState({
305
+ ...userState,
306
+ loadingDriver: false,
307
+ result: { ...userState.result, error: response.content.result }
308
+ })
309
+ }
310
+
311
+ if (!response.content.error) {
312
+ setUserState({
313
+ ...userState,
314
+ loadingDriver: false,
315
+ result: { ...response.content }
316
+ })
317
+ changeUser({
318
+ ...session.user,
319
+ ...response.content.result
320
+ })
321
+ }
322
+ } catch (err) {
323
+ if (err.constructor.name !== 'Cancel') {
324
+ setUserState({
325
+ ...userState,
326
+ loadingDriver: false,
327
+ result: {
328
+ error: true,
329
+ result: err.message
330
+ }
331
+ })
332
+ }
333
+ }
334
+ }
335
+
336
+ /**
337
+ * function to send verify code with twilio
338
+ * @param {Object} values object with cellphone and country code values
339
+ */
340
+ const sendVerifyPhoneCode = async (values) => {
341
+ const body = {
342
+ cellphone: values.cellphone,
343
+ country_phone_code: parseInt(values.country_phone_code)
344
+ }
345
+ try {
346
+ setVerifyPhoneState({ ...verifyPhoneState, loading: true })
347
+ const response = await fetch(`${ordering.root}/auth/sms/twilio/verify`, {
348
+ method: 'POST',
349
+ headers: {
350
+ 'Content-Type': 'application/json',
351
+ 'X-App-X': ordering.appId,
352
+ 'X-Socket-Id-X': socket?.getId()
353
+ },
354
+ body: JSON.stringify(body)
355
+ })
356
+ const res = await response.json()
357
+ setVerifyPhoneState({
358
+ ...verifyPhoneState,
359
+ loading: false,
360
+ result: res
361
+ })
362
+ } catch (error) {
363
+ setVerifyPhoneState({
364
+ ...verifyPhoneState,
365
+ loading: false,
366
+ result: {
367
+ error: error.message
368
+ }
369
+ })
370
+ }
371
+ }
372
+
373
+ const updatePromotions = async (change, setState, state) => {
374
+ try {
375
+ const response = await ordering.users(props?.userData?.id || userState.result.result.id).save(change, {
376
+ accessToken: accessToken
377
+ })
378
+ setState({
379
+ ...state,
380
+ changes: response.content.error ? change : {},
381
+ result: response.content,
382
+ loading: false
383
+ })
384
+
385
+ if (!response.content.error) {
386
+ setUserState({
387
+ ...userState,
388
+ loadingDriver: false,
389
+ result: {
390
+ ...userState.result,
391
+ ...response.content
392
+ }
393
+ })
394
+ if (!isCustomerMode) {
395
+ changeUser({
396
+ ...session.user,
397
+ ...response.content.result
398
+ })
399
+ } else {
400
+ setUserCustomer({
401
+ ...customer.user,
402
+ ...response.content.result
403
+ }, change?.setCustomerInLocal ?? true)
404
+ }
405
+
406
+ if (handleSuccessUpdate) {
407
+ handleSuccessUpdate(response.content.result)
408
+ }
409
+ }
410
+ } catch (err) {
411
+ setState({
412
+ ...state,
413
+ result: {
414
+ error: true,
415
+ result: err.message
416
+ },
417
+ loading: false
418
+ })
419
+ }
420
+ }
421
+
422
+ const handleChangePromotions = (enabled, isSingle = false) => {
423
+ const _changes = {
424
+ settings: {
425
+ email: {
426
+ newsletter: !isSingle ? enabled : enabled?.email,
427
+ promotions: !isSingle ? enabled : enabled?.email
428
+ },
429
+ notification: {
430
+ newsletter: !isSingle ? enabled : enabled?.notification,
431
+ promotions: !isSingle ? enabled : enabled?.notification
432
+ },
433
+ sms: {
434
+ newsletter: !isSingle ? enabled : enabled?.sms,
435
+ promotions: !isSingle ? enabled : enabled?.sms
436
+ }
437
+ }
438
+ }
439
+
440
+ const state = {
441
+ changes: {
442
+ ...[isSingle ? singleNotifications : notificationsGroup]?.changes,
443
+ ..._changes
444
+ },
445
+ loading: true
446
+ }
447
+ if (isSingle) {
448
+ setSingleNotifications({ ...singleNotifications, ...state })
449
+ return
450
+ }
451
+ setNotificationsGroup({ ...notificationsGroup, ...state })
452
+ }
453
+
454
+ const handleChangeNotifications = (value) => {
455
+ setFormState({
456
+ ...formState,
457
+ changes: {
458
+ ...formState?.changes,
459
+ settings: { email: { newsletter: value?.email, promotions: value?.email }, notification: { newsletter: value?.notification, promotions: value?.notification }, sms: { newsletter: value?.sms, promotions: value?.sms } }
460
+ }
461
+ })
462
+ }
463
+
464
+ const handleRemoveAccount = async (userId) => {
465
+ const idToDelete = userId ?? session.user.id
466
+ try {
467
+ setAccountState({ ...removeAccountState, loading: true })
468
+ const response = await fetch(`${ordering.root}/users/${idToDelete}`, {
469
+ method: 'DELETE',
470
+ headers: {
471
+ 'Content-Type': 'application/json',
472
+ Authorization: `Bearer ${accessToken}`,
473
+ 'X-App-X': ordering.appId,
474
+ 'X-Socket-Id-X': socket?.getId()
475
+ }
476
+ })
477
+ const res = await response.json()
478
+ setAccountState({
479
+ ...removeAccountState,
480
+ loading: false,
481
+ result: res?.result,
482
+ error: res?.error
483
+ })
484
+ } catch (error) {
485
+ setAccountState({
486
+ ...removeAccountState,
487
+ loading: false,
488
+ error: error.message
489
+ })
490
+ }
491
+ }
492
+
493
+ useEffect(() => {
494
+ updatePromotions(
495
+ singleNotifications?.loading ? singleNotifications?.changes : notificationsGroup?.changes,
496
+ singleNotifications?.loading ? setSingleNotifications : setNotificationsGroup,
497
+ singleNotifications?.loading ? singleNotifications : notificationsGroup
498
+ )
499
+ }, [notificationsGroup?.loading, singleNotifications?.loading])
500
+
501
+ useEffect(() => {
502
+ const handleUpdateDriver = (data) => {
503
+ const changes = {}
504
+ data.changes?.map(change => (
505
+ changes[change.attribute] = change.new
506
+ ))
507
+ setUserState({
508
+ ...userState,
509
+ loadingDriver: false,
510
+ result: {
511
+ ...userState?.result,
512
+ ...changes
513
+ }
514
+ })
515
+ changeUser({
516
+ ...session.user,
517
+ ...changes
518
+ })
519
+ }
520
+
521
+ socket.on('drivers_changes', handleUpdateDriver)
522
+ return () => {
523
+ socket.off('drivers_changes', handleUpdateDriver)
524
+ }
525
+ }, [socket?.socket])
526
+
527
+ return (
528
+ <>
529
+ {UIComponent && (
530
+ <UIComponent
531
+ {...props}
532
+ isEdit={isEdit}
533
+ cleanFormState={cleanFormState}
534
+ formState={formState}
535
+ userState={userState}
536
+ removeAccountState={removeAccountState}
537
+ validationFields={validationFields}
538
+ showField={showField}
539
+ singleNotifications={singleNotifications}
540
+ notificationsGroup={notificationsGroup}
541
+ setFormState={setFormState}
542
+ isRequiredField={isRequiredField}
543
+ handleChangeInput={handleChangeInput}
544
+ handleButtonUpdateClick={handleUpdateClick}
545
+ handlechangeImage={handlechangeImage}
546
+ toggleIsEdit={() => setIsEdit(!isEdit)}
547
+ handleToggleAvalaibleStatusDriver={handleToggleAvalaibleStatusDriver}
548
+ handleSendVerifyCode={sendVerifyPhoneCode}
549
+ verifyPhoneState={verifyPhoneState}
550
+ handleChangePromotions={handleChangePromotions}
551
+ handleRemoveAccount={handleRemoveAccount}
552
+ handleChangeNotifications={handleChangeNotifications}
553
+ />
554
+ )}
555
+ </>
556
+ )
557
+ }
558
+
559
+ UserFormDetails.propTypes = {
560
+ /**
561
+ * UI Component, this must be containt all graphic elements and use parent props
562
+ */
563
+ UIComponent: PropTypes.elementType,
564
+ /**
565
+ * Use session user to details
566
+ */
567
+ useSessionUser: (props, propName) => {
568
+ if (props[propName] !== undefined && typeof props[propName] !== 'boolean') {
569
+ return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`boolean\`.`)
570
+ }
571
+ if (props.user === undefined && props.userId === undefined && !props[propName]) {
572
+ return new Error(`Invalid prop \`${propName}\` must be true when \`user\` and \`userId\` is not present.`)
573
+ }
574
+ if (props[propName] && (props.user !== undefined || props.userId !== undefined)) {
575
+ return new Error(`Invalid prop \`${propName}\` must be without \`userId\` and \`user\`.`)
576
+ }
577
+ },
578
+ /**
579
+ * Refresh session user data from Ordering API
580
+ */
581
+ refreshSessionUser: PropTypes.bool,
582
+ /**
583
+ * User ID
584
+ * If you provide the user id the component get user form Ordering API
585
+ */
586
+ userId: (props, propName) => {
587
+ if (props[propName] !== undefined && typeof props[propName] !== 'number') {
588
+ return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`number\`.`)
589
+ }
590
+ if (props.user === undefined && !props.useSessionUser && !props[propName]) {
591
+ return new Error(`Invalid prop \`${propName}\` must be true when \`user\` and \`useSessionUser\` is not present.`)
592
+ }
593
+ if (props[propName] && (props.useSessionUser || props.user !== undefined)) {
594
+ return new Error(`Invalid prop \`${propName}\` must be without \`useSessionUser\` and \`user\`.`)
595
+ }
596
+ },
597
+ /**
598
+ * User object
599
+ * If you provide user object the component not get user form Ordering API
600
+ */
601
+ user: (props, propName) => {
602
+ if (props[propName] !== undefined && typeof props[propName] !== 'object') {
603
+ return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`object\`.`)
604
+ }
605
+ if (props.userId === undefined && !props.useSessionUser && !props[propName]) {
606
+ return new Error(`Invalid prop \`${propName}\` must be true when \`useSessionUser\` and \`userId\` is not present.`)
607
+ }
608
+ if (props[propName] && (props.useSessionUser || props.userId !== undefined)) {
609
+ return new Error(`Invalid prop \`${propName}\` must be without \`useSessionUser\` and \`userId\`.`)
610
+ }
611
+ },
612
+ /**
613
+ * Function to change default user details behavior
614
+ * @param {Object} user Current user data
615
+ * @param {Object} changes Current form changes
616
+ */
617
+ handleButtonUpdateClick: PropTypes.func,
618
+ /**
619
+ * Function to get user update success event
620
+ * @param {Object} user User with session data
621
+ */
622
+ handleSuccessUpdate: PropTypes.func,
623
+ /**
624
+ * Enable to get validation fields to show/hide fields from Ordering API
625
+ */
626
+ useValidationFields: PropTypes.bool,
627
+ /**
628
+ * Type of validation field to apply and get from API
629
+ */
630
+ validationFieldsType: PropTypes.string,
631
+ /**
632
+ * Enable/Disable default session manager
633
+ * Save user and token with default session manager
634
+ */
635
+ useDefualtSessionManager: PropTypes.bool,
636
+ /**
637
+ * Access token to update user
638
+ * Is required when `useDefualtSessionManager` is false
639
+ */
640
+ accessToken: (props, propName) => {
641
+ if (props[propName] !== undefined && typeof props[propName] !== 'string') {
642
+ return new Error(`Invalid prop \`${propName}\` of type \`${typeof props[propName]}\` supplied to \`UserFormDetails\`, expected \`object\`.`)
643
+ }
644
+ if (props[propName] === undefined && !props.useDefualtSessionManager) {
645
+ return new Error(`Invalid prop \`${propName}\` is required when \`useDefualtSessionManager\` is false.`)
646
+ }
647
+ },
648
+ /**
649
+ * Components types before user details form
650
+ * Array of type components, the parent props will pass to these components
651
+ */
652
+ beforeComponents: PropTypes.arrayOf(PropTypes.elementType),
653
+ /**
654
+ * Components types after user details form
655
+ * Array of type components, the parent props will pass to these components
656
+ */
657
+ afterComponents: PropTypes.arrayOf(PropTypes.elementType),
658
+ /**
659
+ * Elements before user details form
660
+ * Array of HTML/Components elements, these components will not get the parent props
661
+ */
662
+ beforeElements: PropTypes.arrayOf(PropTypes.element),
663
+ /**
664
+ * Elements after user details form
665
+ * Array of HTML/Components elements, these components will not get the parent props
666
+ */
667
+ afterElements: PropTypes.arrayOf(PropTypes.element),
668
+ /**
669
+ * Url to login page
670
+ * Url to create element link to login page
671
+ */
672
+ linkToLogin: PropTypes.string,
673
+ /**
674
+ * Element to custom link to login
675
+ * You can provide de link element as react router Link or your custom Anchor to login page
676
+ */
677
+ elementLinkToLogin: PropTypes.element
678
+ }
679
+
680
+ UserFormDetails.defaultProps = {
681
+ useValidationFields: false,
682
+ validationFieldsType: 'checkout',
683
+ useDefualtSessionManager: true,
684
+ beforeComponents: [],
685
+ afterComponents: [],
686
+ beforeElements: [],
687
+ afterElements: []
688
+ }