@open-tender/cloud 0.5.8 → 0.5.9

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 (283) hide show
  1. package/LICENSE.md +21 -21
  2. package/README.md +3 -3
  3. package/dist/cjs/app/hooks.d.ts +67 -67
  4. package/dist/cjs/app/hooks.js +8 -8
  5. package/dist/cjs/app/index.d.ts +2 -2
  6. package/dist/cjs/app/index.js +5 -5
  7. package/dist/cjs/app/store.d.ts +197 -197
  8. package/dist/cjs/app/store.js +65 -65
  9. package/dist/cjs/index.d.ts +5 -5
  10. package/dist/cjs/index.js +11 -11
  11. package/dist/cjs/services/api.d.ts +173 -173
  12. package/dist/cjs/services/api.js +741 -741
  13. package/dist/cjs/services/errors.d.ts +50 -50
  14. package/dist/cjs/services/errors.js +53 -53
  15. package/dist/cjs/services/index.d.ts +3 -3
  16. package/dist/cjs/services/index.js +7 -7
  17. package/dist/cjs/slices/alerts.d.ts +5 -5
  18. package/dist/cjs/slices/alerts.js +29 -29
  19. package/dist/cjs/slices/allergens.d.ts +101 -101
  20. package/dist/cjs/slices/allergens.js +83 -83
  21. package/dist/cjs/slices/announcements.d.ts +180 -180
  22. package/dist/cjs/slices/announcements.js +81 -81
  23. package/dist/cjs/slices/checkout.d.ts +69 -69
  24. package/dist/cjs/slices/checkout.js +326 -326
  25. package/dist/cjs/slices/completedOrders.d.ts +31 -31
  26. package/dist/cjs/slices/completedOrders.js +61 -61
  27. package/dist/cjs/slices/config.d.ts +317 -317
  28. package/dist/cjs/slices/config.js +195 -195
  29. package/dist/cjs/slices/confirmation.d.ts +8 -8
  30. package/dist/cjs/slices/confirmation.js +23 -23
  31. package/dist/cjs/slices/customer/account.d.ts +128 -128
  32. package/dist/cjs/slices/customer/account.js +351 -351
  33. package/dist/cjs/slices/customer/addresses.d.ts +55 -55
  34. package/dist/cjs/slices/customer/addresses.js +132 -132
  35. package/dist/cjs/slices/customer/allergens.d.ts +37 -37
  36. package/dist/cjs/slices/customer/allergens.js +94 -94
  37. package/dist/cjs/slices/customer/communicationPreferences.d.ts +69 -69
  38. package/dist/cjs/slices/customer/communicationPreferences.js +164 -164
  39. package/dist/cjs/slices/customer/creditCards.d.ts +137 -137
  40. package/dist/cjs/slices/customer/creditCards.js +170 -170
  41. package/dist/cjs/slices/customer/favorites.d.ts +68 -68
  42. package/dist/cjs/slices/customer/favorites.js +173 -173
  43. package/dist/cjs/slices/customer/fcmToken.d.ts +49 -49
  44. package/dist/cjs/slices/customer/fcmToken.js +110 -110
  45. package/dist/cjs/slices/customer/giftCards.d.ts +98 -98
  46. package/dist/cjs/slices/customer/giftCards.js +222 -222
  47. package/dist/cjs/slices/customer/groupOrders.d.ts +118 -118
  48. package/dist/cjs/slices/customer/groupOrders.js +262 -262
  49. package/dist/cjs/slices/customer/history.d.ts +23 -23
  50. package/dist/cjs/slices/customer/history.js +57 -57
  51. package/dist/cjs/slices/customer/houseAccounts.d.ts +26 -26
  52. package/dist/cjs/slices/customer/houseAccounts.js +67 -67
  53. package/dist/cjs/slices/customer/index.d.ts +42 -42
  54. package/dist/cjs/slices/customer/index.js +68 -68
  55. package/dist/cjs/slices/customer/loyalty.d.ts +251 -251
  56. package/dist/cjs/slices/customer/loyalty.js +110 -110
  57. package/dist/cjs/slices/customer/order.d.ts +116 -116
  58. package/dist/cjs/slices/customer/order.js +98 -98
  59. package/dist/cjs/slices/customer/orders.d.ts +27 -27
  60. package/dist/cjs/slices/customer/orders.js +69 -69
  61. package/dist/cjs/slices/customer/pointsShop.d.ts +35 -35
  62. package/dist/cjs/slices/customer/pointsShop.js +86 -86
  63. package/dist/cjs/slices/customer/qrCode.d.ts +23 -23
  64. package/dist/cjs/slices/customer/qrCode.js +57 -57
  65. package/dist/cjs/slices/customer/rewards.d.ts +26 -26
  66. package/dist/cjs/slices/customer/rewards.js +67 -67
  67. package/dist/cjs/slices/customer/thanx.d.ts +23 -23
  68. package/dist/cjs/slices/customer/thanx.js +56 -56
  69. package/dist/cjs/slices/customer/tpls.d.ts +238 -238
  70. package/dist/cjs/slices/customer/tpls.js +102 -102
  71. package/dist/cjs/slices/customer/tplsPointsShop.d.ts +38 -38
  72. package/dist/cjs/slices/customer/tplsPointsShop.js +88 -88
  73. package/dist/cjs/slices/deals.d.ts +25 -25
  74. package/dist/cjs/slices/deals.js +96 -96
  75. package/dist/cjs/slices/donations.d.ts +27 -27
  76. package/dist/cjs/slices/donations.js +57 -57
  77. package/dist/cjs/slices/geolocation.d.ts +11 -11
  78. package/dist/cjs/slices/geolocation.js +36 -36
  79. package/dist/cjs/slices/giftCards.d.ts +27 -27
  80. package/dist/cjs/slices/giftCards.js +58 -58
  81. package/dist/cjs/slices/groupOrder.d.ts +418 -418
  82. package/dist/cjs/slices/groupOrder.js +266 -266
  83. package/dist/cjs/slices/guest.d.ts +51 -51
  84. package/dist/cjs/slices/guest.js +91 -91
  85. package/dist/cjs/slices/index.d.ts +41 -41
  86. package/dist/cjs/slices/index.js +44 -44
  87. package/dist/cjs/slices/loader.d.ts +9 -9
  88. package/dist/cjs/slices/loader.js +25 -25
  89. package/dist/cjs/slices/menu.d.ts +31 -31
  90. package/dist/cjs/slices/menu.js +97 -97
  91. package/dist/cjs/slices/menuDisplay.d.ts +32 -32
  92. package/dist/cjs/slices/menuDisplay.js +59 -59
  93. package/dist/cjs/slices/menuItems.d.ts +26 -26
  94. package/dist/cjs/slices/menuItems.js +57 -57
  95. package/dist/cjs/slices/misc.d.ts +17 -17
  96. package/dist/cjs/slices/misc.js +51 -51
  97. package/dist/cjs/slices/modal.d.ts +5 -5
  98. package/dist/cjs/slices/modal.js +30 -30
  99. package/dist/cjs/slices/nav.d.ts +7 -7
  100. package/dist/cjs/slices/nav.js +23 -23
  101. package/dist/cjs/slices/navSite.d.ts +7 -7
  102. package/dist/cjs/slices/navSite.js +23 -23
  103. package/dist/cjs/slices/notifications.d.ts +5 -5
  104. package/dist/cjs/slices/notifications.js +27 -27
  105. package/dist/cjs/slices/oneTimePasscode.d.ts +40 -40
  106. package/dist/cjs/slices/oneTimePasscode.js +91 -91
  107. package/dist/cjs/slices/order.d.ts +372 -372
  108. package/dist/cjs/slices/order.js +528 -528
  109. package/dist/cjs/slices/orderFulfillment.d.ts +37 -37
  110. package/dist/cjs/slices/orderFulfillment.js +77 -77
  111. package/dist/cjs/slices/orderRating.d.ts +52 -52
  112. package/dist/cjs/slices/orderRating.js +105 -105
  113. package/dist/cjs/slices/posts.d.ts +24 -24
  114. package/dist/cjs/slices/posts.js +55 -55
  115. package/dist/cjs/slices/pushNotifications.d.ts +9 -9
  116. package/dist/cjs/slices/pushNotifications.js +29 -29
  117. package/dist/cjs/slices/qr.d.ts +11 -11
  118. package/dist/cjs/slices/qr.js +34 -34
  119. package/dist/cjs/slices/quote.d.ts +102 -102
  120. package/dist/cjs/slices/quote.js +65 -65
  121. package/dist/cjs/slices/resetPassword.d.ts +41 -41
  122. package/dist/cjs/slices/resetPassword.js +80 -80
  123. package/dist/cjs/slices/revenueCenters.d.ts +35 -35
  124. package/dist/cjs/slices/revenueCenters.js +95 -96
  125. package/dist/cjs/slices/sidebar.d.ts +7 -7
  126. package/dist/cjs/slices/sidebar.js +23 -23
  127. package/dist/cjs/slices/sidebarModal.d.ts +7 -7
  128. package/dist/cjs/slices/sidebarModal.js +23 -23
  129. package/dist/cjs/slices/signUp.d.ts +25 -25
  130. package/dist/cjs/slices/signUp.js +60 -60
  131. package/dist/cjs/slices/tags.d.ts +101 -101
  132. package/dist/cjs/slices/tags.js +90 -90
  133. package/dist/cjs/slices/terms.d.ts +20 -20
  134. package/dist/cjs/slices/terms.js +51 -51
  135. package/dist/cjs/slices/types.d.ts +62 -62
  136. package/dist/cjs/slices/types.js +66 -66
  137. package/dist/cjs/slices/unsubscribe.d.ts +39 -39
  138. package/dist/cjs/slices/unsubscribe.js +78 -78
  139. package/dist/cjs/slices/validTimes.d.ts +23 -23
  140. package/dist/cjs/slices/validTimes.js +57 -57
  141. package/dist/cjs/slices/verifyAccount.d.ts +23 -23
  142. package/dist/cjs/slices/verifyAccount.js +54 -54
  143. package/dist/esm/app/hooks.d.ts +67 -67
  144. package/dist/esm/app/hooks.js +4 -4
  145. package/dist/esm/app/index.d.ts +2 -2
  146. package/dist/esm/app/index.js +2 -2
  147. package/dist/esm/app/store.d.ts +197 -197
  148. package/dist/esm/app/store.js +62 -62
  149. package/dist/esm/index.d.ts +5 -5
  150. package/dist/esm/index.js +5 -5
  151. package/dist/esm/services/api.d.ts +173 -173
  152. package/dist/esm/services/api.js +739 -739
  153. package/dist/esm/services/errors.d.ts +50 -50
  154. package/dist/esm/services/errors.js +50 -50
  155. package/dist/esm/services/index.d.ts +3 -3
  156. package/dist/esm/services/index.js +3 -3
  157. package/dist/esm/slices/alerts.d.ts +5 -5
  158. package/dist/esm/slices/alerts.js +24 -24
  159. package/dist/esm/slices/allergens.d.ts +101 -101
  160. package/dist/esm/slices/allergens.js +77 -77
  161. package/dist/esm/slices/announcements.d.ts +180 -180
  162. package/dist/esm/slices/announcements.js +75 -75
  163. package/dist/esm/slices/checkout.d.ts +69 -69
  164. package/dist/esm/slices/checkout.js +318 -318
  165. package/dist/esm/slices/completedOrders.d.ts +31 -31
  166. package/dist/esm/slices/completedOrders.js +57 -57
  167. package/dist/esm/slices/config.d.ts +317 -317
  168. package/dist/esm/slices/config.js +168 -168
  169. package/dist/esm/slices/confirmation.d.ts +8 -8
  170. package/dist/esm/slices/confirmation.js +18 -18
  171. package/dist/esm/slices/customer/account.d.ts +128 -128
  172. package/dist/esm/slices/customer/account.js +344 -344
  173. package/dist/esm/slices/customer/addresses.d.ts +55 -55
  174. package/dist/esm/slices/customer/addresses.js +127 -127
  175. package/dist/esm/slices/customer/allergens.d.ts +37 -37
  176. package/dist/esm/slices/customer/allergens.js +89 -89
  177. package/dist/esm/slices/customer/communicationPreferences.d.ts +69 -69
  178. package/dist/esm/slices/customer/communicationPreferences.js +159 -159
  179. package/dist/esm/slices/customer/creditCards.d.ts +137 -137
  180. package/dist/esm/slices/customer/creditCards.js +165 -165
  181. package/dist/esm/slices/customer/favorites.d.ts +68 -68
  182. package/dist/esm/slices/customer/favorites.js +168 -168
  183. package/dist/esm/slices/customer/fcmToken.d.ts +49 -49
  184. package/dist/esm/slices/customer/fcmToken.js +106 -106
  185. package/dist/esm/slices/customer/giftCards.d.ts +98 -98
  186. package/dist/esm/slices/customer/giftCards.js +217 -217
  187. package/dist/esm/slices/customer/groupOrders.d.ts +118 -118
  188. package/dist/esm/slices/customer/groupOrders.js +256 -256
  189. package/dist/esm/slices/customer/history.d.ts +23 -23
  190. package/dist/esm/slices/customer/history.js +53 -53
  191. package/dist/esm/slices/customer/houseAccounts.d.ts +26 -26
  192. package/dist/esm/slices/customer/houseAccounts.js +62 -62
  193. package/dist/esm/slices/customer/index.d.ts +42 -42
  194. package/dist/esm/slices/customer/index.js +64 -64
  195. package/dist/esm/slices/customer/loyalty.d.ts +251 -251
  196. package/dist/esm/slices/customer/loyalty.js +102 -102
  197. package/dist/esm/slices/customer/order.d.ts +116 -116
  198. package/dist/esm/slices/customer/order.js +94 -94
  199. package/dist/esm/slices/customer/orders.d.ts +27 -27
  200. package/dist/esm/slices/customer/orders.js +63 -63
  201. package/dist/esm/slices/customer/pointsShop.d.ts +35 -35
  202. package/dist/esm/slices/customer/pointsShop.js +82 -82
  203. package/dist/esm/slices/customer/qrCode.d.ts +23 -23
  204. package/dist/esm/slices/customer/qrCode.js +53 -53
  205. package/dist/esm/slices/customer/rewards.d.ts +26 -26
  206. package/dist/esm/slices/customer/rewards.js +62 -62
  207. package/dist/esm/slices/customer/thanx.d.ts +23 -23
  208. package/dist/esm/slices/customer/thanx.js +52 -52
  209. package/dist/esm/slices/customer/tpls.d.ts +238 -238
  210. package/dist/esm/slices/customer/tpls.js +98 -98
  211. package/dist/esm/slices/customer/tplsPointsShop.d.ts +38 -38
  212. package/dist/esm/slices/customer/tplsPointsShop.js +84 -84
  213. package/dist/esm/slices/deals.d.ts +25 -25
  214. package/dist/esm/slices/deals.js +90 -90
  215. package/dist/esm/slices/donations.d.ts +27 -27
  216. package/dist/esm/slices/donations.js +53 -53
  217. package/dist/esm/slices/geolocation.d.ts +11 -11
  218. package/dist/esm/slices/geolocation.js +30 -30
  219. package/dist/esm/slices/giftCards.d.ts +27 -27
  220. package/dist/esm/slices/giftCards.js +54 -54
  221. package/dist/esm/slices/groupOrder.d.ts +418 -418
  222. package/dist/esm/slices/groupOrder.js +259 -259
  223. package/dist/esm/slices/guest.d.ts +51 -51
  224. package/dist/esm/slices/guest.js +86 -86
  225. package/dist/esm/slices/index.d.ts +41 -41
  226. package/dist/esm/slices/index.js +41 -41
  227. package/dist/esm/slices/loader.d.ts +9 -9
  228. package/dist/esm/slices/loader.js +21 -21
  229. package/dist/esm/slices/menu.d.ts +31 -31
  230. package/dist/esm/slices/menu.js +90 -90
  231. package/dist/esm/slices/menuDisplay.d.ts +32 -32
  232. package/dist/esm/slices/menuDisplay.js +55 -55
  233. package/dist/esm/slices/menuItems.d.ts +26 -26
  234. package/dist/esm/slices/menuItems.js +52 -52
  235. package/dist/esm/slices/misc.d.ts +17 -17
  236. package/dist/esm/slices/misc.js +41 -41
  237. package/dist/esm/slices/modal.d.ts +5 -5
  238. package/dist/esm/slices/modal.js +25 -25
  239. package/dist/esm/slices/nav.d.ts +7 -7
  240. package/dist/esm/slices/nav.js +19 -19
  241. package/dist/esm/slices/navSite.d.ts +7 -7
  242. package/dist/esm/slices/navSite.js +19 -19
  243. package/dist/esm/slices/notifications.d.ts +5 -5
  244. package/dist/esm/slices/notifications.js +22 -22
  245. package/dist/esm/slices/oneTimePasscode.d.ts +40 -40
  246. package/dist/esm/slices/oneTimePasscode.js +86 -86
  247. package/dist/esm/slices/order.d.ts +372 -372
  248. package/dist/esm/slices/order.js +508 -508
  249. package/dist/esm/slices/orderFulfillment.d.ts +37 -37
  250. package/dist/esm/slices/orderFulfillment.js +73 -73
  251. package/dist/esm/slices/orderRating.d.ts +52 -52
  252. package/dist/esm/slices/orderRating.js +101 -101
  253. package/dist/esm/slices/posts.d.ts +24 -24
  254. package/dist/esm/slices/posts.js +51 -51
  255. package/dist/esm/slices/pushNotifications.d.ts +9 -9
  256. package/dist/esm/slices/pushNotifications.js +23 -23
  257. package/dist/esm/slices/qr.d.ts +11 -11
  258. package/dist/esm/slices/qr.js +29 -29
  259. package/dist/esm/slices/quote.d.ts +102 -102
  260. package/dist/esm/slices/quote.js +61 -61
  261. package/dist/esm/slices/resetPassword.d.ts +41 -41
  262. package/dist/esm/slices/resetPassword.js +76 -76
  263. package/dist/esm/slices/revenueCenters.d.ts +35 -35
  264. package/dist/esm/slices/revenueCenters.js +89 -90
  265. package/dist/esm/slices/sidebar.d.ts +7 -7
  266. package/dist/esm/slices/sidebar.js +19 -19
  267. package/dist/esm/slices/sidebarModal.d.ts +7 -7
  268. package/dist/esm/slices/sidebarModal.js +19 -19
  269. package/dist/esm/slices/signUp.d.ts +25 -25
  270. package/dist/esm/slices/signUp.js +56 -56
  271. package/dist/esm/slices/tags.d.ts +101 -101
  272. package/dist/esm/slices/tags.js +84 -84
  273. package/dist/esm/slices/terms.d.ts +20 -20
  274. package/dist/esm/slices/terms.js +47 -47
  275. package/dist/esm/slices/types.d.ts +62 -62
  276. package/dist/esm/slices/types.js +63 -63
  277. package/dist/esm/slices/unsubscribe.d.ts +39 -39
  278. package/dist/esm/slices/unsubscribe.js +74 -74
  279. package/dist/esm/slices/validTimes.d.ts +23 -23
  280. package/dist/esm/slices/validTimes.js +52 -52
  281. package/dist/esm/slices/verifyAccount.d.ts +23 -23
  282. package/dist/esm/slices/verifyAccount.js +50 -50
  283. package/package.json +61 -61
@@ -1,259 +1,259 @@
1
- import { __awaiter } from "tslib";
2
- import { createAsyncThunk, createSelector, createSlice } from '@reduxjs/toolkit';
3
- import { ReducerType } from './types';
4
- import { MISSING_CUSTOMER } from '@open-tender/types';
5
- import { currentLocalDate, isoToDate, makeSimpleCart, rehydrateCart } from '@open-tender/utils';
6
- import { resetOrder, selectTimezone, setCart, setMenuVars } from './order';
7
- import { checkAuth, makeCartData, selectToken } from './customer';
8
- const initialState = {
9
- cart: [],
10
- cartGuest: null,
11
- cartGuests: [],
12
- cartId: null,
13
- cartOwner: null,
14
- closed: false,
15
- cutoffAt: null,
16
- guestCount: null,
17
- guestLimit: null,
18
- isCartOwner: false,
19
- requestedAt: null,
20
- revenueCenterId: null,
21
- serviceType: null,
22
- spendingLimit: null,
23
- token: null,
24
- error: null,
25
- loading: 'idle'
26
- };
27
- export var GroupOrderActionType;
28
- (function (GroupOrderActionType) {
29
- GroupOrderActionType["JoinGroupOrder"] = "groupOrder/joinGroupOrder";
30
- GroupOrderActionType["FetchGroupOrder"] = "groupOrder/fetchGroupOrder";
31
- GroupOrderActionType["UpdateGroupOrder"] = "groupOrder/updateGroupOrder";
32
- GroupOrderActionType["ReloadGuestOrder"] = "groupOrder/reloadGuestOrder";
33
- GroupOrderActionType["AddCustomerGroupOrder"] = "customer/addCustomerGroupOrder";
34
- })(GroupOrderActionType || (GroupOrderActionType = {}));
35
- export const makeCartPayload = (response, cartGuestId) => {
36
- const { customer = null, closed, cart_id: cartId, token, cart, revenue_center_id: revenueCenterId, service_type: serviceType, requested_at: requestedAt, cutoff_at: cutoffAt, spending_limit: spendingLimit, guest_limit: guestLimit, guest_count: guestCount, cart_guests: cartGuests } = response;
37
- const filteredCart = cartGuestId
38
- ? cart.filter(i => i.cart_guest_id === cartGuestId)
39
- : cart;
40
- return {
41
- cartId,
42
- token,
43
- revenueCenterId,
44
- serviceType,
45
- requestedAt,
46
- cutoffAt,
47
- guestLimit,
48
- guestCount,
49
- spendingLimit,
50
- closed,
51
- cartOwner: customer,
52
- cart: filteredCart,
53
- cartGuests: cartGuests || []
54
- };
55
- };
56
- export const joinGroupOrder = createAsyncThunk(GroupOrderActionType.JoinGroupOrder, (requestData, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
57
- const { api } = getState().config;
58
- if (!api)
59
- return null;
60
- try {
61
- const data = {
62
- cart_id: requestData.cart_id,
63
- first_name: requestData.first_name,
64
- last_name: requestData.last_name
65
- };
66
- const response = yield api.postCartGuest(data);
67
- const { cart_guest_id: cartGuestId, first_name: firstName, last_name: lastName } = response;
68
- const { revenueCenter } = getState().order;
69
- dispatch(resetOrder());
70
- const { serviceType, requestedAt } = getState().groupOrder;
71
- dispatch(setMenuVars({ revenueCenter, serviceType, requestedAt }));
72
- dispatch(setCart([]));
73
- const payload = { cartGuestId, firstName, lastName };
74
- return payload;
75
- }
76
- catch (err) {
77
- return rejectWithValue(err);
78
- }
79
- }));
80
- export const fetchGroupOrder = createAsyncThunk(GroupOrderActionType.FetchGroupOrder, (id, { getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
81
- const { api } = getState().config;
82
- if (!api)
83
- return;
84
- try {
85
- const response = yield api.getCart(id);
86
- const { cartGuest } = getState().groupOrder;
87
- const cartGuestId = cartGuest ? cartGuest.cartGuestId : null;
88
- const payload = makeCartPayload(response, cartGuestId);
89
- return payload;
90
- }
91
- catch (err) {
92
- return rejectWithValue(err);
93
- }
94
- }));
95
- export const updateGroupOrder = createAsyncThunk(GroupOrderActionType.UpdateGroupOrder, (_, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
96
- const { api } = getState().config;
97
- if (!api)
98
- return;
99
- const { cartId, cartGuest } = getState().groupOrder;
100
- const orderCart = getState().order.cart;
101
- if (!orderCart || !cartGuest)
102
- return;
103
- try {
104
- const data = {
105
- cart: makeSimpleCart(orderCart),
106
- cart_guest_id: cartGuest.cartGuestId
107
- };
108
- const response = yield api.putCart(cartId, data);
109
- const payload = makeCartPayload(response, cartGuest.cartGuestId);
110
- return payload;
111
- }
112
- catch (err) {
113
- yield dispatch(fetchGroupOrder(cartId));
114
- return rejectWithValue(err);
115
- }
116
- }));
117
- export const reloadGuestOrder = createAsyncThunk(GroupOrderActionType.ReloadGuestOrder, (_, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
118
- const { api } = getState().config;
119
- if (!api)
120
- return;
121
- try {
122
- const { revenueCenterId, serviceType } = getState().groupOrder;
123
- const { cart: items } = getState().groupOrder;
124
- const menuItems = yield api.getMenuItems(revenueCenterId, serviceType);
125
- const { cart } = rehydrateCart(menuItems, items);
126
- dispatch(setCart(cart));
127
- return;
128
- }
129
- catch (err) {
130
- return rejectWithValue(err);
131
- }
132
- }));
133
- export const addCustomerGroupOrder = createAsyncThunk(GroupOrderActionType.AddCustomerGroupOrder, ({ spendingLimit, callback }, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
134
- try {
135
- const api = getState().config.api;
136
- const token = selectToken(getState());
137
- if (!token)
138
- throw new Error(MISSING_CUSTOMER);
139
- const cartData = makeCartData(getState().order, spendingLimit);
140
- const response = yield api.postCustomerGroupOrder(token, cartData);
141
- const customer = getState().customer.account.profile;
142
- const payload = Object.assign(Object.assign({}, makeCartPayload(response)), { isCartOwner: true, cartOwner: customer });
143
- if (callback)
144
- callback();
145
- return payload;
146
- }
147
- catch (err) {
148
- const error = err;
149
- return checkAuth(error, dispatch, () => rejectWithValue(error));
150
- }
151
- }));
152
- const groupOrderSlice = createSlice({
153
- name: ReducerType.GroupOrder,
154
- initialState,
155
- reducers: {
156
- resetGroupOrder: () => initialState,
157
- adjustGroupOrder: (state, action) => {
158
- return Object.assign(Object.assign({}, state), action.payload);
159
- }
160
- },
161
- extraReducers: builder => {
162
- builder
163
- .addCase(joinGroupOrder.fulfilled, (state, action) => {
164
- state.loading = 'idle';
165
- state.error = null;
166
- state.cartGuest = action.payload;
167
- })
168
- .addCase(joinGroupOrder.pending, state => {
169
- state.loading = 'pending';
170
- })
171
- .addCase(joinGroupOrder.rejected, (state, action) => {
172
- state.loading = 'idle';
173
- state.error = action.payload;
174
- })
175
- .addCase(fetchGroupOrder.fulfilled, (state, action) => {
176
- return Object.assign(Object.assign(Object.assign({}, state), { loading: 'idle', error: null }), action.payload);
177
- })
178
- .addCase(fetchGroupOrder.pending, state => {
179
- state.loading = 'pending';
180
- })
181
- .addCase(fetchGroupOrder.rejected, (state, action) => {
182
- state.loading = 'idle';
183
- state.error = action.payload;
184
- })
185
- .addCase(updateGroupOrder.fulfilled, (state, action) => {
186
- return Object.assign(Object.assign(Object.assign({}, state), { loading: 'idle', error: null }), action.payload);
187
- })
188
- .addCase(updateGroupOrder.pending, state => {
189
- state.loading = 'pending';
190
- })
191
- .addCase(updateGroupOrder.rejected, (state, action) => {
192
- state.loading = 'idle';
193
- state.error = action.payload;
194
- })
195
- .addCase(reloadGuestOrder.fulfilled, state => {
196
- state.loading = 'idle';
197
- })
198
- .addCase(reloadGuestOrder.pending, state => {
199
- state.loading = 'pending';
200
- })
201
- .addCase(reloadGuestOrder.rejected, (state, action) => {
202
- state.loading = 'idle';
203
- state.error = action.payload;
204
- })
205
- .addCase(addCustomerGroupOrder.fulfilled, (state, action) => {
206
- return Object.assign(Object.assign(Object.assign({}, state), action.payload), { loading: 'idle', error: null });
207
- })
208
- .addCase(addCustomerGroupOrder.pending, state => {
209
- state.loading = 'pending';
210
- })
211
- .addCase(addCustomerGroupOrder.rejected, (state, action) => {
212
- state.error = action.payload;
213
- state.loading = 'idle';
214
- });
215
- }
216
- });
217
- export const { resetGroupOrder, adjustGroupOrder } = groupOrderSlice.actions;
218
- export const selectGroupOrder = (state) => state.groupOrder;
219
- export const selectGroupOrderToken = (state) => state.groupOrder.token;
220
- export const selectSpendingLimit = createSelector((state) => {
221
- const { cartGuest, spendingLimit } = state.groupOrder;
222
- return { cartGuest, spendingLimit };
223
- }, ({ cartGuest, spendingLimit }) => {
224
- return cartGuest && spendingLimit ? parseFloat(spendingLimit) : null;
225
- });
226
- export const selectGroupOrderClosed = createSelector((state) => {
227
- const { cartGuest, cutoffAt, closed } = state.groupOrder;
228
- const tz = selectTimezone(state);
229
- return { cartGuest, cutoffAt, closed, tz };
230
- }, ({ cartGuest, cutoffAt, closed, tz }) => {
231
- const cutoffDate = cutoffAt ? isoToDate(cutoffAt, tz) : null;
232
- const pastCutoff = cutoffDate ? currentLocalDate(tz) > cutoffDate : false;
233
- return cartGuest && (closed || pastCutoff);
234
- });
235
- export const selectGroupOrderTests = createSelector((state) => {
236
- const { closed, cutoffAt, guestLimit, guestCount } = state.groupOrder;
237
- const tz = selectTimezone(state);
238
- return { closed, cutoffAt, guestLimit, guestCount, tz };
239
- }, ({ closed, cutoffAt, guestLimit, guestCount, tz }) => {
240
- const cutoffDate = cutoffAt ? isoToDate(cutoffAt, tz) : null;
241
- const pastCutoff = cutoffDate ? new Date() > cutoffDate : false;
242
- const spotsRemaining = guestLimit ? guestLimit - (guestCount !== null && guestCount !== void 0 ? guestCount : 0) : null;
243
- const atCapacity = spotsRemaining !== null && spotsRemaining <= 0;
244
- return { closed, pastCutoff, atCapacity };
245
- });
246
- export const selectGroupOrderPrepTimes = createSelector((state) => {
247
- const { revenueCenter, serviceType } = state.order;
248
- return { revenueCenter, serviceType };
249
- }, ({ revenueCenter, serviceType }) => {
250
- if (!revenueCenter || !serviceType)
251
- return {};
252
- const { wait_times, group_ordering } = revenueCenter;
253
- const { prep_time, lead_time: leadTime } = group_ordering || {};
254
- const st = serviceType === 'WALKIN' ? 'PICKUP' : serviceType;
255
- const waitTime = wait_times && wait_times[st] ? wait_times[st] : 0;
256
- const prepTime = (waitTime !== null && waitTime !== void 0 ? waitTime : 0) + (prep_time !== null && prep_time !== void 0 ? prep_time : 0);
257
- return { prepTime, leadTime };
258
- });
259
- export const groupOrderReducer = groupOrderSlice.reducer;
1
+ import { __awaiter } from "tslib";
2
+ import { createAsyncThunk, createSelector, createSlice } from '@reduxjs/toolkit';
3
+ import { ReducerType } from './types';
4
+ import { MISSING_CUSTOMER } from '@open-tender/types';
5
+ import { currentLocalDate, isoToDate, makeSimpleCart, rehydrateCart } from '@open-tender/utils';
6
+ import { resetOrder, selectTimezone, setCart, setMenuVars } from './order';
7
+ import { checkAuth, makeCartData, selectToken } from './customer';
8
+ const initialState = {
9
+ cart: [],
10
+ cartGuest: null,
11
+ cartGuests: [],
12
+ cartId: null,
13
+ cartOwner: null,
14
+ closed: false,
15
+ cutoffAt: null,
16
+ guestCount: null,
17
+ guestLimit: null,
18
+ isCartOwner: false,
19
+ requestedAt: null,
20
+ revenueCenterId: null,
21
+ serviceType: null,
22
+ spendingLimit: null,
23
+ token: null,
24
+ error: null,
25
+ loading: 'idle'
26
+ };
27
+ export var GroupOrderActionType;
28
+ (function (GroupOrderActionType) {
29
+ GroupOrderActionType["JoinGroupOrder"] = "groupOrder/joinGroupOrder";
30
+ GroupOrderActionType["FetchGroupOrder"] = "groupOrder/fetchGroupOrder";
31
+ GroupOrderActionType["UpdateGroupOrder"] = "groupOrder/updateGroupOrder";
32
+ GroupOrderActionType["ReloadGuestOrder"] = "groupOrder/reloadGuestOrder";
33
+ GroupOrderActionType["AddCustomerGroupOrder"] = "customer/addCustomerGroupOrder";
34
+ })(GroupOrderActionType || (GroupOrderActionType = {}));
35
+ export const makeCartPayload = (response, cartGuestId) => {
36
+ const { customer = null, closed, cart_id: cartId, token, cart, revenue_center_id: revenueCenterId, service_type: serviceType, requested_at: requestedAt, cutoff_at: cutoffAt, spending_limit: spendingLimit, guest_limit: guestLimit, guest_count: guestCount, cart_guests: cartGuests } = response;
37
+ const filteredCart = cartGuestId
38
+ ? cart.filter(i => i.cart_guest_id === cartGuestId)
39
+ : cart;
40
+ return {
41
+ cartId,
42
+ token,
43
+ revenueCenterId,
44
+ serviceType,
45
+ requestedAt,
46
+ cutoffAt,
47
+ guestLimit,
48
+ guestCount,
49
+ spendingLimit,
50
+ closed,
51
+ cartOwner: customer,
52
+ cart: filteredCart,
53
+ cartGuests: cartGuests || []
54
+ };
55
+ };
56
+ export const joinGroupOrder = createAsyncThunk(GroupOrderActionType.JoinGroupOrder, (requestData, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
57
+ const { api } = getState().config;
58
+ if (!api)
59
+ return null;
60
+ try {
61
+ const data = {
62
+ cart_id: requestData.cart_id,
63
+ first_name: requestData.first_name,
64
+ last_name: requestData.last_name
65
+ };
66
+ const response = yield api.postCartGuest(data);
67
+ const { cart_guest_id: cartGuestId, first_name: firstName, last_name: lastName } = response;
68
+ const { revenueCenter } = getState().order;
69
+ dispatch(resetOrder());
70
+ const { serviceType, requestedAt } = getState().groupOrder;
71
+ dispatch(setMenuVars({ revenueCenter, serviceType, requestedAt }));
72
+ dispatch(setCart([]));
73
+ const payload = { cartGuestId, firstName, lastName };
74
+ return payload;
75
+ }
76
+ catch (err) {
77
+ return rejectWithValue(err);
78
+ }
79
+ }));
80
+ export const fetchGroupOrder = createAsyncThunk(GroupOrderActionType.FetchGroupOrder, (id, { getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
81
+ const { api } = getState().config;
82
+ if (!api)
83
+ return;
84
+ try {
85
+ const response = yield api.getCart(id);
86
+ const { cartGuest } = getState().groupOrder;
87
+ const cartGuestId = cartGuest ? cartGuest.cartGuestId : null;
88
+ const payload = makeCartPayload(response, cartGuestId);
89
+ return payload;
90
+ }
91
+ catch (err) {
92
+ return rejectWithValue(err);
93
+ }
94
+ }));
95
+ export const updateGroupOrder = createAsyncThunk(GroupOrderActionType.UpdateGroupOrder, (_, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
96
+ const { api } = getState().config;
97
+ if (!api)
98
+ return;
99
+ const { cartId, cartGuest } = getState().groupOrder;
100
+ const orderCart = getState().order.cart;
101
+ if (!orderCart || !cartGuest)
102
+ return;
103
+ try {
104
+ const data = {
105
+ cart: makeSimpleCart(orderCart),
106
+ cart_guest_id: cartGuest.cartGuestId
107
+ };
108
+ const response = yield api.putCart(cartId, data);
109
+ const payload = makeCartPayload(response, cartGuest.cartGuestId);
110
+ return payload;
111
+ }
112
+ catch (err) {
113
+ yield dispatch(fetchGroupOrder(cartId));
114
+ return rejectWithValue(err);
115
+ }
116
+ }));
117
+ export const reloadGuestOrder = createAsyncThunk(GroupOrderActionType.ReloadGuestOrder, (_, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
118
+ const { api } = getState().config;
119
+ if (!api)
120
+ return;
121
+ try {
122
+ const { revenueCenterId, serviceType } = getState().groupOrder;
123
+ const { cart: items } = getState().groupOrder;
124
+ const menuItems = yield api.getMenuItems(revenueCenterId, serviceType);
125
+ const { cart } = rehydrateCart(menuItems, items);
126
+ dispatch(setCart(cart));
127
+ return;
128
+ }
129
+ catch (err) {
130
+ return rejectWithValue(err);
131
+ }
132
+ }));
133
+ export const addCustomerGroupOrder = createAsyncThunk(GroupOrderActionType.AddCustomerGroupOrder, ({ spendingLimit, callback }, { dispatch, getState, rejectWithValue }) => __awaiter(void 0, void 0, void 0, function* () {
134
+ try {
135
+ const api = getState().config.api;
136
+ const token = selectToken(getState());
137
+ if (!token)
138
+ throw new Error(MISSING_CUSTOMER);
139
+ const cartData = makeCartData(getState().order, spendingLimit);
140
+ const response = yield api.postCustomerGroupOrder(token, cartData);
141
+ const customer = getState().customer.account.profile;
142
+ const payload = Object.assign(Object.assign({}, makeCartPayload(response)), { isCartOwner: true, cartOwner: customer });
143
+ if (callback)
144
+ callback();
145
+ return payload;
146
+ }
147
+ catch (err) {
148
+ const error = err;
149
+ return checkAuth(error, dispatch, () => rejectWithValue(error));
150
+ }
151
+ }));
152
+ const groupOrderSlice = createSlice({
153
+ name: ReducerType.GroupOrder,
154
+ initialState,
155
+ reducers: {
156
+ resetGroupOrder: () => initialState,
157
+ adjustGroupOrder: (state, action) => {
158
+ return Object.assign(Object.assign({}, state), action.payload);
159
+ }
160
+ },
161
+ extraReducers: builder => {
162
+ builder
163
+ .addCase(joinGroupOrder.fulfilled, (state, action) => {
164
+ state.loading = 'idle';
165
+ state.error = null;
166
+ state.cartGuest = action.payload;
167
+ })
168
+ .addCase(joinGroupOrder.pending, state => {
169
+ state.loading = 'pending';
170
+ })
171
+ .addCase(joinGroupOrder.rejected, (state, action) => {
172
+ state.loading = 'idle';
173
+ state.error = action.payload;
174
+ })
175
+ .addCase(fetchGroupOrder.fulfilled, (state, action) => {
176
+ return Object.assign(Object.assign(Object.assign({}, state), { loading: 'idle', error: null }), action.payload);
177
+ })
178
+ .addCase(fetchGroupOrder.pending, state => {
179
+ state.loading = 'pending';
180
+ })
181
+ .addCase(fetchGroupOrder.rejected, (state, action) => {
182
+ state.loading = 'idle';
183
+ state.error = action.payload;
184
+ })
185
+ .addCase(updateGroupOrder.fulfilled, (state, action) => {
186
+ return Object.assign(Object.assign(Object.assign({}, state), { loading: 'idle', error: null }), action.payload);
187
+ })
188
+ .addCase(updateGroupOrder.pending, state => {
189
+ state.loading = 'pending';
190
+ })
191
+ .addCase(updateGroupOrder.rejected, (state, action) => {
192
+ state.loading = 'idle';
193
+ state.error = action.payload;
194
+ })
195
+ .addCase(reloadGuestOrder.fulfilled, state => {
196
+ state.loading = 'idle';
197
+ })
198
+ .addCase(reloadGuestOrder.pending, state => {
199
+ state.loading = 'pending';
200
+ })
201
+ .addCase(reloadGuestOrder.rejected, (state, action) => {
202
+ state.loading = 'idle';
203
+ state.error = action.payload;
204
+ })
205
+ .addCase(addCustomerGroupOrder.fulfilled, (state, action) => {
206
+ return Object.assign(Object.assign(Object.assign({}, state), action.payload), { loading: 'idle', error: null });
207
+ })
208
+ .addCase(addCustomerGroupOrder.pending, state => {
209
+ state.loading = 'pending';
210
+ })
211
+ .addCase(addCustomerGroupOrder.rejected, (state, action) => {
212
+ state.error = action.payload;
213
+ state.loading = 'idle';
214
+ });
215
+ }
216
+ });
217
+ export const { resetGroupOrder, adjustGroupOrder } = groupOrderSlice.actions;
218
+ export const selectGroupOrder = (state) => state.groupOrder;
219
+ export const selectGroupOrderToken = (state) => state.groupOrder.token;
220
+ export const selectSpendingLimit = createSelector((state) => {
221
+ const { cartGuest, spendingLimit } = state.groupOrder;
222
+ return { cartGuest, spendingLimit };
223
+ }, ({ cartGuest, spendingLimit }) => {
224
+ return cartGuest && spendingLimit ? parseFloat(spendingLimit) : null;
225
+ });
226
+ export const selectGroupOrderClosed = createSelector((state) => {
227
+ const { cartGuest, cutoffAt, closed } = state.groupOrder;
228
+ const tz = selectTimezone(state);
229
+ return { cartGuest, cutoffAt, closed, tz };
230
+ }, ({ cartGuest, cutoffAt, closed, tz }) => {
231
+ const cutoffDate = cutoffAt ? isoToDate(cutoffAt, tz) : null;
232
+ const pastCutoff = cutoffDate ? currentLocalDate(tz) > cutoffDate : false;
233
+ return cartGuest && (closed || pastCutoff);
234
+ });
235
+ export const selectGroupOrderTests = createSelector((state) => {
236
+ const { closed, cutoffAt, guestLimit, guestCount } = state.groupOrder;
237
+ const tz = selectTimezone(state);
238
+ return { closed, cutoffAt, guestLimit, guestCount, tz };
239
+ }, ({ closed, cutoffAt, guestLimit, guestCount, tz }) => {
240
+ const cutoffDate = cutoffAt ? isoToDate(cutoffAt, tz) : null;
241
+ const pastCutoff = cutoffDate ? new Date() > cutoffDate : false;
242
+ const spotsRemaining = guestLimit ? guestLimit - (guestCount !== null && guestCount !== void 0 ? guestCount : 0) : null;
243
+ const atCapacity = spotsRemaining !== null && spotsRemaining <= 0;
244
+ return { closed, pastCutoff, atCapacity };
245
+ });
246
+ export const selectGroupOrderPrepTimes = createSelector((state) => {
247
+ const { revenueCenter, serviceType } = state.order;
248
+ return { revenueCenter, serviceType };
249
+ }, ({ revenueCenter, serviceType }) => {
250
+ if (!revenueCenter || !serviceType)
251
+ return {};
252
+ const { wait_times, group_ordering } = revenueCenter;
253
+ const { prep_time, lead_time: leadTime } = group_ordering || {};
254
+ const st = serviceType === 'WALKIN' ? 'PICKUP' : serviceType;
255
+ const waitTime = wait_times && wait_times[st] ? wait_times[st] : 0;
256
+ const prepTime = (waitTime !== null && waitTime !== void 0 ? waitTime : 0) + (prep_time !== null && prep_time !== void 0 ? prep_time : 0);
257
+ return { prepTime, leadTime };
258
+ });
259
+ export const groupOrderReducer = groupOrderSlice.reducer;
@@ -1,51 +1,51 @@
1
- import { AppState } from '../app';
2
- import { Brands, RequestError, RequestStatus } from '@open-tender/types';
3
- export interface GuestState {
4
- brands: Brands | null;
5
- email: string | null;
6
- error: RequestError;
7
- loading: RequestStatus;
8
- showMagicLink: boolean;
9
- }
10
- export declare enum GuestActionType {
11
- FetchGuest = "guest/fetchGuest",
12
- FetchGuestThanx = "guest/fetchGuestThanx"
13
- }
14
- export declare const fetchGuest: import("@reduxjs/toolkit").AsyncThunk<Partial<GuestState>, {
15
- email: string;
16
- callback?: (() => void) | undefined;
17
- }, {
18
- state: AppState;
19
- rejectValue: {
20
- error: RequestError;
21
- email: string;
22
- };
23
- dispatch?: import("redux").Dispatch<import("redux").AnyAction> | undefined;
24
- extra?: unknown;
25
- serializedErrorType?: unknown;
26
- pendingMeta?: unknown;
27
- fulfilledMeta?: unknown;
28
- rejectedMeta?: unknown;
29
- }>;
30
- export declare const fetchGuestThanx: import("@reduxjs/toolkit").AsyncThunk<void | {
31
- email: string;
32
- }, {
33
- email: string;
34
- callback?: (() => void) | null | undefined;
35
- origin?: string | undefined;
36
- }, {
37
- state: AppState;
38
- rejectValue: {
39
- error: RequestError;
40
- email: string;
41
- };
42
- dispatch?: import("redux").Dispatch<import("redux").AnyAction> | undefined;
43
- extra?: unknown;
44
- serializedErrorType?: unknown;
45
- pendingMeta?: unknown;
46
- fulfilledMeta?: unknown;
47
- rejectedMeta?: unknown;
48
- }>;
49
- export declare const resetGuest: import("@reduxjs/toolkit").ActionCreatorWithoutPayload<"guest/resetGuest">, resetGuestErrors: import("@reduxjs/toolkit").ActionCreatorWithoutPayload<"guest/resetGuestErrors">, setGuestEmail: import("@reduxjs/toolkit").ActionCreatorWithPayload<any, "guest/setGuestEmail">;
50
- export declare const selectGuest: (state: AppState) => GuestState;
51
- export declare const guestReducer: import("redux").Reducer<GuestState, import("redux").AnyAction>;
1
+ import { AppState } from '../app';
2
+ import { Brands, RequestError, RequestStatus } from '@open-tender/types';
3
+ export interface GuestState {
4
+ brands: Brands | null;
5
+ email: string | null;
6
+ error: RequestError;
7
+ loading: RequestStatus;
8
+ showMagicLink: boolean;
9
+ }
10
+ export declare enum GuestActionType {
11
+ FetchGuest = "guest/fetchGuest",
12
+ FetchGuestThanx = "guest/fetchGuestThanx"
13
+ }
14
+ export declare const fetchGuest: import("@reduxjs/toolkit").AsyncThunk<Partial<GuestState>, {
15
+ email: string;
16
+ callback?: (() => void) | undefined;
17
+ }, {
18
+ state: AppState;
19
+ rejectValue: {
20
+ error: RequestError;
21
+ email: string;
22
+ };
23
+ dispatch?: import("redux").Dispatch<import("redux").AnyAction> | undefined;
24
+ extra?: unknown;
25
+ serializedErrorType?: unknown;
26
+ pendingMeta?: unknown;
27
+ fulfilledMeta?: unknown;
28
+ rejectedMeta?: unknown;
29
+ }>;
30
+ export declare const fetchGuestThanx: import("@reduxjs/toolkit").AsyncThunk<void | {
31
+ email: string;
32
+ }, {
33
+ email: string;
34
+ callback?: (() => void) | null | undefined;
35
+ origin?: string | undefined;
36
+ }, {
37
+ state: AppState;
38
+ rejectValue: {
39
+ error: RequestError;
40
+ email: string;
41
+ };
42
+ dispatch?: import("redux").Dispatch<import("redux").AnyAction> | undefined;
43
+ extra?: unknown;
44
+ serializedErrorType?: unknown;
45
+ pendingMeta?: unknown;
46
+ fulfilledMeta?: unknown;
47
+ rejectedMeta?: unknown;
48
+ }>;
49
+ export declare const resetGuest: import("@reduxjs/toolkit").ActionCreatorWithoutPayload<"guest/resetGuest">, resetGuestErrors: import("@reduxjs/toolkit").ActionCreatorWithoutPayload<"guest/resetGuestErrors">, setGuestEmail: import("@reduxjs/toolkit").ActionCreatorWithPayload<any, "guest/setGuestEmail">;
50
+ export declare const selectGuest: (state: AppState) => GuestState;
51
+ export declare const guestReducer: import("redux").Reducer<GuestState, import("redux").AnyAction>;