@lookiero/checkout 8.14.0-beta.3 → 8.14.0

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 (254) hide show
  1. package/.eslintrc.js +1 -1
  2. package/cypress/integration/checkout.spec.ts +259 -0
  3. package/cypress/support/e2e.ts +3 -0
  4. package/cypress/support/index.d.ts +8 -0
  5. package/cypress/support/interceptBlockCheckoutBooking.ts +4 -0
  6. package/cypress/support/interceptGiveCheckoutFeedback.ts +4 -0
  7. package/cypress/support/interceptKeepCheckoutItem.ts +4 -0
  8. package/cypress/support/interceptListCheckoutQuestionsByCheckoutId.ts +9 -0
  9. package/cypress/support/interceptListReturnQuestionsByCheckoutItemId.ts +9 -0
  10. package/cypress/support/interceptPayment.ts +23 -0
  11. package/cypress/support/interceptReplaceCheckoutItem.ts +4 -0
  12. package/cypress/support/interceptReturnCheckoutItem.ts +4 -0
  13. package/cypress/support/interceptSubmitCheckout.ts +4 -0
  14. package/cypress/support/interceptViewBookedProductsVariantsForCheckoutItem.ts +9 -0
  15. package/cypress/support/interceptViewCheckoutById.ts +6 -0
  16. package/cypress/support/interceptViewFirstAvailableCheckoutByCustomerId.ts +9 -0
  17. package/cypress/support/interceptViewFiveItemsDiscountByCustomerId.ts +6 -0
  18. package/cypress/support/interceptViewIsSizeChangeEnabledByCheckoutId.ts +6 -0
  19. package/cypress/support/interceptViewPaymentFlowPayloadByCheckoutId.ts +9 -0
  20. package/cypress/support/interceptViewPricingByCheckoutId.ts +6 -0
  21. package/cypress/tsconfig.json +8 -0
  22. package/cypress.config.ts +50 -0
  23. package/dist/src/ExpoRoot.js +2 -2
  24. package/dist/src/infrastructure/projection/payment/react/useViewPaymentFlowPayloadByCheckoutId.js +1 -1
  25. package/dist/src/infrastructure/ui/Root.d.ts +1 -2
  26. package/dist/src/infrastructure/ui/Root.js +2 -4
  27. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/ReturnQuestion.js +3 -1
  28. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/behaviors/isChildReturnQuestion.js +2 -1
  29. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/behaviors/useReturnQuestionItem.d.ts +3 -3
  30. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/ReturnQuestionItem.d.ts +4 -3
  31. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionFeedbackItem/HostDefaultReturnQuestionFeedbackItem.d.ts +2 -1
  32. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionFeedbackItem/HostDefaultReturnQuestionFeedbackItem.js +1 -0
  33. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionItem/HostDefaultReturnQuestionItem.d.ts +2 -1
  34. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionItem/HostDefaultReturnQuestionItem.js +8 -6
  35. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostRadioGroupReturnQuestionItem/HostRadioGroupReturnQuestionItem.d.ts +2 -1
  36. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostRadioGroupReturnQuestionItem/HostRadioGroupReturnQuestionItem.js +2 -1
  37. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostSelectReturnQuestionItem/HostSelectReturnQuestionItem.d.ts +2 -1
  38. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostSelectReturnQuestionItem/HostSelectReturnQuestionItem.js +4 -4
  39. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostSelectReturnQuestionItem/HostSelectReturnQuestionItem.style.d.ts +1 -1
  40. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostSelectReturnQuestionItem/HostSelectReturnQuestionItem.style.js +1 -1
  41. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostStackReturnQuestionItem/form/HostStackReturnQuestionItem.d.ts +2 -1
  42. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostStackReturnQuestionItem/form/HostStackReturnQuestionItem.js +1 -0
  43. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostStackReturnQuestionItem/modal/HostStackReturnQuestionItem.d.ts +2 -1
  44. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/hostStackReturnQuestionItem/modal/HostStackReturnQuestionItem.js +5 -3
  45. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/modalOptionReturnQuestionItems/ModalOptionReturnQuestionItems.js +6 -5
  46. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/optionReturnQuestionItem/OptionReturnQuestionItem.d.ts +2 -1
  47. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/optionReturnQuestionItem/OptionReturnQuestionItem.js +2 -1
  48. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/radioReturnQuestionItem/RadioReturnQuestionItem.d.ts +2 -1
  49. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/radioReturnQuestionItem/RadioReturnQuestionItem.js +2 -1
  50. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/returnQuestionFeedbackItem/ReturnQuestionFeedbackItem.d.ts +2 -1
  51. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/returnQuestionFeedbackItem/ReturnQuestionFeedbackItem.js +2 -1
  52. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/textareaReturnQuestionItem/TextareaReturnQuestionItem.d.ts +2 -1
  53. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/components/textareaReturnQuestionItem/TextareaReturnQuestionItem.js +2 -1
  54. package/dist/src/infrastructure/ui/components/organisms/returnQuestions/util/returnQuestionFeedback.js +18 -9
  55. package/dist/src/infrastructure/ui/test/render.js +1 -3
  56. package/dist/src/infrastructure/ui/views/App.js +7 -12
  57. package/dist/src/infrastructure/ui/views/item/components/getOutOfCheckoutModal/GetOutOfCheckoutModal.js +2 -3
  58. package/dist/src/infrastructure/ui/views/item/components/getOutOfCheckoutModal/GetOutOfCheckoutModal.style.d.ts +1 -1
  59. package/dist/src/infrastructure/ui/views/item/components/getOutOfCheckoutModal/GetOutOfCheckoutModal.style.js +1 -1
  60. package/dist/src/infrastructure/ui/views/item/components/returnQuestionsFeedback/ReturnQuestionsFeedback.js +1 -1
  61. package/dist/src/infrastructure/ui/views/item/components/selectModal/SelectModal.d.ts +9 -2
  62. package/dist/src/infrastructure/ui/views/item/components/selectModal/SelectModal.js +5 -6
  63. package/dist/src/infrastructure/ui/views/item/components/selectModal/SelectModal.style.d.ts +1 -1
  64. package/dist/src/infrastructure/ui/views/item/components/selectModal/SelectModal.style.js +1 -1
  65. package/dist/src/infrastructure/ui/views/item/components/sizeWithoutStockModal/SizeWithoutStockModal.js +2 -3
  66. package/dist/src/infrastructure/ui/views/return/components/returnQuestionsForm/ReturnQuestionsForm.js +4 -3
  67. package/dist/src/infrastructure/ui/views/summary/components/collapsiblePricing/CollapsiblePricing.js +2 -2
  68. package/dist/src/projection/returnQuestion/returnQuestion.constants.d.ts +9 -0
  69. package/dist/src/projection/returnQuestion/returnQuestion.constants.js +10 -0
  70. package/dist/src/projection/returnQuestion/returnQuestion.d.ts +23 -16
  71. package/dist/src/projection/returnQuestion/returnQuestion.js +1 -11
  72. package/dist/src/projection/returnQuestion/returnQuestion.metadata.d.ts +12 -0
  73. package/dist/src/projection/returnQuestion/returnQuestion.metadata.js +1 -0
  74. package/dist/src/projection/returnQuestion/returnQuestion.typeguard.d.ts +5 -0
  75. package/dist/src/projection/returnQuestion/returnQuestion.typeguard.js +10 -0
  76. package/dist/src/version.d.ts +1 -1
  77. package/dist/src/version.js +1 -1
  78. package/jest.setup.js +0 -20
  79. package/package.json +8 -7
  80. package/src/ExpoRoot.tsx +2 -2
  81. package/src/infrastructure/domain/uiSetting/react/useUpdateUiSetting.test.ts +1 -1
  82. package/src/infrastructure/projection/payment/react/useViewPaymentFlowPayloadByCheckoutId.ts +1 -1
  83. package/src/infrastructure/projection/returnQuestion/react/useListReturnQuestionsByCheckoutItemId.test.ts +4 -9
  84. package/src/infrastructure/projection/returnQuestion/returnQuestions.mock.ts +72 -117
  85. package/src/infrastructure/ui/Root.tsx +17 -21
  86. package/src/infrastructure/ui/components/organisms/returnQuestions/ReturnQuestion.test.tsx +10 -12
  87. package/src/infrastructure/ui/components/organisms/returnQuestions/ReturnQuestion.tsx +10 -8
  88. package/src/infrastructure/ui/components/organisms/returnQuestions/ReturnQuestions.test.tsx +10 -9
  89. package/src/infrastructure/ui/components/organisms/returnQuestions/behaviors/isChildReturnQuestion.ts +2 -1
  90. package/src/infrastructure/ui/components/organisms/returnQuestions/behaviors/useReturnQuestionItem.test.tsx +7 -9
  91. package/src/infrastructure/ui/components/organisms/returnQuestions/behaviors/useReturnQuestionItem.tsx +3 -3
  92. package/src/infrastructure/ui/components/organisms/returnQuestions/components/ReturnQuestionItem.ts +4 -3
  93. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionFeedbackItem/HostDefaultReturnQuestionFeedbackItem.test.tsx +7 -13
  94. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionFeedbackItem/HostDefaultReturnQuestionFeedbackItem.tsx +4 -2
  95. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionItem/HostDefaultReturnQuestionItem.test.tsx +8 -14
  96. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostDefaultReturnQuestionItem/HostDefaultReturnQuestionItem.tsx +13 -7
  97. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostRadioGroupReturnQuestionItem/HostRadioGroupReturnQuestionItem.tsx +7 -5
  98. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostSelectReturnQuestionItem/HostSelectReturnQuestionItem.style.ts +1 -1
  99. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostSelectReturnQuestionItem/HostSelectReturnQuestionItem.test.tsx +10 -14
  100. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostSelectReturnQuestionItem/HostSelectReturnQuestionItem.tsx +9 -8
  101. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostStackReturnQuestionItem/form/HostStackReturnQuestionItem.tsx +5 -3
  102. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostStackReturnQuestionItem/modal/HostStackReturnQuestionItem.test.tsx +43 -36
  103. package/src/infrastructure/ui/components/organisms/returnQuestions/components/hostStackReturnQuestionItem/modal/HostStackReturnQuestionItem.tsx +10 -7
  104. package/src/infrastructure/ui/components/organisms/returnQuestions/components/modalOptionReturnQuestionItems/ModalOptionReturnQuestionItems.tsx +13 -12
  105. package/src/infrastructure/ui/components/organisms/returnQuestions/components/optionReturnQuestionItem/OptionReturnQuestionItem.test.tsx +8 -14
  106. package/src/infrastructure/ui/components/organisms/returnQuestions/components/optionReturnQuestionItem/OptionReturnQuestionItem.tsx +6 -4
  107. package/src/infrastructure/ui/components/organisms/returnQuestions/components/radioReturnQuestionItem/RadioReturnQuestionItem.tsx +6 -4
  108. package/src/infrastructure/ui/components/organisms/returnQuestions/components/returnQuestionFeedbackItem/ReturnQuestionFeedbackItem.test.tsx +23 -25
  109. package/src/infrastructure/ui/components/organisms/returnQuestions/components/returnQuestionFeedbackItem/ReturnQuestionFeedbackItem.tsx +5 -3
  110. package/src/infrastructure/ui/components/organisms/returnQuestions/components/textareaReturnQuestionItem/TextareaReturnQuestionItem.test.tsx +9 -29
  111. package/src/infrastructure/ui/components/organisms/returnQuestions/components/textareaReturnQuestionItem/TextareaReturnQuestionItem.tsx +7 -5
  112. package/src/infrastructure/ui/components/organisms/returnQuestions/util/__snapshots__/returnQuestionFeedback.test.ts.snap +5 -4
  113. package/src/infrastructure/ui/components/organisms/returnQuestions/util/returnQuestionFeedback.ts +32 -18
  114. package/src/infrastructure/ui/test/render.tsx +1 -4
  115. package/src/infrastructure/ui/views/App.tsx +16 -23
  116. package/src/infrastructure/ui/views/item/components/getOutOfCheckoutModal/GetOutOfCheckoutModal.style.ts +1 -1
  117. package/src/infrastructure/ui/views/item/components/getOutOfCheckoutModal/GetOutOfCheckoutModal.tsx +2 -3
  118. package/src/infrastructure/ui/views/item/components/getOutOfCheckoutModal/__snapshots__/GetOutOfCheckoutModal.test.tsx.snap +10 -6
  119. package/src/infrastructure/ui/views/item/components/itemActions/ItemActions.tsx +0 -1
  120. package/src/infrastructure/ui/views/item/components/returnQuestionsFeedback/ReturnQuestionsFeedback.tsx +2 -4
  121. package/src/infrastructure/ui/views/item/components/selectModal/SelectModal.style.ts +1 -1
  122. package/src/infrastructure/ui/views/item/components/selectModal/SelectModal.tsx +21 -10
  123. package/src/infrastructure/ui/views/item/components/selectModal/__snapshots__/SelecModal.test.tsx.snap +15 -5
  124. package/src/infrastructure/ui/views/item/components/sizeWithoutStockModal/SizeWithoutStockModal.tsx +2 -4
  125. package/src/infrastructure/ui/views/item/components/sizeWithoutStockModal/__snapshots__/SizeWithoutStockModal.test.tsx.snap +10 -6
  126. package/src/infrastructure/ui/views/item/views/itemWithoutCustomerDecission/ItemWithoutCustomerDecission.tsx +2 -2
  127. package/src/infrastructure/ui/views/return/components/returnQuestionsForm/ReturnQuestionsForm.tsx +10 -4
  128. package/src/infrastructure/ui/views/summary/components/collapsiblePricing/CollapsiblePricing.tsx +2 -2
  129. package/src/infrastructure/ui/views/summary/components/collapsiblePricing/__snapshots__/CollapsiblePricing.test.tsx.snap +2 -2
  130. package/src/projection/returnQuestion/listReturnQuestionsByCheckoutItemId.test.ts +4 -12
  131. package/src/projection/returnQuestion/returnQuestion.constants.ts +10 -0
  132. package/src/projection/returnQuestion/returnQuestion.metadata.ts +17 -0
  133. package/src/projection/returnQuestion/returnQuestion.ts +42 -20
  134. package/src/projection/returnQuestion/returnQuestion.typeguard.ts +24 -0
  135. package/dist/pact.config.d.ts +0 -13
  136. package/dist/pact.config.js +0 -9
  137. package/dist/public/public/assets/adaptive-icon.png +0 -0
  138. package/dist/public/public/assets/favicon.png +0 -0
  139. package/dist/public/public/assets/icon.png +0 -0
  140. package/dist/public/public/assets/splash.png +0 -0
  141. package/dist/public/public/images/not-found.png +0 -0
  142. package/dist/src/infrastructure/projection/bookedProductsVariants/bookedProductsVariants.mock.d.ts +0 -3
  143. package/dist/src/infrastructure/projection/bookedProductsVariants/bookedProductsVariants.mock.js +0 -27
  144. package/dist/src/infrastructure/projection/bookedProductsVariants/httpBookedProductsVariantsForCheckoutItemView.pact.d.ts +0 -1
  145. package/dist/src/infrastructure/projection/bookedProductsVariants/httpBookedProductsVariantsForCheckoutItemView.pact.js +0 -48
  146. package/dist/src/infrastructure/projection/checkout/checkout.mock.d.ts +0 -19
  147. package/dist/src/infrastructure/projection/checkout/checkout.mock.js +0 -21
  148. package/dist/src/infrastructure/projection/checkout/httpCheckoutByIdView.pact.d.ts +0 -1
  149. package/dist/src/infrastructure/projection/checkout/httpCheckoutByIdView.pact.js +0 -109
  150. package/dist/src/infrastructure/projection/checkout/httpFirstAvailableCheckoutByCustomerIdView.pact.d.ts +0 -1
  151. package/dist/src/infrastructure/projection/checkout/httpFirstAvailableCheckoutByCustomerIdView.pact.js +0 -49
  152. package/dist/src/infrastructure/projection/checkout/httpFiveItemsDiscountByCustomerIdView.pact.d.ts +0 -1
  153. package/dist/src/infrastructure/projection/checkout/httpFiveItemsDiscountByCustomerIdView.pact.js +0 -44
  154. package/dist/src/infrastructure/projection/checkout/httpIsCheckoutEnabledByCustomerIdView.pact.d.ts +0 -1
  155. package/dist/src/infrastructure/projection/checkout/httpIsCheckoutEnabledByCustomerIdView.pact.js +0 -44
  156. package/dist/src/infrastructure/projection/checkout/httpIsSizeChangeEnabledByCheckoutIdView.pact.d.ts +0 -1
  157. package/dist/src/infrastructure/projection/checkout/httpIsSizeChangeEnabledByCheckoutIdView.pact.js +0 -44
  158. package/dist/src/infrastructure/projection/checkout/react/useViewIsCheckoutAccessibleByCustomerId.d.ts +0 -10
  159. package/dist/src/infrastructure/projection/checkout/react/useViewIsCheckoutAccessibleByCustomerId.js +0 -17
  160. package/dist/src/infrastructure/projection/checkoutBooking/checkoutBooking.mock.d.ts +0 -3
  161. package/dist/src/infrastructure/projection/checkoutBooking/checkoutBooking.mock.js +0 -6
  162. package/dist/src/infrastructure/projection/checkoutBooking/httpCheckoutBookingByIdView.pact.d.ts +0 -1
  163. package/dist/src/infrastructure/projection/checkoutBooking/httpCheckoutBookingByIdView.pact.js +0 -49
  164. package/dist/src/infrastructure/projection/checkoutItem/checkoutItem.mock.d.ts +0 -15
  165. package/dist/src/infrastructure/projection/checkoutItem/checkoutItem.mock.js +0 -43
  166. package/dist/src/infrastructure/projection/checkoutItem/httpCheckoutItemByIdView.pact.d.ts +0 -1
  167. package/dist/src/infrastructure/projection/checkoutItem/httpCheckoutItemByIdView.pact.js +0 -50
  168. package/dist/src/infrastructure/projection/checkoutQuestion/checkoutQuestions.mock.d.ts +0 -3
  169. package/dist/src/infrastructure/projection/checkoutQuestion/checkoutQuestions.mock.js +0 -103
  170. package/dist/src/infrastructure/projection/checkoutQuestion/httpCheckoutQuestionsByCheckoutIdView.pact.d.ts +0 -1
  171. package/dist/src/infrastructure/projection/checkoutQuestion/httpCheckoutQuestionsByCheckoutIdView.pact.js +0 -48
  172. package/dist/src/infrastructure/projection/payment/httpPaymentFlowPayloadByCheckoutIdView.pact.d.ts +0 -1
  173. package/dist/src/infrastructure/projection/payment/httpPaymentFlowPayloadByCheckoutIdView.pact.js +0 -109
  174. package/dist/src/infrastructure/projection/payment/paymentFlowPayload.mock.d.ts +0 -6
  175. package/dist/src/infrastructure/projection/payment/paymentFlowPayload.mock.js +0 -183
  176. package/dist/src/infrastructure/projection/pricing/httpPricingByCheckoutIdView.pact.d.ts +0 -1
  177. package/dist/src/infrastructure/projection/pricing/httpPricingByCheckoutIdView.pact.js +0 -48
  178. package/dist/src/infrastructure/projection/pricing/pricing.mock.d.ts +0 -9
  179. package/dist/src/infrastructure/projection/pricing/pricing.mock.js +0 -42
  180. package/dist/src/infrastructure/projection/returnQuestion/httpReturnQuestionsByCheckoutItemIdView.pact.d.ts +0 -1
  181. package/dist/src/infrastructure/projection/returnQuestion/httpReturnQuestionsByCheckoutItemIdView.pact.js +0 -48
  182. package/dist/src/infrastructure/projection/returnQuestion/returnQuestions.mock.d.ts +0 -3
  183. package/dist/src/infrastructure/projection/returnQuestion/returnQuestions.mock.js +0 -400
  184. package/dist/src/infrastructure/ui/components/layouts/layout/Layout.d.ts +0 -21
  185. package/dist/src/infrastructure/ui/components/layouts/layout/Layout.js +0 -1
  186. package/dist/src/infrastructure/ui/components/layouts/layout/components/footer/Footer.d.ts +0 -6
  187. package/dist/src/infrastructure/ui/components/layouts/layout/components/footer/Footer.js +0 -4
  188. package/dist/src/infrastructure/ui/components/layouts/layout/components/header/Header.d.ts +0 -6
  189. package/dist/src/infrastructure/ui/components/layouts/layout/components/header/Header.js +0 -5
  190. package/dist/src/infrastructure/ui/components/layouts/layout/components/header/Header.style.d.ts +0 -4
  191. package/dist/src/infrastructure/ui/components/layouts/layout/components/header/Header.style.js +0 -19
  192. package/dist/src/infrastructure/ui/components/layouts/layout/dummyLayout/DummyLayout.d.ts +0 -3
  193. package/dist/src/infrastructure/ui/components/layouts/layout/dummyLayout/DummyLayout.js +0 -18
  194. package/dist/src/infrastructure/ui/components/layouts/layout/dummyLayout/DummyLayout.style.d.ts +0 -12
  195. package/dist/src/infrastructure/ui/components/layouts/layout/dummyLayout/DummyLayout.style.js +0 -13
  196. package/dist/src/infrastructure/ui/components/templates/header/defaultHeader/DefaultHeader.d.ts +0 -6
  197. package/dist/src/infrastructure/ui/components/templates/header/defaultHeader/DefaultHeader.js +0 -11
  198. package/dist/src/infrastructure/ui/components/templates/header/defaultHeader/DefaultHeader.style.d.ts +0 -8
  199. package/dist/src/infrastructure/ui/components/templates/header/defaultHeader/DefaultHeader.style.js +0 -11
  200. package/dist/src/infrastructure/ui/hooks/useNewFeedbackExperiment.d.ts +0 -11
  201. package/dist/src/infrastructure/ui/hooks/useNewFeedbackExperiment.js +0 -49
  202. package/dist/src/infrastructure/ui/i18n/fetchTranslations.d.ts +0 -9
  203. package/dist/src/infrastructure/ui/i18n/fetchTranslations.js +0 -9
  204. package/dist/src/infrastructure/ui/i18n/translationEndpoint.d.ts +0 -19
  205. package/dist/src/infrastructure/ui/i18n/translationEndpoint.js +0 -21
  206. package/dist/src/infrastructure/ui/routing/CheckoutAccessibilityMiddleware.d.ts +0 -9
  207. package/dist/src/infrastructure/ui/routing/CheckoutAccessibilityMiddleware.js +0 -21
  208. package/dist/src/infrastructure/ui/views/App.style.d.ts +0 -6
  209. package/dist/src/infrastructure/ui/views/App.style.js +0 -7
  210. package/dist/src/infrastructure/ui/views/feedback/components/checkoutQuestionsForm/CheckoutQuestionsForm.style.d.ts +0 -7
  211. package/dist/src/infrastructure/ui/views/feedback/components/checkoutQuestionsForm/CheckoutQuestionsForm.style.js +0 -10
  212. package/dist/src/infrastructure/ui/views/item/components/returnQuestionsForm/ReturnQuestionsForm.d.ts +0 -11
  213. package/dist/src/infrastructure/ui/views/item/components/returnQuestionsForm/ReturnQuestionsForm.js +0 -40
  214. package/dist/src/infrastructure/ui/views/item/components/returnQuestionsForm/ReturnQuestionsForm.style.d.ts +0 -12
  215. package/dist/src/infrastructure/ui/views/item/components/returnQuestionsForm/ReturnQuestionsForm.style.js +0 -15
  216. package/dist/src/infrastructure/ui/views/return/Return.style.d.ts +0 -40
  217. package/dist/src/infrastructure/ui/views/return/Return.style.js +0 -43
  218. package/dist/src/infrastructure/ui/views/summary/components/stickyPricing/StickyPricing.d.ts +0 -13
  219. package/dist/src/infrastructure/ui/views/summary/components/stickyPricing/StickyPricing.js +0 -9
  220. package/dist/src/infrastructure/ui/views/summary/components/stickyPricing/StickyPricing.style.d.ts +0 -7
  221. package/dist/src/infrastructure/ui/views/summary/components/stickyPricing/StickyPricing.style.js +0 -10
  222. package/dist/src/projection/checkout/viewIsCheckoutAccessibleByCustomerId.d.ts +0 -17
  223. package/dist/src/projection/checkout/viewIsCheckoutAccessibleByCustomerId.js +0 -13
  224. package/dist/src/projection/shared/country.d.ts +0 -14
  225. package/dist/src/projection/shared/country.js +0 -15
  226. package/dist/src/projection/shared/customer.d.ts +0 -8
  227. package/dist/src/projection/shared/customer.js +0 -1
  228. package/dist/src/projection/shared/locale.d.ts +0 -12
  229. package/dist/src/projection/shared/locale.js +0 -13
  230. package/dist/src/projection/shared/order.d.ts +0 -6
  231. package/dist/src/projection/shared/order.js +0 -1
  232. package/dist/src/projection/shared/price.d.ts +0 -10
  233. package/dist/src/projection/shared/price.js +0 -1
  234. package/dist/src/projection/shared/size.d.ts +0 -20
  235. package/dist/src/projection/shared/size.js +0 -3
  236. package/dist/src/projection/shared/subscription.d.ts +0 -2
  237. package/dist/src/projection/shared/subscription.js +0 -1
  238. package/dist/src/shared/ui/components/atoms/error/Error.d.ts +0 -10
  239. package/dist/src/shared/ui/components/atoms/error/Error.js +0 -4
  240. package/pact.config.ts +0 -31
  241. package/pact.publish.js +0 -32
  242. package/src/infrastructure/projection/bookedProductsVariants/httpBookedProductsVariantsForCheckoutItemView.pact.ts +0 -62
  243. package/src/infrastructure/projection/checkout/httpCheckoutByIdView.pact.ts +0 -128
  244. package/src/infrastructure/projection/checkout/httpFirstAvailableCheckoutByCustomerIdView.pact.ts +0 -63
  245. package/src/infrastructure/projection/checkout/httpFiveItemsDiscountByCustomerIdView.pact.ts +0 -57
  246. package/src/infrastructure/projection/checkout/httpIsCheckoutEnabledByCustomerIdView.pact.ts +0 -57
  247. package/src/infrastructure/projection/checkout/httpIsSizeChangeEnabledByCheckoutIdView.pact.ts +0 -57
  248. package/src/infrastructure/projection/checkoutBooking/httpCheckoutBookingByIdView.pact.ts +0 -63
  249. package/src/infrastructure/projection/checkoutItem/httpCheckoutItemByIdView.pact.ts +0 -64
  250. package/src/infrastructure/projection/checkoutQuestion/httpCheckoutQuestionsByCheckoutIdView.pact.ts +0 -62
  251. package/src/infrastructure/projection/payment/httpPaymentFlowPayloadByCheckoutIdView.pact.ts +0 -136
  252. package/src/infrastructure/projection/pricing/httpPricingByCheckoutIdView.pact.ts +0 -62
  253. package/src/infrastructure/projection/returnQuestion/httpReturnQuestionsByCheckoutItemIdView.pact.ts +0 -62
  254. package/src/infrastructure/ui/views/App.style.ts +0 -9
@@ -1,19 +1,21 @@
1
+ /* eslint-disable react/prop-types */
1
2
  import React, { useCallback } from "react";
2
3
  import { TouchableHighlight, ViewStyle } from "react-native";
3
4
  import { Text } from "@lookiero/aurora";
4
5
  import { useI18nMessage } from "@lookiero/i18n-react";
6
+ import { ReturnQuestionType } from "../../../../../../../projection/returnQuestion/returnQuestion.constants";
5
7
  import { useReturnQuestionFeedbackForReturnQuestion } from "../../behaviors/useReturnQuestionFeedback";
6
- import { ReturnQuestionItem, ReturnQuestionItemProps } from "../ReturnQuestionItem";
8
+ import { ReturnQuestionItem } from "../ReturnQuestionItem";
7
9
  import { containerUnderlayColor, style } from "./OptionReturnQuestionItem.style";
8
10
 
9
- const OptionReturnQuestionItem: ReturnQuestionItem = ({
11
+ const OptionReturnQuestionItem: ReturnQuestionItem<ReturnQuestionType.OPTION> = ({
10
12
  returnQuestion,
11
13
  returnQuestionParent,
12
14
  testID,
13
- }: ReturnQuestionItemProps) => {
15
+ }) => {
14
16
  const { onChange } = useReturnQuestionFeedbackForReturnQuestion({ returnQuestion: returnQuestionParent });
15
17
 
16
- const optionText = useI18nMessage({ id: returnQuestion.name });
18
+ const optionText = useI18nMessage({ id: returnQuestion.translationKey });
17
19
  const handleOnPress = useCallback(
18
20
  () => onChange({ returnQuestionId: returnQuestionParent.id, returnQuestionFeedback: returnQuestion.id }),
19
21
  [onChange, returnQuestion.id, returnQuestionParent.id],
@@ -1,6 +1,8 @@
1
+ /* eslint-disable react/prop-types */
1
2
  import React, { useCallback, useEffect, useState } from "react";
2
3
  import { View, Option, OPTION_VARIANT, SIZE } from "@lookiero/aurora";
3
4
  import { useIntl } from "@lookiero/i18n-react";
5
+ import { ReturnQuestionType } from "../../../../../../../projection/returnQuestion/returnQuestion.constants";
4
6
  import {
5
7
  useReturnQuestionFeedback,
6
8
  useReturnQuestionFeedbackForReturnQuestion,
@@ -9,16 +11,16 @@ import {
9
11
  deepestReturnQuestionWithFeedbackForReturnQuestion,
10
12
  feedbackForReturnQuestion,
11
13
  } from "../../util/returnQuestionFeedback";
12
- import { ReturnQuestionItem, ReturnQuestionItemProps } from "../ReturnQuestionItem";
14
+ import { ReturnQuestionItem } from "../ReturnQuestionItem";
13
15
  import { ModalOptionReturnQuestionItems } from "../modalOptionReturnQuestionItems/ModalOptionReturnQuestionItems";
14
16
  import { style } from "./RadioReturnQuestionItem.style";
15
17
 
16
- const RadioReturnQuestionItem: ReturnQuestionItem = ({
18
+ const RadioReturnQuestionItem: ReturnQuestionItem<ReturnQuestionType.OPTION> = ({
17
19
  returnQuestion,
18
20
  returnQuestionParent,
19
21
  testID,
20
22
  portalHostName,
21
- }: ReturnQuestionItemProps) => {
23
+ }) => {
22
24
  const intl = useIntl();
23
25
  const [modalVisible, setModalVisible] = useState(false);
24
26
  const {
@@ -33,7 +35,7 @@ const RadioReturnQuestionItem: ReturnQuestionItem = ({
33
35
  );
34
36
 
35
37
  const inputValue = feedbackForReturnQuestion({ feedback, returnQuestion, translate }).join(" / ");
36
- const optionText = intl.formatMessage({ id: returnQuestion.name });
38
+ const optionText = intl.formatMessage({ id: returnQuestion.translationKey });
37
39
 
38
40
  const hasChildren = Boolean(returnQuestion.children && returnQuestion.children.length > 0);
39
41
 
@@ -1,8 +1,6 @@
1
1
  import React from "react";
2
- import {
3
- ReturnQuestionProjection,
4
- ReturnQuestionType,
5
- } from "../../../../../../../projection/returnQuestion/returnQuestion";
2
+ import { ReturnQuestionProjection } from "../../../../../../../projection/returnQuestion/returnQuestion";
3
+ import { ReturnQuestionType } from "../../../../../../../projection/returnQuestion/returnQuestion.constants";
6
4
  import { feedback as mockFeedback } from "../../../../../../projection/feedback/feedback.mock";
7
5
  import { I18nMessages } from "../../../../../i18n/i18n";
8
6
  import { render } from "../../../../../test/render";
@@ -12,40 +10,34 @@ jest.mock("../../behaviors/useReturnQuestionFeedback", () => ({
12
10
  useReturnQuestionFeedback: () => mockFeedback,
13
11
  }));
14
12
 
15
- const returnQuestion: ReturnQuestionProjection = {
13
+ const returnQuestion: ReturnQuestionProjection<ReturnQuestionType.HOST_DEFAULT> = {
16
14
  id: "0ad1dba8-b02c-4121-a1e3-981f1c30800d",
17
- name: "size_title",
18
- placeholder: "",
19
- type: ReturnQuestionType.HOST_STACK,
15
+ translationKey: "size_title",
16
+ type: ReturnQuestionType.HOST_DEFAULT,
20
17
  children: [
21
18
  {
22
19
  id: "9251dc2c-d76a-484d-9299-346929af932f",
23
- name: "size_large",
24
- placeholder: "",
20
+ translationKey: "size_large",
25
21
  type: ReturnQuestionType.OPTION,
26
22
  children: [
27
23
  {
28
24
  id: "542c4d24-e1da-484f-8c3a-7d89ee135adc",
29
- name: "",
30
- placeholder: "",
31
- type: ReturnQuestionType.HOST_STACK,
25
+ translationKey: "",
26
+ type: ReturnQuestionType.HOST_DEFAULT,
32
27
  children: [
33
28
  {
34
29
  id: "68c0bb98-b00a-4b86-af43-528fe903cb69",
35
- name: "size_overall",
36
- placeholder: "",
30
+ translationKey: "size_overall",
37
31
  type: ReturnQuestionType.OPTION,
38
32
  },
39
33
  {
40
34
  id: "85e84a77-461c-41e6-8544-95b5294d0b80",
41
- name: "size_trousers_too_long",
42
- placeholder: "",
35
+ translationKey: "size_trousers_too_long",
43
36
  type: ReturnQuestionType.OPTION,
44
37
  },
45
38
  {
46
39
  id: "29441d25-8d9f-471e-a13e-a03f61c88091",
47
- name: "size_fit_cut_does_not_fit",
48
- placeholder: "",
40
+ translationKey: "size_fit_cut_does_not_fit",
49
41
  type: ReturnQuestionType.OPTION,
50
42
  },
51
43
  ],
@@ -54,11 +46,17 @@ const returnQuestion: ReturnQuestionProjection = {
54
46
  },
55
47
  ],
56
48
  };
57
- const returnQuestionUnanswered: ReturnQuestionProjection = {
49
+ const returnQuestionUnanswered: ReturnQuestionProjection<ReturnQuestionType.HOST_DEFAULT> = {
58
50
  id: "fd7ff4a0-78ed-4c0d-aa4d-64962739c322",
59
- name: "style_title",
60
- placeholder: "",
61
- type: ReturnQuestionType.HOST_STACK,
51
+ translationKey: "style_title",
52
+ type: ReturnQuestionType.HOST_DEFAULT,
53
+ children: [
54
+ {
55
+ id: "68c0bb98-b00a-4b86-af43-528fe903cb69",
56
+ translationKey: "size_overall",
57
+ type: ReturnQuestionType.OPTION,
58
+ },
59
+ ],
62
60
  };
63
61
 
64
62
  describe("ReturnQuestionFeedbackItem component (ReturnQuestions organism)", () => {
@@ -70,7 +68,7 @@ describe("ReturnQuestionFeedbackItem component (ReturnQuestions organism)", () =
70
68
  />,
71
69
  );
72
70
 
73
- expect(getByText(returnQuestion.name)).toBeTruthy();
71
+ expect(getByText(returnQuestion.translationKey)).toBeTruthy();
74
72
  expect(getByText("size_large / size_overall")).toBeTruthy();
75
73
  });
76
74
 
@@ -82,7 +80,7 @@ describe("ReturnQuestionFeedbackItem component (ReturnQuestions organism)", () =
82
80
  />,
83
81
  );
84
82
 
85
- expect(getByText(returnQuestionUnanswered.name)).toBeTruthy();
83
+ expect(getByText(returnQuestionUnanswered.translationKey)).toBeTruthy();
86
84
  expect(getByText(I18nMessages.FEEDBACK_UNANSWERED)).toBeTruthy();
87
85
  });
88
86
  });
@@ -1,15 +1,17 @@
1
+ /* eslint-disable react/prop-types */
1
2
  import React, { useCallback } from "react";
2
3
  import { View } from "react-native";
3
4
  import { Text } from "@lookiero/aurora";
4
5
  import { useI18nMessage, useIntl } from "@lookiero/i18n-react";
6
+ import { ReturnQuestionType } from "../../../../../../../projection/returnQuestion/returnQuestion.constants";
5
7
  import { I18nMessages } from "../../../../../i18n/i18n";
6
8
  import { useReturnQuestionFeedback } from "../../behaviors/useReturnQuestionFeedback";
7
9
  import { feedbackForReturnQuestion } from "../../util/returnQuestionFeedback";
8
- import { ReturnQuestionItem, ReturnQuestionItemProps } from "../ReturnQuestionItem";
10
+ import { ReturnQuestionItem } from "../ReturnQuestionItem";
9
11
  import { style } from "./ReturnQuestionFeedbackItem.style";
10
12
 
11
- const ReturnQuestionFeedbackItem: ReturnQuestionItem = ({ returnQuestion }: ReturnQuestionItemProps) => {
12
- const titleText = useI18nMessage({ id: returnQuestion.name });
13
+ const ReturnQuestionFeedbackItem: ReturnQuestionItem<ReturnQuestionType.HOST_DEFAULT> = ({ returnQuestion }) => {
14
+ const titleText = useI18nMessage({ id: returnQuestion.translationKey });
13
15
  const unansweredText = useI18nMessage({ id: I18nMessages.FEEDBACK_UNANSWERED });
14
16
 
15
17
  const returnQuestionFeedback = useReturnQuestionFeedback();
@@ -1,9 +1,7 @@
1
1
  import { fireEvent } from "@testing-library/react-native";
2
2
  import React from "react";
3
- import {
4
- ReturnQuestionProjection,
5
- ReturnQuestionType,
6
- } from "../../../../../../../projection/returnQuestion/returnQuestion";
3
+ import { ReturnQuestionProjection } from "../../../../../../../projection/returnQuestion/returnQuestion";
4
+ import { ReturnQuestionType } from "../../../../../../../projection/returnQuestion/returnQuestion.constants";
7
5
  import { render } from "../../../../../test/render";
8
6
  import { TextareaReturnQuestionItem } from "./TextareaReturnQuestionItem";
9
7
 
@@ -15,31 +13,13 @@ jest.mock("../../behaviors/useReturnQuestionFeedback", () => ({
15
13
  const returnQuestionParent = {
16
14
  id: "0ad1dba8-b02c-4121-a1e3-981f1c30800d",
17
15
  } as ReturnQuestionProjection;
18
- const returnQuestion: ReturnQuestionProjection = {
19
- id: "9251dc2c-d76a-484d-9299-346929af932f",
20
- name: "size_large",
21
- placeholder: "",
22
- type: ReturnQuestionType.OPTION,
23
- children: [
24
- {
25
- id: "68c0bb98-b00a-4b86-af43-528fe903cb69",
26
- name: "size_overall",
27
- placeholder: "",
28
- type: ReturnQuestionType.OPTION,
29
- },
30
- {
31
- id: "85e84a77-461c-41e6-8544-95b5294d0b80",
32
- name: "size_trousers_too_long",
33
- placeholder: "",
34
- type: ReturnQuestionType.OPTION,
35
- },
36
- {
37
- id: "29441d25-8d9f-471e-a13e-a03f61c88091",
38
- name: "size_fit_cut_does_not_fit",
39
- placeholder: "",
40
- type: ReturnQuestionType.OPTION,
41
- },
42
- ],
16
+ const returnQuestion: ReturnQuestionProjection<ReturnQuestionType.TEXTAREA> = {
17
+ id: "1123a37d-bc00-43a4-9d28-cee1dfaf356c",
18
+ translationKey: "comment_textarea",
19
+ type: ReturnQuestionType.TEXTAREA,
20
+ metadata: {
21
+ placeholder: "comment_textarea_placeholder",
22
+ },
43
23
  };
44
24
 
45
25
  describe("TextareaReturnQuestionItem component (ReturnQuestions organism)", () => {
@@ -1,21 +1,23 @@
1
+ /* eslint-disable react/prop-types */
1
2
  import React, { useCallback, useMemo } from "react";
2
3
  import { View } from "@lookiero/aurora";
3
4
  import { useIntl } from "@lookiero/i18n-react";
5
+ import { ReturnQuestionType } from "../../../../../../../projection/returnQuestion/returnQuestion.constants";
4
6
  import { InputField } from "../../../../../../../shared/ui/components/molecules/inputField/InputField";
5
7
  import { useReturnQuestionFeedbackForReturnQuestion } from "../../behaviors/useReturnQuestionFeedback";
6
- import { ReturnQuestionItem, ReturnQuestionItemProps } from "../ReturnQuestionItem";
8
+ import { ReturnQuestionItem } from "../ReturnQuestionItem";
7
9
  import { style } from "./TextareaReturnQuestionItem.style";
8
10
 
9
- const TextareaReturnQuestionItem: ReturnQuestionItem = ({
11
+ const TextareaReturnQuestionItem: ReturnQuestionItem<ReturnQuestionType.TEXTAREA> = ({
10
12
  returnQuestion,
11
13
  returnQuestionParent,
12
14
  testID,
13
- }: ReturnQuestionItemProps) => {
15
+ }) => {
14
16
  const { formatMessage } = useIntl();
15
17
 
16
18
  const placeholderText = useMemo(
17
- () => (returnQuestion.placeholder ? formatMessage({ id: returnQuestion.placeholder }) : ""),
18
- [formatMessage, returnQuestion.placeholder],
19
+ () => (returnQuestion.metadata.placeholder ? formatMessage({ id: returnQuestion.metadata.placeholder }) : ""),
20
+ [formatMessage, returnQuestion.metadata.placeholder],
19
21
  );
20
22
 
21
23
  const { feedback, onChange } = useReturnQuestionFeedbackForReturnQuestion({ returnQuestion: returnQuestionParent });
@@ -13,14 +13,15 @@ exports[`returnQuestionFeedback utils return the deepest returnQuestion with fee
13
13
  "children": [
14
14
  {
15
15
  "id": "1123a37d-bc00-43a4-9d28-cee1dfaf356c",
16
- "name": "comment_textarea",
17
- "placeholder": "comment_textarea_placeholder",
16
+ "metadata": {
17
+ "placeholder": "comment_textarea_placeholder",
18
+ },
19
+ "translationKey": "comment_textarea",
18
20
  "type": "TEXTAREA",
19
21
  },
20
22
  ],
21
23
  "id": "ce3e8d57-5eea-4dd3-bef4-2e811a143612",
22
- "name": "comment_title",
23
- "placeholder": "",
24
+ "translationKey": "comment_title",
24
25
  "type": "HOST_TEXTAREA",
25
26
  },
26
27
  false,
@@ -1,5 +1,9 @@
1
1
  import { FeedbackProjection } from "../../../../../../projection/feedback/feedback";
2
2
  import { ReturnQuestionProjection } from "../../../../../../projection/returnQuestion/returnQuestion";
3
+ import {
4
+ returnQuestionHasChildren,
5
+ returnQuestionWithTranslationKey,
6
+ } from "../../../../../../projection/returnQuestion/returnQuestion.typeguard";
3
7
 
4
8
  type Uuid = string;
5
9
 
@@ -32,14 +36,16 @@ const feedbackForReturnQuestion: RecursiveFeedbackForReturnQuestionFunction = ({
32
36
  const returnQuestionFeedback = feedback[returnQuestionId];
33
37
 
34
38
  if (isUuid(returnQuestionFeedback as string)) {
35
- const feebackReturnQuestionChild = returnQuestion.children?.find(
36
- (childReturnQuestion) => childReturnQuestion.id === returnQuestionFeedback,
37
- );
39
+ const feebackReturnQuestionChild =
40
+ returnQuestionHasChildren(returnQuestion) &&
41
+ returnQuestion.children?.find((childReturnQuestion) => childReturnQuestion.id === returnQuestionFeedback);
38
42
 
39
43
  if (feebackReturnQuestionChild) {
40
44
  return [
41
45
  ...acc,
42
- translate(feebackReturnQuestionChild?.name),
46
+ ...(returnQuestionWithTranslationKey(feebackReturnQuestionChild)
47
+ ? [translate(feebackReturnQuestionChild.translationKey)]
48
+ : []),
43
49
  ...feedbackForReturnQuestion({ feedback, returnQuestion: feebackReturnQuestionChild, translate, acc }),
44
50
  ];
45
51
  }
@@ -51,13 +57,15 @@ const feedbackForReturnQuestion: RecursiveFeedbackForReturnQuestionFunction = ({
51
57
  }
52
58
 
53
59
  return (
54
- returnQuestion.children?.reduce(
55
- (acc, childReturnQuestion) => [
56
- ...acc,
57
- ...feedbackForReturnQuestion({ feedback, returnQuestion: childReturnQuestion, translate, acc }),
58
- ],
59
- [] as string[],
60
- ) || []
60
+ (returnQuestionHasChildren(returnQuestion) &&
61
+ returnQuestion.children?.reduce(
62
+ (acc, childReturnQuestion) => [
63
+ ...acc,
64
+ ...feedbackForReturnQuestion({ feedback, returnQuestion: childReturnQuestion, translate, acc }),
65
+ ],
66
+ [] as string[],
67
+ )) ||
68
+ []
61
69
  );
62
70
  };
63
71
 
@@ -84,9 +92,9 @@ const deepestReturnQuestionWithFeedbackForReturnQuestion: RecursiveDeepestReturn
84
92
  const returnQuestionFeedback = feedback[returnQuestionId];
85
93
 
86
94
  if (isUuid(returnQuestionFeedback as string)) {
87
- const feebackReturnQuestionChild = returnQuestion.children?.find(
88
- (childReturnQuestion) => childReturnQuestion.id === returnQuestionFeedback,
89
- );
95
+ const feebackReturnQuestionChild =
96
+ returnQuestionHasChildren(returnQuestion) &&
97
+ returnQuestion.children?.find((childReturnQuestion) => childReturnQuestion.id === returnQuestionFeedback);
90
98
 
91
99
  if (feebackReturnQuestionChild) {
92
100
  return deepestReturnQuestionWithFeedbackForReturnQuestion({
@@ -102,9 +110,11 @@ const deepestReturnQuestionWithFeedbackForReturnQuestion: RecursiveDeepestReturn
102
110
  return [returnQuestion, false];
103
111
  }
104
112
 
105
- const feebackReturnQuestionChild = returnQuestion.children?.find((childReturnQuestion) =>
106
- Object.keys(feedback).find((id) => id === childReturnQuestion.id),
107
- );
113
+ const feebackReturnQuestionChild =
114
+ returnQuestionHasChildren(returnQuestion) &&
115
+ returnQuestion.children?.find((childReturnQuestion) =>
116
+ Object.keys(feedback).find((id) => id === childReturnQuestion.id),
117
+ );
108
118
 
109
119
  if (feebackReturnQuestionChild) {
110
120
  return deepestReturnQuestionWithFeedbackForReturnQuestion({
@@ -114,7 +124,11 @@ const deepestReturnQuestionWithFeedbackForReturnQuestion: RecursiveDeepestReturn
114
124
  });
115
125
  }
116
126
 
117
- return [deepestReturnQuestion, !returnQuestion.children || returnQuestion.children.length === 0];
127
+ const hasChildren = Boolean(
128
+ returnQuestionHasChildren(returnQuestion) && returnQuestion.children && returnQuestion.children.length > 0,
129
+ );
130
+
131
+ return [deepestReturnQuestion, !hasChildren];
118
132
  };
119
133
 
120
134
  export { feedbackForReturnQuestion, deepestReturnQuestionWithFeedbackForReturnQuestion };
@@ -5,7 +5,6 @@ import { IntlProvider } from "react-intl";
5
5
  import { Aurora } from "@lookiero/aurora";
6
6
  import { TranslationMessages } from "@lookiero/i18n/domain/translation/model/translationMessages";
7
7
  import { Logger, LoggerProvider } from "@lookiero/sty-psp-logging";
8
- import { EnvironmentStyleProvider } from "@lookiero/sty-psp-ui";
9
8
  import { BasePathProvider } from "../routing/useBasePath";
10
9
 
11
10
  interface RenderArgs {
@@ -28,9 +27,7 @@ const renderWrapper: RenderWrapperFunction =
28
27
  <IntlProvider locale={locale as string} messages={messages} onError={() => void 0}>
29
28
  <LoggerProvider logger={logger}>
30
29
  <BasePathProvider basePath="">
31
- <EnvironmentStyleProvider>
32
- <Wrapper>{children}</Wrapper>
33
- </EnvironmentStyleProvider>
30
+ <Wrapper>{children}</Wrapper>
34
31
  </BasePathProvider>
35
32
  </LoggerProvider>
36
33
  </IntlProvider>
@@ -1,12 +1,11 @@
1
1
  import { PortalProvider } from "@gorhom/portal";
2
2
  import React, { FC } from "react";
3
- import { StatusBar, View } from "react-native";
3
+ import { StatusBar } from "react-native";
4
4
  import { SafeAreaProvider } from "react-native-safe-area-context";
5
5
  import { PortalProvider as AuroraPortalProvider } from "@lookiero/aurora";
6
6
  import { Notifications } from "@lookiero/sty-psp-notifications";
7
- import { theme, useEnvironmentStyle } from "@lookiero/sty-psp-ui";
7
+ import { theme } from "@lookiero/sty-psp-ui";
8
8
  import { MESSAGING_CONTEXT_ID } from "../../delivery/baseBootstrap";
9
- import { style } from "./App.style";
10
9
 
11
10
  const { colorBgBase } = theme();
12
11
 
@@ -14,26 +13,20 @@ interface AppProps {
14
13
  readonly children: JSX.Element;
15
14
  }
16
15
 
17
- const App: FC<AppProps> = ({ children }) => {
18
- const { container } = useEnvironmentStyle();
16
+ const App: FC<AppProps> = ({ children }) => (
17
+ <SafeAreaProvider>
18
+ <PortalProvider>
19
+ <StatusBar backgroundColor={colorBgBase} barStyle="dark-content" translucent />
20
+ <Notifications contextId={MESSAGING_CONTEXT_ID} />
21
+ {/*
22
+ We are using the Aurora's PortalProvider at this level for notifications to work properly.
19
23
 
20
- return (
21
- <View style={[style.container, container]}>
22
- <SafeAreaProvider>
23
- <PortalProvider>
24
- <StatusBar backgroundColor={colorBgBase} barStyle="dark-content" translucent />
25
- <Notifications contextId={MESSAGING_CONTEXT_ID} />
26
- {/*
27
- We are using the Aurora's PortalProvider at this level for notifications to work properly.
28
-
29
- PaymentInstrumentSelect uses Aurora's Portal, and if we rely on UAF's Portal (injected by <Aurora>)
30
- notifications would be displayed in a layer below Portal's one (not visible).
31
- */}
32
- <AuroraPortalProvider>{children}</AuroraPortalProvider>
33
- </PortalProvider>
34
- </SafeAreaProvider>
35
- </View>
36
- );
37
- };
24
+ PaymentInstrumentSelect uses Aurora's Portal, and if we rely on UAF's Portal (injected by <Aurora>)
25
+ notifications would be displayed in a layer below Portal's one (not visible).
26
+ */}
27
+ <AuroraPortalProvider>{children}</AuroraPortalProvider>
28
+ </PortalProvider>
29
+ </SafeAreaProvider>
30
+ );
38
31
 
39
32
  export { App };
@@ -17,7 +17,7 @@ const style = StyleSheet.create({
17
17
  marginVertical: space8,
18
18
  width: "100%",
19
19
  },
20
- modal: {
20
+ modalContent: {
21
21
  paddingHorizontal: space6,
22
22
  },
23
23
  title: {
@@ -2,7 +2,7 @@ import React, { FC } from "react";
2
2
  import { View } from "react-native";
3
3
  import { ALIGN, Button, BUTTON_VARIANT, Text } from "@lookiero/aurora";
4
4
  import { useI18nMessage } from "@lookiero/i18n-react";
5
- import { Modal, useEnvironmentStyle } from "@lookiero/sty-psp-ui";
5
+ import { Modal } from "@lookiero/sty-psp-ui";
6
6
  import { I18nMessages } from "../../../../i18n/i18n";
7
7
  import { style } from "./GetOutOfCheckoutModal.style";
8
8
 
@@ -12,7 +12,6 @@ interface GetOutOfCheckoutModalProps {
12
12
  readonly onConfirm: () => void;
13
13
  }
14
14
  const GetOutOfCheckoutModal: FC<GetOutOfCheckoutModalProps> = ({ visible, onDismiss, onConfirm }) => {
15
- const { modal } = useEnvironmentStyle();
16
15
  const titleText = useI18nMessage({ id: I18nMessages.GET_OUT_OF_CHECKOUT_MODAL_TITLE });
17
16
  const descriptionText = useI18nMessage({ id: I18nMessages.GET_OUT_OF_CHECKOUT_MODAL_DESCRIPTION });
18
17
  const dismissButtonText = useI18nMessage({ id: I18nMessages.GET_OUT_OF_CHECKOUT_MODAL_DISMISS_BUTTON });
@@ -20,7 +19,7 @@ const GetOutOfCheckoutModal: FC<GetOutOfCheckoutModalProps> = ({ visible, onDism
20
19
 
21
20
  return (
22
21
  <Modal visible={visible} onClose={onDismiss}>
23
- <View style={[style.modal, modal?.content]}>
22
+ <View style={style.modalContent}>
24
23
  <Text align={ALIGN.CENTER} level={1} style={style.title}>
25
24
  {titleText}
26
25
  </Text>
@@ -76,6 +76,7 @@ exports[`GetOutOfCheckoutModal component matches the snapshot 1`] = `
76
76
  "zIndex": 1,
77
77
  }
78
78
  }
79
+ testID="modal-close-button"
79
80
  />
80
81
  <View
81
82
  pointerEvents="box-none"
@@ -132,6 +133,12 @@ exports[`GetOutOfCheckoutModal component matches the snapshot 1`] = `
132
133
  }
133
134
  >
134
135
  <View
136
+ contentInset={
137
+ {
138
+ "bottom": 0,
139
+ "top": 0,
140
+ }
141
+ }
135
142
  keyboardShouldPersistTaps="handled"
136
143
  showsVerticalScrollIndicator={false}
137
144
  >
@@ -144,12 +151,9 @@ exports[`GetOutOfCheckoutModal component matches the snapshot 1`] = `
144
151
  >
145
152
  <View
146
153
  style={
147
- [
148
- {
149
- "paddingHorizontal": 24,
150
- },
151
- undefined,
152
- ]
154
+ {
155
+ "paddingHorizontal": 24,
156
+ }
153
157
  }
154
158
  >
155
159
  <Text
@@ -21,7 +21,6 @@ interface ItemActionsProps {
21
21
  readonly onReplace: (value: string) => void;
22
22
  readonly onLayout?: ({ width, height }: LayoutRectangle) => void;
23
23
  }
24
-
25
24
  const ItemActions: FC<ItemActionsProps> = ({
26
25
  productVariants,
27
26
  currentProductVariant,
@@ -2,10 +2,8 @@ import React, { FC } from "react";
2
2
  import { View } from "react-native";
3
3
  import { ButtonIcon, Text } from "@lookiero/aurora";
4
4
  import { useI18nMessage } from "@lookiero/i18n-react";
5
- import {
6
- ReturnQuestionProjection,
7
- ReturnQuestionType,
8
- } from "../../../../../../projection/returnQuestion/returnQuestion";
5
+ import { ReturnQuestionProjection } from "../../../../../../projection/returnQuestion/returnQuestion";
6
+ import { ReturnQuestionType } from "../../../../../../projection/returnQuestion/returnQuestion.constants";
9
7
  import { ReturnQuestions } from "../../../../components/organisms/returnQuestions/ReturnQuestions";
10
8
  import {
11
9
  ReturnQuestionItemProvider,
@@ -4,7 +4,7 @@ import { theme } from "@lookiero/sty-psp-ui";
4
4
  const { borderWidth1, colorBorderInteractive, space1, space5, space6 } = theme();
5
5
 
6
6
  const style = StyleSheet.create({
7
- modal: {
7
+ modalContent: {
8
8
  paddingBottom: space6,
9
9
  paddingHorizontal: space6,
10
10
  },
@@ -1,11 +1,17 @@
1
1
  import React, { FC, useCallback } from "react";
2
- import { TouchableHighlight, View } from "react-native";
2
+ import { StyleProp, TextStyle, TouchableHighlight, View, ViewStyle } from "react-native";
3
3
  import { COLOR, Text } from "@lookiero/aurora";
4
- import { Modal, theme, useEnvironmentStyle } from "@lookiero/sty-psp-ui";
4
+ import { Modal, theme } from "@lookiero/sty-psp-ui";
5
5
  import { style } from "./SelectModal.style";
6
6
 
7
7
  const { colorBgPrimaryLight } = theme();
8
8
 
9
+ interface SelectModalStyle {
10
+ readonly modalContent: StyleProp<ViewStyle>;
11
+ readonly option: StyleProp<ViewStyle>;
12
+ readonly optionText: StyleProp<TextStyle>;
13
+ }
14
+
9
15
  interface Option {
10
16
  readonly label: string;
11
17
  readonly value: string;
@@ -15,22 +21,23 @@ interface SelectModalProps {
15
21
  readonly title?: string;
16
22
  readonly value: string | undefined;
17
23
  readonly options: Option[];
18
- readonly modalVisible: boolean;
19
- readonly testID?: string;
24
+ readonly style?: Partial<SelectModalStyle>;
20
25
  readonly onChange?: (value: string) => void;
21
26
  readonly onClose?: () => void;
27
+ readonly modalVisible: boolean;
28
+ readonly testID?: string;
22
29
  }
23
30
 
24
31
  const SelectModal: FC<SelectModalProps> = ({
25
32
  modalVisible,
33
+ onChange = () => void 0,
34
+ onClose = () => void 0,
26
35
  options,
36
+ style: customStyle,
27
37
  testID,
28
38
  title,
29
39
  value,
30
- onChange = () => void 0,
31
- onClose = () => void 0,
32
40
  }) => {
33
- const { modal } = useEnvironmentStyle();
34
41
  const handleOnPressOption = useCallback(
35
42
  (value: string) => {
36
43
  onChange(value);
@@ -41,7 +48,7 @@ const SelectModal: FC<SelectModalProps> = ({
41
48
 
42
49
  return (
43
50
  <Modal testID={testID} visible={modalVisible} scroll showCloseButton onClose={onClose}>
44
- <View style={[style.modal, modal?.content]}>
51
+ <View style={[style.modalContent, customStyle?.modalContent]}>
45
52
  {title && (
46
53
  <Text level={3} style={style.modalTitle} heading>
47
54
  {title}
@@ -52,13 +59,17 @@ const SelectModal: FC<SelectModalProps> = ({
52
59
  key={optionValue}
53
60
  accessibilityLabel={optionValue}
54
61
  disabled={value === optionValue}
55
- style={style.option}
62
+ style={[style.option, customStyle?.option]}
56
63
  testID={optionValue}
57
64
  underlayColor={colorBgPrimaryLight}
58
65
  accessible
59
66
  onPress={value !== optionValue ? () => handleOnPressOption(optionValue) : undefined}
60
67
  >
61
- <Text color={value === optionValue ? COLOR.TEXT_MEDIUM : COLOR.TEXT} level={3} style={style.optionText}>
68
+ <Text
69
+ color={value === optionValue ? COLOR.TEXT_MEDIUM : COLOR.TEXT}
70
+ level={3}
71
+ style={[style.optionText as ViewStyle, customStyle?.optionText]}
72
+ >
62
73
  {label}
63
74
  </Text>
64
75
  </TouchableHighlight>