@licklist/design 0.58.6-dev.9 → 0.58.6

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 (243) hide show
  1. package/bitbucket-pipelines.yml +8 -0
  2. package/dist/assets/iframe/calendar.svg +2 -2
  3. package/dist/assets/iframe/calendar.svg.js +1 -1
  4. package/dist/assets/iframe/ticket.svg +2 -2
  5. package/dist/assets/iframe/ticket.svg.js +1 -1
  6. package/dist/calendar/Calendar.d.ts +1 -1
  7. package/dist/calendar/Calendar.d.ts.map +1 -1
  8. package/dist/calendar/Calendar.js +1 -1
  9. package/dist/calendar/components/CalendarButtons/CalendarButtons.js +1 -1
  10. package/dist/calendar/components/CalendarDates/CalendarDates.d.ts +2 -2
  11. package/dist/calendar/components/CalendarDates/CalendarDates.d.ts.map +1 -1
  12. package/dist/calendar/components/CalendarDates/CalendarDates.js +1 -1
  13. package/dist/events/edit-event-modal/component/EditEventForm/EditEventForm.js +1 -1
  14. package/dist/events/event-statistic-modal/EventStatisticModal.js +1 -1
  15. package/dist/iframe/event/event-card/IframeEventCard.d.ts +1 -2
  16. package/dist/iframe/event/event-card/IframeEventCard.d.ts.map +1 -1
  17. package/dist/iframe/event/event-card/IframeEventCard.js +1 -1
  18. package/dist/iframe/event/event-venue-map/IframeEventVenueMap.js +1 -1
  19. package/dist/iframe/order-process/components/BookingSummary/BookingSummary.d.ts +2 -2
  20. package/dist/iframe/order-process/components/BookingSummary/BookingSummary.d.ts.map +1 -1
  21. package/dist/iframe/order-process/components/BookingSummary/BookingSummary.js +1 -1
  22. package/dist/iframe/order-process/components/BookingSummary/components/BookingSummaryAccordion/BookingSummaryAccordion.d.ts +2 -4
  23. package/dist/iframe/order-process/components/BookingSummary/components/BookingSummaryAccordion/BookingSummaryAccordion.d.ts.map +1 -1
  24. package/dist/iframe/order-process/components/BookingSummary/components/BookingSummaryAccordion/BookingSummaryAccordion.js +1 -1
  25. package/dist/iframe/order-process/components/BookingSummary/components/SummaryTotal/components/SummaryTotalBlock.d.ts +1 -1
  26. package/dist/iframe/order-process/components/BookingSummary/components/SummaryTotal/components/SummaryTotalBlock.d.ts.map +1 -1
  27. package/dist/iframe/order-process/components/BookingSummary/components/SummaryTotal/components/SummaryTotalBlock.js +1 -1
  28. package/dist/iframe/order-process/components/BookingSummary/components/ToggleHeader/ToggleHeader.d.ts +2 -4
  29. package/dist/iframe/order-process/components/BookingSummary/components/ToggleHeader/ToggleHeader.d.ts.map +1 -1
  30. package/dist/iframe/order-process/components/BookingSummary/components/ToggleHeader/ToggleHeader.js +1 -1
  31. package/dist/iframe/order-process/components/BookingSummary/types/index.d.ts +0 -4
  32. package/dist/iframe/order-process/components/BookingSummary/types/index.d.ts.map +1 -1
  33. package/dist/iframe/order-process/components/CalendarStepsForm/CalendarStepsForm.js +1 -1
  34. package/dist/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.js +1 -1
  35. package/dist/iframe/page/components/PageBody/components/LeftBlock/LeftBlock.d.ts.map +1 -1
  36. package/dist/iframe/page/components/PageBody/components/LeftBlock/LeftBlock.js +1 -1
  37. package/dist/iframe/page/components/PageBody/constants.d.ts +0 -1
  38. package/dist/iframe/page/components/PageBody/constants.d.ts.map +1 -1
  39. package/dist/iframe/page/components/PageBody/constants.js +1 -1
  40. package/dist/iframe/page/components/PageBody/hooks/useResizePageBody.d.ts.map +1 -1
  41. package/dist/iframe/page/components/PageBody/hooks/useResizePageBody.js +1 -1
  42. package/dist/iframe/payment/order-items-table/OrderItemsTable.js +1 -1
  43. package/dist/iframe/payment/order-items-table/utils/paymentSummary.js +1 -1
  44. package/dist/iframe/payment/payment-form/PaymentForm.js +1 -1
  45. package/dist/iframe/payment/payment-page/PaymentPage.d.ts.map +1 -1
  46. package/dist/iframe/payment/payment-page/PaymentPage.js +1 -1
  47. package/dist/iframe/payment/payment-page/PaymentTimer.js +1 -1
  48. package/dist/iframe/payment/payment-status-page/PaymentStatusPage.js +1 -1
  49. package/dist/iframe/ryft/RyftPaymentForm.d.ts.map +1 -1
  50. package/dist/iframe/ryft/RyftPaymentForm.js +1 -1
  51. package/dist/index.js +1 -1
  52. package/dist/product-set/card/ProductSetCard.d.ts +1 -2
  53. package/dist/product-set/card/ProductSetCard.d.ts.map +1 -1
  54. package/dist/product-set/card/ProductSetCard.js +1 -1
  55. package/dist/product-set/control/ProductSetControl.d.ts +1 -2
  56. package/dist/product-set/control/ProductSetControl.d.ts.map +1 -1
  57. package/dist/product-set/control/ProductSetControl.js +1 -1
  58. package/dist/product-set/control/TutorialGifCard.d.ts +1 -2
  59. package/dist/product-set/control/TutorialGifCard.d.ts.map +1 -1
  60. package/dist/product-set/control/TutorialGifCard.js +1 -1
  61. package/dist/product-set/form/ProductCategoriesControl.d.ts +1 -2
  62. package/dist/product-set/form/ProductCategoriesControl.d.ts.map +1 -1
  63. package/dist/product-set/form/ProductCategoriesControl.js +1 -1
  64. package/dist/product-set/form/ProductSetForm.d.ts +2 -7
  65. package/dist/product-set/form/ProductSetForm.d.ts.map +1 -1
  66. package/dist/product-set/form/ProductSetForm.js +1 -1
  67. package/dist/product-set/form/ProductsControl.d.ts +1 -2
  68. package/dist/product-set/form/ProductsControl.d.ts.map +1 -1
  69. package/dist/product-set/form/ProductsControl.js +1 -1
  70. package/dist/product-set/form/StepsControl.d.ts +1 -2
  71. package/dist/product-set/form/StepsControl.d.ts.map +1 -1
  72. package/dist/product-set/form/StepsControl.js +1 -1
  73. package/dist/product-set/form/SubProductsControl.d.ts +1 -2
  74. package/dist/product-set/form/SubProductsControl.d.ts.map +1 -1
  75. package/dist/product-set/form/SubProductsControl.js +1 -1
  76. package/dist/product-set/form/VenueMapsControl.js +1 -1
  77. package/dist/product-set/hooks/useSortableTreeFunctions.d.ts +1 -2
  78. package/dist/product-set/hooks/useSortableTreeFunctions.d.ts.map +1 -1
  79. package/dist/product-set/hooks/useSortableTreeFunctions.js +1 -1
  80. package/dist/product-set/item/CreateProductSetItem.d.ts +1 -2
  81. package/dist/product-set/item/CreateProductSetItem.d.ts.map +1 -1
  82. package/dist/product-set/item/CreateProductSetItem.js +1 -1
  83. package/dist/product-set/product/ProductControl.d.ts +1 -3
  84. package/dist/product-set/product/ProductControl.d.ts.map +1 -1
  85. package/dist/product-set/product/ProductControl.js +1 -1
  86. package/dist/product-set/product/fixed-duration-fields/FixedDurationOptions.d.ts +2 -4
  87. package/dist/product-set/product/fixed-duration-fields/FixedDurationOptions.d.ts.map +1 -1
  88. package/dist/product-set/product/fixed-duration-fields/FixedDurationOptions.js +1 -1
  89. package/dist/product-set/product/quantity/ProductQuantityControl.d.ts +0 -1
  90. package/dist/product-set/product/quantity/ProductQuantityControl.d.ts.map +1 -1
  91. package/dist/product-set/product/quantity/ProductQuantityControl.js +1 -1
  92. package/dist/product-set/product-category/ProductCategoryControl.d.ts +1 -3
  93. package/dist/product-set/product-category/ProductCategoryControl.d.ts.map +1 -1
  94. package/dist/product-set/product-category/ProductCategoryControl.js +1 -1
  95. package/dist/provider/working-hours-input/WorkingHoursInputDescription.d.ts.map +1 -1
  96. package/dist/provider/working-hours-input/WorkingHoursInputDescription.js +1 -1
  97. package/dist/recurring-date-picker-input/RecurringDatePickerInput.d.ts +0 -2
  98. package/dist/recurring-date-picker-input/RecurringDatePickerInput.d.ts.map +1 -1
  99. package/dist/recurring-date-picker-input/RecurringDatePickerInput.js +1 -1
  100. package/dist/sales/booking/results/components/ResultCard.d.ts.map +1 -1
  101. package/dist/sales/booking/results/components/ResultCard.js +1 -1
  102. package/dist/sales/notes/NotesTableRow.js +1 -1
  103. package/dist/setting/dashboard/snippets/card/SnippetCard.js +1 -1
  104. package/dist/snippet/snippet-template/control/PropertyControl.d.ts +1 -3
  105. package/dist/snippet/snippet-template/control/PropertyControl.d.ts.map +1 -1
  106. package/dist/snippet/snippet-template/control/PropertyControl.js +1 -1
  107. package/dist/snippet/snippet-template/preview/Preview.js +1 -1
  108. package/dist/sortable-list/SortableList.d.ts +1 -2
  109. package/dist/sortable-list/SortableList.d.ts.map +1 -1
  110. package/dist/sortable-list/SortableList.js +1 -1
  111. package/dist/sortable-tree/SortableTreeItem.d.ts +1 -3
  112. package/dist/sortable-tree/SortableTreeItem.d.ts.map +1 -1
  113. package/dist/sortable-tree/SortableTreeItem.js +1 -1
  114. package/dist/static/manual-date-picker/ManualDatePicker.js +1 -1
  115. package/dist/static/manual-date-picker/constants/index.d.ts +1 -4
  116. package/dist/static/manual-date-picker/constants/index.d.ts.map +1 -1
  117. package/dist/static/manual-date-picker/constants/index.js +1 -1
  118. package/dist/static/manual-date-picker/utils/index.d.ts +0 -4
  119. package/dist/static/manual-date-picker/utils/index.d.ts.map +1 -1
  120. package/dist/static/manual-date-picker/utils/index.js +1 -1
  121. package/dist/striped-static-table/StripedStaticTable.js +1 -1
  122. package/dist/styles/iframe-events/Card.scss +8 -24
  123. package/dist/styles/iframe-events/PoweredBy.scss +2 -2
  124. package/dist/styles/iframe-order-process/IframeOrderProcess.scss +20 -57
  125. package/dist/styles/iframe-page/Page.scss +0 -1
  126. package/dist/styles/iframe-page/PageBody.scss +12 -34
  127. package/dist/styles/iframe-page/PageHeader.scss +39 -41
  128. package/dist/styles/product-set/EditVenueMapSetModal.scss +1 -1
  129. package/dist/styles/ryft-payment-form/RyftPaymentForm.scss +2 -125
  130. package/dist/styles/sales/BookingResults.scss +1 -1
  131. package/dist/venue-map-sets/form/components/VenueMapImageControl.js +1 -1
  132. package/jest.config.js +29 -0
  133. package/package.json +35 -10
  134. package/src/assets/iframe/calendar.svg +2 -2
  135. package/src/assets/iframe/ticket.svg +2 -2
  136. package/src/calendar/Calendar.stories.tsx +0 -23
  137. package/src/calendar/Calendar.tsx +5 -5
  138. package/src/calendar/components/CalendarDates/CalendarDates.tsx +5 -0
  139. package/src/iframe/event/event-card/IframeEventCard.stories.tsx +0 -1
  140. package/src/iframe/event/event-card/IframeEventCard.tsx +8 -7
  141. package/src/iframe/order-process/components/BookingSummary/BookingSummary.stories.tsx +0 -9
  142. package/src/iframe/order-process/components/BookingSummary/BookingSummary.tsx +7 -58
  143. package/src/iframe/order-process/components/BookingSummary/components/BookingSummaryAccordion/BookingSummaryAccordion.tsx +0 -8
  144. package/src/iframe/order-process/components/BookingSummary/components/SummaryTotal/components/SummaryTotalBlock.tsx +4 -4
  145. package/src/iframe/order-process/components/BookingSummary/components/ToggleHeader/ToggleHeader.tsx +10 -63
  146. package/src/iframe/order-process/components/BookingSummary/types/index.ts +0 -4
  147. package/src/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.tsx +1 -1
  148. package/src/iframe/page/components/PageBody/components/LeftBlock/LeftBlock.tsx +1 -3
  149. package/src/iframe/page/components/PageBody/constants.ts +0 -2
  150. package/src/iframe/page/components/PageBody/hooks/useResizePageBody.ts +0 -10
  151. package/src/iframe/payment/order-items-table/utils/paymentSummary.tsx +6 -6
  152. package/src/iframe/payment/payment-page/PaymentPage.stories.tsx +6 -546
  153. package/src/iframe/payment/payment-page/PaymentPage.tsx +29 -38
  154. package/src/iframe/ryft/RyftPaymentForm.tsx +5 -11
  155. package/src/product-set/card/ProductSetCard.tsx +1 -12
  156. package/src/product-set/control/ProductSetControl.tsx +24 -46
  157. package/src/product-set/control/TutorialGifCard.tsx +3 -11
  158. package/src/product-set/form/ProductCategoriesControl.tsx +1 -12
  159. package/src/product-set/form/ProductSetForm.tsx +1 -10
  160. package/src/product-set/form/ProductsControl.tsx +0 -10
  161. package/src/product-set/form/StepsControl.tsx +2 -8
  162. package/src/product-set/form/SubProductsControl.tsx +0 -3
  163. package/src/product-set/hooks/useSortableTreeFunctions.ts +0 -6
  164. package/src/product-set/item/CreateProductSetItem.tsx +0 -3
  165. package/src/product-set/product/ProductControl.tsx +15 -48
  166. package/src/product-set/product/fixed-duration-fields/FixedDurationOptions.tsx +2 -8
  167. package/src/product-set/product/quantity/ProductQuantityControl.tsx +3 -4
  168. package/src/product-set/product-category/ProductCategoryControl.tsx +50 -116
  169. package/src/provider/working-hours-input/WorkingHoursInputDescription.tsx +18 -4
  170. package/src/recurring-date-picker-input/RecurringDatePickerInput.tsx +1 -4
  171. package/src/sales/booking/results/BookingResults.stories.tsx +2 -3
  172. package/src/sales/booking/results/components/ResultCard.tsx +5 -2
  173. package/src/snippet/snippet-template/control/PropertyControl.tsx +2 -6
  174. package/src/sortable-list/SortableList.tsx +0 -3
  175. package/src/sortable-tree/SortableTreeItem.tsx +0 -6
  176. package/src/static/manual-date-picker/ManualDatePicker.tsx +3 -3
  177. package/src/static/manual-date-picker/constants/index.ts +2 -6
  178. package/src/static/manual-date-picker/utils/index.ts +0 -11
  179. package/src/static/switch/BooleanSwitch.tsx +1 -1
  180. package/src/styles/iframe-events/Card.scss +8 -24
  181. package/src/styles/iframe-events/PoweredBy.scss +2 -2
  182. package/src/styles/iframe-order-process/IframeOrderProcess.scss +20 -57
  183. package/src/styles/iframe-page/Page.scss +0 -1
  184. package/src/styles/iframe-page/PageBody.scss +12 -34
  185. package/src/styles/iframe-page/PageHeader.scss +39 -41
  186. package/src/styles/product-set/EditVenueMapSetModal.scss +1 -1
  187. package/src/styles/ryft-payment-form/RyftPaymentForm.scss +2 -125
  188. package/src/styles/sales/BookingResults.scss +1 -1
  189. package/tests/Auth/Authorizer.test.tsx +194 -0
  190. package/tests/Auth/Layout/UserNavDropDown.test.tsx +43 -0
  191. package/tests/Auth/Layout/UserNavDropDownToggle.test.tsx +33 -0
  192. package/tests/Auth/Login/LoginComponent.test.tsx +246 -0
  193. package/tests/Auth/Login/LoginFormComponent.test.tsx +182 -0
  194. package/tests/Auth/Register/RegisterComponent.test.tsx +285 -0
  195. package/tests/Auth/Register/RegisterFormComponent.test.tsx +170 -0
  196. package/tests/Auth/Settings/Dashboard/IpInput.test.tsx +130 -0
  197. package/tests/Auth/Social/SocialCallbackComponent.test.tsx +133 -0
  198. package/tests/Auth/Social/SocialFormComponent.test.tsx +118 -0
  199. package/tests/FileUpload/FileUpload.test.tsx +42 -0
  200. package/tests/Notification/EmailTemplate.test.tsx +82 -0
  201. package/tests/ProductSet/ProductSetPopover.test.tsx +40 -0
  202. package/tests/Report/Report.test.tsx +48 -0
  203. package/tests/Sales/Coupon.test.tsx +51 -0
  204. package/tests/Sales/SalesAndVIews.test.tsx +63 -0
  205. package/tests/SnippetTemplates/SnippetTemplates.test.tsx +56 -0
  206. package/tests/Table/FilterHelperComponent.test.tsx +88 -0
  207. package/tests/Table/PaginationHelperComponent.test.tsx +109 -0
  208. package/tests/Table/PerPageHelperComponent.test.tsx +34 -0
  209. package/tests/Table/TableHelperComponent.test.tsx +295 -0
  210. package/tests/TipTapEditor/TipTapEditor.test.tsx +28 -0
  211. package/tests/__mock__/hooks/useAuthApi.ts +13 -0
  212. package/tests/__mock__/hooks/useAuthMock.ts +13 -0
  213. package/tests/__mock__/hooks/useFormMock.ts +27 -0
  214. package/tests/__mock__/hooks/useNotificationMock.ts +13 -0
  215. package/tests/__mock__/hooks/useQueryMock.ts +16 -0
  216. package/tests/__mock__/hooks/useSocialApiMock.ts +20 -0
  217. package/tests/__mock__/hooks/useTranslationMock.ts +17 -0
  218. package/tests/__mock__/hooks/useUserApiMock.ts +18 -0
  219. package/tests/__mock__/hooks/useUserMock.ts +13 -0
  220. package/tests/__mock__/styleMock.js +1 -0
  221. package/tests/__mock__/windowMock.ts +5 -0
  222. package/tests/packages/react-query.tsx +28 -0
  223. package/tests/setupTests.ts +10 -0
  224. package/dist/iframe/ryft/utils/ryft-form.d.ts +0 -5
  225. package/dist/iframe/ryft/utils/ryft-form.d.ts.map +0 -1
  226. package/dist/iframe/ryft/utils/ryft-form.js +0 -1
  227. package/dist/product-set/control/DateInput.d.ts +0 -17
  228. package/dist/product-set/control/DateInput.d.ts.map +0 -1
  229. package/dist/product-set/control/DateInput.js +0 -1
  230. package/dist/product-set/control/ProductSetRecurrenceOverridesControl.d.ts +0 -11
  231. package/dist/product-set/control/ProductSetRecurrenceOverridesControl.d.ts.map +0 -1
  232. package/dist/product-set/control/ProductSetRecurrenceOverridesControl.js +0 -1
  233. package/dist/recurring-date-picker-input/DatePickerInput.d.ts +0 -19
  234. package/dist/recurring-date-picker-input/DatePickerInput.d.ts.map +0 -1
  235. package/dist/recurring-date-picker-input/DatePickerInput.js +0 -1
  236. package/dist/recurring-date-picker-input/RecurrenceAndFrequencyInput.d.ts +0 -15
  237. package/dist/recurring-date-picker-input/RecurrenceAndFrequencyInput.d.ts.map +0 -1
  238. package/dist/recurring-date-picker-input/RecurrenceAndFrequencyInput.js +0 -1
  239. package/src/iframe/ryft/utils/ryft-form.ts +0 -47
  240. package/src/product-set/control/DateInput.tsx +0 -313
  241. package/src/product-set/control/ProductSetRecurrenceOverridesControl.tsx +0 -63
  242. package/src/recurring-date-picker-input/DatePickerInput.tsx +0 -93
  243. package/src/recurring-date-picker-input/RecurrenceAndFrequencyInput.tsx +0 -136
@@ -0,0 +1,27 @@
1
+ import * as hook from "react-hook-form";
2
+
3
+ /**
4
+ * Mocks custom hook
5
+ * @param mockReturn
6
+ */
7
+ const useFormMock = (mockReturn: any = {}) => {
8
+ const mock = hook as jest.Mocked<typeof hook>;
9
+
10
+ return mock.useForm.mockReturnValue({
11
+ register: jest.fn(),
12
+ handleSubmit: jest.fn(),
13
+ formState: {
14
+ dirtyFields: {
15
+ has: jest.fn(),
16
+ },
17
+ errors: jest.fn(),
18
+ },
19
+ setValue: jest.fn(),
20
+ getValues: jest.fn(),
21
+ control: jest.fn(),
22
+ watch: jest.fn(),
23
+ ...mockReturn,
24
+ });
25
+ };
26
+
27
+ export default useFormMock;
@@ -0,0 +1,13 @@
1
+ import * as hook from "@licklist/plugins/dist/context/app/hooks/useNotification";
2
+
3
+ /**
4
+ * Mocks custom hook
5
+ * @param mockReturn
6
+ */
7
+ const useNotificationMock = (mockReturn: any = null) => {
8
+ const mock = hook as jest.Mocked<typeof hook>;
9
+
10
+ return mock.default.mockImplementation(() => mockReturn);
11
+ };
12
+
13
+ export default useNotificationMock;
@@ -0,0 +1,16 @@
1
+ import * as useUserHook from "@licklist/plugins/dist/hooks/Query/useQuery";
2
+
3
+ /**
4
+ * Mocks custom hook
5
+ * @param mockReturn
6
+ */
7
+ const useQueryMock = (mockReturn: any = {}) => {
8
+ const useUserHookMock = useUserHook as jest.Mocked<typeof useUserHook>;
9
+
10
+ return useUserHookMock.default.mockReturnValue({
11
+ get: (key) => key,
12
+ ...mockReturn,
13
+ });
14
+ };
15
+
16
+ export default useQueryMock;
@@ -0,0 +1,20 @@
1
+ import * as hook from "@licklist/plugins/dist/hooks/Api/useSocialApi";
2
+
3
+ /**
4
+ * Mocks custom hook
5
+ * @param mockReturn
6
+ */
7
+ const useSocialApiMock = (mockReturn: any = {}) => {
8
+ const mock = hook as jest.Mocked<typeof hook>;
9
+
10
+ return mock.default.mockReturnValue({
11
+ getSocialProvider: jest.fn(),
12
+ redirectToProvider: jest.fn(),
13
+ registerFacebookCallback: jest.fn(),
14
+ registerTwitterCallback: jest.fn(),
15
+ registerCallback: jest.fn(),
16
+ ...mockReturn,
17
+ });
18
+ };
19
+
20
+ export default useSocialApiMock;
@@ -0,0 +1,17 @@
1
+ import * as hook from "react-i18next";
2
+
3
+ /**
4
+ * Mocks custom hook
5
+ * @param mockReturn
6
+ */
7
+ const useTranslationMock = (mockReturn: any = null) => {
8
+ const hookMock = hook as jest.Mocked<typeof hook>;
9
+
10
+ return hookMock.useTranslation.mockReturnValue(
11
+ mockReturn || {
12
+ t: jest.fn().mockReturnValue("test"),
13
+ }
14
+ );
15
+ };
16
+
17
+ export default useTranslationMock;
@@ -0,0 +1,18 @@
1
+ import * as hook from "@licklist/plugins/dist/hooks/Api/useUserApi";
2
+
3
+ /**
4
+ * Mocks custom hook
5
+ * @param mockReturn
6
+ */
7
+ const useUserApiMock = (mockReturn: any = {}) => {
8
+ const mock = hook as jest.Mocked<typeof hook>;
9
+
10
+ return mock.default.mockReturnValue({
11
+ profile: jest.fn(),
12
+ login: jest.fn(),
13
+ setAuthorizationToken: jest.fn(),
14
+ ...mockReturn,
15
+ });
16
+ };
17
+
18
+ export default useUserApiMock;
@@ -0,0 +1,13 @@
1
+ import * as useUserHook from "@licklist/plugins/dist/context/user/hooks/useUser";
2
+
3
+ /**
4
+ * Mocks custom hook
5
+ * @param mockReturn
6
+ */
7
+ const useUserMock = (mockReturn: any = null) => {
8
+ const useUserHookMock = useUserHook as jest.Mocked<typeof useUserHook>;
9
+
10
+ return useUserHookMock.default.mockReturnValue(mockReturn);
11
+ };
12
+
13
+ export default useUserMock;
@@ -0,0 +1 @@
1
+ module.exports = {};
@@ -0,0 +1,5 @@
1
+ const mockWindow = () => {
2
+ (global as any).window = Object.create(window);
3
+ };
4
+
5
+ export default mockWindow;
@@ -0,0 +1,28 @@
1
+ import { PropsWithChildren } from "react";
2
+ import * as React from "react";
3
+ import { QueryClient, QueryClientProvider, setLogger } from "react-query";
4
+
5
+ const queryClient = new QueryClient({
6
+ defaultOptions: {
7
+ queries: {
8
+ // ✅ turns retries off
9
+ retry: false,
10
+ cacheTime: 0,
11
+ },
12
+ },
13
+ });
14
+
15
+ setLogger({
16
+ // eslint-disable-next-line no-console
17
+ log: console.log,
18
+ // eslint-disable-next-line no-console
19
+ warn: console.warn,
20
+ // ✅ no more errors on the console
21
+ error: () => undefined,
22
+ });
23
+
24
+ const wrapper = ({ children }: PropsWithChildren<unknown>) => (
25
+ <QueryClientProvider client={queryClient}>{children}</QueryClientProvider>
26
+ );
27
+
28
+ export { queryClient, wrapper };
@@ -0,0 +1,10 @@
1
+ // jest-dom adds custom jest matchers for asserting on DOM nodes.
2
+ // allows you to do things like:
3
+ // expect(element).toHaveTextContent(/react/i)
4
+ // learn more: https://github.com/testing-library/jest-dom
5
+ import "@testing-library/jest-dom";
6
+ import "@testing-library/jest-dom/extend-expect";
7
+ import { configure } from "enzyme";
8
+ import React16Adapter from "enzyme-adapter-react-16";
9
+
10
+ configure({ adapter: new React16Adapter() });
@@ -1,5 +0,0 @@
1
- import { TFunction } from "react-i18next";
2
- export declare const injectComponentsInRyftForm: ({ t, }: {
3
- t: TFunction<string[]>;
4
- }) => void;
5
- //# sourceMappingURL=ryft-form.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ryft-form.d.ts","sourceRoot":"","sources":["../../../../src/iframe/ryft/utils/ryft-form.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1C,eAAO,MAAM,0BAA0B;OAGlC,UAAU,MAAM,EAAE,CAAC;UAyCvB,CAAC"}
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});exports.injectComponentsInRyftForm=function(e){var t=e.t,n=document.getElementById("ryft-pay-iframe"),i=document.getElementById("card-title-container");if(n&&!i){var r=document.createElement("div"),d=document.createElement("div"),a=document.createElement("div");a.id="card-title-container",r.textContent=t("Design:enterCardDetails"),d.className="bold-text form-label",d.innerText=t("Design:paymentDetails"),a.append(r,d),null==n||n.before(a);var o=document.getElementById("ryft-pay-grid");if(o){var m=document.createElement("div"),c=document.createElement("div"),l=document.createElement("div"),s=document.createElement("div");m.className="mobile-pay-title",m.innerText=t("Design:expressCheckoutWith"),c.id="mobile-pay-divider-text",c.innerText="or",l.id="mobile-pay-divider",s.id="mobile-pay-divider-container",s.append(c,l),o.before(m),o.after(s)}}};
@@ -1,17 +0,0 @@
1
- /// <reference types="react" />
2
- import { Modifier } from "@popperjs/core";
3
- import { ProductSetRecurrence } from "@licklist/core/dist/DataMapper/Product/ProductSetRecurrenceDataMapper";
4
- import { WorkHour } from "@licklist/core/dist/DataMapper/Provider/WorkHourDataMapper";
5
- export interface DateAndRecurrenceInputValues {
6
- menuRecurrences?: Partial<ProductSetRecurrence>[];
7
- }
8
- interface DateAndRecurrenceInputProps {
9
- isEventEditProductSet?: boolean;
10
- workHours?: WorkHour[];
11
- providerHasBookingManagement: boolean;
12
- isLoading?: boolean;
13
- }
14
- export declare const DateInput: ({ isEventEditProductSet, isLoading, workHours, providerHasBookingManagement, }: DateAndRecurrenceInputProps) => JSX.Element;
15
- export declare const sameWidthPopperModifier: Modifier<"sameWidth", Record<string, unknown>>;
16
- export {};
17
- //# sourceMappingURL=DateInput.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"DateInput.d.ts","sourceRoot":"","sources":["../../../src/product-set/control/DateInput.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAO1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,uEAAuE,CAAC;AAG7G,OAAO,EAAE,QAAQ,EAAE,MAAM,4DAA4D,CAAC;AAgBtF,MAAM,WAAW,4BAA4B;IAC3C,eAAe,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC,EAAE,CAAC;CACnD;AAED,UAAU,2BAA2B;IACnC,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC;IACvB,4BAA4B,EAAE,OAAO,CAAC;IACtC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,SAAS,mFAKnB,2BAA2B,gBAmP7B,CAAC;AAEF,eAAO,MAAM,uBAAuB,EAAE,QAAQ,CAC5C,WAAW,EACX,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAsBxB,CAAC"}
@@ -1 +0,0 @@
1
- "use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var r=require("tslib"),t=require("react"),n=e(t),i=require("react-i18next"),a=require("react-bootstrap"),u=require("../../static/Icon.js"),o=require("react-hook-form"),l=require("@react-aria/utils"),s=require("react-use"),c=require("luxon");require("../../static/index.js");var d=require("../../modals/confirmation/ConfirmModal.js"),m=require("rrule"),v=e(m),f=require("@licklist/core/dist/Config/Date"),p=require("../../recurring-date-picker-input/RecurringDatePickerInput.js"),g=require("../../zone/form/components/AvailableTimesControl.js"),T=require("../../recurring-date-picker-input/DatePickerInput.js"),b=require("./ProductSetRecurrenceOverridesControl.js"),E={name:"sameWidth",enabled:!0,phase:"beforeWrite",requires:["computeStyles"],fn:function(e){var r=e.state,t={width:"".concat(r.rects.reference.width+4,"px"),marginLeft:"-2px",maxWidth:"unset"};Object.assign(r.styles.popper,t)},effect:function(e){var r=e.state,t=r.elements.reference.getBoundingClientRect().width,n={width:"".concat(t,"px"),maxWidth:"unset"};Object.assign(r.elements.popper.style,n)}};exports.DateInput=function(e){var x,D,q,R,h=e.isEventEditProductSet,_=e.isLoading,y=e.workHours,I=e.providerHasBookingManagement,M=o.useFormContext(),O=M.control,k=M.register,w=M.formState.errors,C=M.getValues,S=M.setValue,F=M.clearErrors,j=o.useFieldArray({name:"menuRecurrences",control:O,keyName:"_id"}),A=j.fields,N=j.append,P=j.update,V=r.__read(t.useState(!1),2),L=V[0],W=V[1],B=t.useRef(),H=r.__read(t.useState({index:null,values:null}),2),z=H[0],G=H[1],J=function(){return G({index:null,values:null})},K=t.useRef();s.useClickAway(K,(function(e){var r,t,n;d.CONFIRM_MODAL_ACTIONS.includes(null===(n=null===(t=null===(r=e.target)||void 0===r?void 0:r.attributes)||void 0===t?void 0:t.getNamedItem("data-id"))||void 0===n?void 0:n.value)||(W(!1),J())}));var U=l.useId(),Y=i.useTranslation("Design").t,Z=function(){A.length>=1||(J(),W((function(e){return!e})))};return n.createElement(a.Form.Group,null,n.createElement(a.Form.Label,null,Y(h?"whenOverridesAvailable":"productSetAvailable")),n.createElement(a.OverlayTrigger,{show:L,overlay:n.createElement(a.Popover,{id:U,className:"rounded"},n.createElement(a.Popover.Content,{className:"shadow-lg rounded",ref:K},n.createElement(T.DatePickerInput,{defaultValues:z.values,onChange:function(e){return r.__awaiter(void 0,void 0,void 0,(function(){var t,n,i,a,u,o,l,s,d,g,T,b,E;return r.__generator(this,(function(r){switch(r.label){case 0:return[4,null===(d=B.current)||void 0===d?void 0:d.trigger()];case 1:return t=r.sent(),(null==e?void 0:e.startTime)&&(null==e?void 0:e.endTime)&&t&&(n=c.DateTime.fromISO(e.startTime),i=c.DateTime.fromISO(e.endTime),a=B.current.getValues().availableTimes,!a.every((function(e){var r=c.DateTime.fromFormat(e,f.TIME_FORMAT);return r.diff(n,"minutes").minutes>=0&&r.diff(i,"minutes").minutes<=0})))?(B.current.setError("availableTimes",{message:Y("Validation:fieldTimeBetween",{attribute:Y("Design:startTimesSmall"),min:n.toFormat(f.TIME_FORMAT),max:i.toFormat(f.TIME_FORMAT)})}),[2]):(u=p.getDateTimeObject(e.startDate,e.endTime||"23:59:59"),o=v.optionsToString({until:u.toJSDate(),byweekday:[],freq:m.Frequency.DAILY,tzid:f.TIMEZONE,interval:1}).replace("RRULE:",""),l=(null===(T=null===(g=null==B?void 0:B.current)||void 0===g?void 0:g.getValues())||void 0===T?void 0:T.availableTimes)||null,s={rrule:o,startDate:e.startDate,endDate:e.startDate,startTime:e.startTime,endTime:e.endTime,availableTimes:l},(null===(b=z.values)||void 0===b?void 0:b.id)&&(s.id=null===(E=z.values)||void 0===E?void 0:E.id),null!==z.index?P(z.index,s):N(s),W((function(){return!1})),J(),[2])}}))}))},onDelete:function(){var e=z.index;W(!1),J(),setTimeout((function(){var r=C().menuRecurrences;S("menuRecurrences",(void 0===r?[]:r).filter((function(r,t){return t!==e})))}),100)}},I&&n.createElement(g.AvailableTimesControl,{workHours:y,isLoading:_,ref:B,defaultValues:[],errorMessage:null===(q=null===(D=null===(x=null==w?void 0:w.menuRecurrences)||void 0===x?void 0:x["".concat(null==z?void 0:z.index)])||void 0===D?void 0:D.availableTimes)||void 0===q?void 0:q.message,clearErrorMessage:function(){return F("menuRecurrences.".concat(null==z?void 0:z.index,".availableTimes"))}})))),trigger:"click",placement:"bottom",popperConfig:{modifiers:[E]}},n.createElement("div",{className:"product-set-recurrences"},A.map((function(e,r){var t,i,a;return n.createElement(b.ProductSetRecurrenceOverridesControl,{key:e._id,menuRecurrence:e,onEdit:function(){return function(e,r){J(),setTimeout((function(){G({index:r,values:e}),W((function(){return!0}))}),100)}(e,r)},errorMessage:null===(a=null===(i=null===(t=null==w?void 0:w.menuRecurrences)||void 0===t?void 0:t["".concat(r)])||void 0===i?void 0:i.availableTimes)||void 0===a?void 0:a.message})})),n.createElement("div",{className:"product-set-recurrence-icon-wrapper",role:"button",tabIndex:0,onClick:Z,onKeyDown:Z},n.createElement(u.default,{type:"plus-circle",height:"1rem",className:"product-set-recurrence-icon-add mr-2"}),Y("addDates")),n.createElement(a.Form.Control,r.__assign({type:"hidden"},k("menuRecurrences",{required:{value:!0,message:Y("Validation:fieldMinNumber",{attribute:Y("dates"),min:1})}}))),n.createElement("div",{className:"manual-form-error"},null===(R=w.menuRecurrences)||void 0===R?void 0:R.message))))},exports.sameWidthPopperModifier=E;
@@ -1,11 +0,0 @@
1
- /// <reference types="react" />
2
- import { ProductSetRecurrence } from "@licklist/core/dist/DataMapper/Product/ProductSetRecurrenceDataMapper";
3
- export interface ProductSetRecurrenceControlProps {
4
- menuRecurrence?: {
5
- _id: string;
6
- } & Partial<ProductSetRecurrence>;
7
- onEdit?: (onEdit: Partial<ProductSetRecurrence>) => void;
8
- errorMessage?: string;
9
- }
10
- export declare const ProductSetRecurrenceOverridesControl: ({ menuRecurrence, onEdit, errorMessage, }: ProductSetRecurrenceControlProps) => JSX.Element;
11
- //# sourceMappingURL=ProductSetRecurrenceOverridesControl.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ProductSetRecurrenceOverridesControl.d.ts","sourceRoot":"","sources":["../../../src/product-set/control/ProductSetRecurrenceOverridesControl.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,uEAAuE,CAAC;AAI7G,MAAM,WAAW,gCAAgC;IAC/C,cAAc,CAAC,EAAE;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC;IACjE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,oBAAoB,CAAC,KAAK,IAAI,CAAC;IACzD,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,eAAO,MAAM,oCAAoC,8CAI9C,gCAAgC,gBA8ClC,CAAC"}
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e,r=require("react"),t=(e=r)&&"object"==typeof e&&"default"in e?e.default:e,a=require("../../static/Icon.js");require("../../static/index.js");var c=require("react-intl");exports.ProductSetRecurrenceOverridesControl=function(e){var r=e.menuRecurrence,n=e.onEdit,l=e.errorMessage,s=c.useIntl().formatDate;return t.createElement("div",{className:"sortable-tree-root flex-column",role:"button",tabIndex:0},t.createElement("div",{key:r.rrule,className:"product-set-recurrence d-flex flex-column mr-0 mb-3 p-3 px-4 flex-grow-1"},t.createElement("span",{className:"d-flex flex-row align-items-center"},t.createElement(a.default,{type:"calendar",height:"1rem",className:"product-set-recurrence-icon-calendar"}),t.createElement("span",{className:"product-set-recurrence-title d-flex flex-grow-1"},s(r.startDate,{dateStyle:"medium"})," "),t.createElement("div",{className:"d-inline-flex",role:"button",tabIndex:0,onClick:function(){return n(r)},onKeyDown:function(){return n(r)}},t.createElement(a.default,{type:"ellipsis-h",height:"1rem",className:"product-set-recurrence-icon-more"}))),t.createElement("span",{className:"product-set-recurrence-description"},s(r.startDate,{dateStyle:"medium"})," ")),t.createElement("div",{className:"manual-form-error ".concat(!l&&"d-none")},l))};
@@ -1,19 +0,0 @@
1
- import { PropsWithChildren } from "react";
2
- import { Frequency } from "rrule";
3
- import { RecurringDatePickerInputValues } from "./RecurringDatePickerInput";
4
- export interface RecurringDatePickerInputProps {
5
- disabled?: boolean;
6
- defaultValues?: Partial<RecurringDatePickerInputValues>;
7
- onChange: (state: RecurringDatePickerInputValues) => void;
8
- onDelete: () => void;
9
- initialFrequency?: Frequency;
10
- setInitialStartDateAfterSelect?: boolean;
11
- minDate?: string;
12
- }
13
- export interface DatePickerInputValues {
14
- startDate: string;
15
- startTime: string;
16
- endTime: string;
17
- }
18
- export declare function DatePickerInput({ disabled, onChange, onDelete, defaultValues, children, minDate, }: PropsWithChildren<RecurringDatePickerInputProps>): JSX.Element;
19
- //# sourceMappingURL=DatePickerInput.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"DatePickerInput.d.ts","sourceRoot":"","sources":["../../src/recurring-date-picker-input/DatePickerInput.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AASlC,OAAO,EAAE,8BAA8B,EAAE,MAAM,4BAA4B,CAAC;AAG5E,MAAM,WAAW,6BAA6B;IAC5C,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC,8BAA8B,CAAC,CAAC;IACxD,QAAQ,EAAE,CAAC,KAAK,EAAE,8BAA8B,KAAK,IAAI,CAAC;IAC1D,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,gBAAgB,CAAC,EAAE,SAAS,CAAC;IAC7B,8BAA8B,CAAC,EAAE,OAAO,CAAC;IACzC,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,qBAAqB;IACpC,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAgB,EAChB,QAAQ,EACR,QAAQ,EACR,aAAa,EACb,QAAQ,EACR,OAAO,GACR,EAAE,iBAAiB,CAAC,6BAA6B,CAAC,eAwDlD"}
@@ -1 +0,0 @@
1
- "use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("tslib"),n=e(require("react")),r=require("react-i18next"),i=e(require("react-bootstrap/Button")),a=require("react-bootstrap"),l=require("react-hook-form"),o=require("luxon"),u=require("../modals/confirmation/ConfirmModal.js");require("../modals/dialog/Dialog.js"),require("../modals/dialog/DialogContext.js");var d=require("../product-set/elements/DeleteFieldButton.js"),s=require("@licklist/core/dist/Config/Date"),m=require("./RecurrenceAndFrequencyInput.js");exports.DatePickerInput=function(e){var c,f,v,D=e.disabled,p=void 0!==D&&D,g=e.onChange,q=e.onDelete,b=e.defaultValues,T=e.children,_=e.minDate,E=r.useTranslation(["Design"]).t,F=l.useForm({defaultValues:{startDate:null!==(c=null==b?void 0:b.startDate)&&void 0!==c?c:"",startTime:null!==(f=null==b?void 0:b.startTime)&&void 0!==f?f:"",endTime:null!==(v=null==b?void 0:b.endTime)&&void 0!==v?v:""},mode:"onChange"}),j=F.handleSubmit,x=function(e){var n=(null==e?void 0:e.endTime)?o.DateTime.fromISO(null==e?void 0:e.endTime).toFormat(s.TIME_FULL_FORMAT):"";g(t.__assign(t.__assign({},e),{endTime:n}))};return n.createElement(l.FormProvider,t.__assign({},F),n.createElement(a.Form,{noValidate:!0,onSubmit:function(e){return e.preventDefault(),e.stopPropagation(),j(x)(e)}},n.createElement(m.default,{disabled:p,minDate:_}),T,n.createElement("div",{className:"d-inline-flex align-items-center w-100"},n.createElement(i,{type:"submit"},E("Design:apply")),b&&n.createElement("div",{className:"d-flex justify-content-end delete-btn"},n.createElement(u.ConfirmModal,null,(function(e){return n.createElement(d.DeleteFieldButton,{onDelete:function(){return e(q)}})}))))))};
@@ -1,15 +0,0 @@
1
- /// <reference types="react" />
2
- import { RegisterOptions } from "react-hook-form";
3
- interface RecurrenceIntervalAndFrequencyInputProps {
4
- disabled?: boolean;
5
- minDate?: string;
6
- startDateLabel?: string;
7
- startTimeLabel?: string;
8
- endDateLabel?: string;
9
- endTimeLabel?: string;
10
- startTimeRules?: Pick<RegisterOptions, "max" | "min" | "validate" | "required" | "pattern">;
11
- endTimeRules?: Pick<RegisterOptions, "max" | "min" | "validate" | "required" | "pattern">;
12
- }
13
- declare function RecurrenceAndFrequencyInput({ disabled, minDate, startDateLabel, startTimeLabel, endTimeLabel, startTimeRules, endTimeRules, }: RecurrenceIntervalAndFrequencyInputProps): JSX.Element;
14
- export default RecurrenceAndFrequencyInput;
15
- //# sourceMappingURL=RecurrenceAndFrequencyInput.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RecurrenceAndFrequencyInput.d.ts","sourceRoot":"","sources":["../../src/recurring-date-picker-input/RecurrenceAndFrequencyInput.tsx"],"names":[],"mappings":";AAIA,OAAO,EAAE,eAAe,EAAkB,MAAM,iBAAiB,CAAC;AAGlE,UAAU,wCAAwC;IAChD,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,IAAI,CACnB,eAAe,EACf,KAAK,GAAG,KAAK,GAAG,UAAU,GAAG,UAAU,GAAG,SAAS,CACpD,CAAC;IACF,YAAY,CAAC,EAAE,IAAI,CACjB,eAAe,EACf,KAAK,GAAG,KAAK,GAAG,UAAU,GAAG,UAAU,GAAG,SAAS,CACpD,CAAC;CACH;AAED,iBAAS,2BAA2B,CAAC,EACnC,QAAgB,EAChB,OAAO,EACP,cAAc,EACd,cAAc,EACd,YAAY,EACZ,cAAc,EACd,YAAY,GACb,EAAE,wCAAwC,eAqG1C;AAED,eAAe,2BAA2B,CAAC"}
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e,t=require("tslib"),a=require("react"),l=(e=a)&&"object"==typeof e&&"default"in e?e.default:e,r=require("react-i18next"),i=require("react-bootstrap"),n=require("react-hook-form"),o=require("luxon");exports.default=function(e){var m,s,u,d=e.disabled,c=void 0!==d&&d,v=e.minDate,f=e.startDateLabel,b=e.startTimeLabel,g=e.endTimeLabel,p=e.startTimeRules,E=e.endTimeRules,T=r.useTranslation(["Design","Notification","App"]).t,F=n.useFormContext(),D=F.getValues,_=F.formState.errors,C=F.register,q=F.trigger,h=D("startDate"),x=D("startTime"),y=D("endTime");return a.useEffect((function(){x&&y&&q("endTime")}),[x]),l.createElement(l.Fragment,null,l.createElement(i.Row,null,l.createElement(i.Col,{xs:12,sm:6},l.createElement(i.Form.Group,null,l.createElement(i.Form.Label,null,null!=f?f:T("Design:date")),l.createElement(i.Form.Control,t.__assign({type:"date"},C("startDate",{required:!0}),{defaultValue:h,className:h&&"date-input-with-value",disabled:c,min:v,isInvalid:Boolean(_.startDate)})),l.createElement(i.Form.Control.Feedback,{type:"invalid"},null===(m=_.startDate)||void 0===m?void 0:m.message)))),l.createElement(i.Row,null,l.createElement(i.Col,{xs:12,sm:6},l.createElement(i.Form.Group,null,l.createElement(i.Form.Label,null,null!=b?b:T("Design:availableFrom")),l.createElement(i.Form.Control,t.__assign({type:"time"},C("startTime",t.__assign({required:!1},p)),{placeholder:"hh:mm",defaultValue:x,disabled:c,isInvalid:Boolean(_.startTime)})),l.createElement(i.Form.Control.Feedback,{type:"invalid"},null===(s=_.startTime)||void 0===s?void 0:s.message))),l.createElement(i.Col,{xs:12,sm:6},l.createElement(i.Form.Group,null,l.createElement(i.Form.Label,null,null!=g?g:T("Design:availableTo")),l.createElement(i.Form.Control,t.__assign({type:"time"},C("endTime",t.__assign({required:!1,validate:function(e){var t;if(!x||!e)return!0;var a=o.DateTime.fromISO(x),l=o.DateTime.fromISO(e);return(null===(t=null==l?void 0:l.diff(a,["minutes"]))||void 0===t?void 0:t.minutes)>=0||"".concat(T("Validation:fieldLaterDate",{attribute:T("Design:endTimeSmall"),min:T("Design:startTimeSmall")}))}},E)),{placeholder:"hh:mm",defaultValue:y,disabled:c,isInvalid:Boolean(_.endTime)})),l.createElement(i.Form.Control.Feedback,{type:"invalid"},null===(u=_.endTime)||void 0===u?void 0:u.message)))))};
@@ -1,47 +0,0 @@
1
- import { TFunction } from "react-i18next";
2
-
3
- export const injectComponentsInRyftForm = ({
4
- t,
5
- }: {
6
- t: TFunction<string[]>;
7
- }) => {
8
- const cardContainer = document.getElementById("ryft-pay-iframe");
9
- const oldCardDividerContainer = document.getElementById(
10
- "card-title-container"
11
- );
12
-
13
- if (!cardContainer || oldCardDividerContainer) {
14
- return;
15
- }
16
-
17
- const cardTitle = document.createElement("div");
18
- const cardText = document.createElement("div");
19
- const cardTitleContainer = document.createElement("div");
20
- cardTitleContainer.id = "card-title-container";
21
- cardTitle.textContent = t("Design:enterCardDetails");
22
- cardText.className = "bold-text form-label";
23
- cardText.innerText = t("Design:paymentDetails");
24
- cardTitleContainer.append(cardTitle, cardText);
25
- cardContainer?.before(cardTitleContainer);
26
-
27
- const payGrid = document.getElementById("ryft-pay-grid");
28
-
29
- if (!payGrid) {
30
- return;
31
- }
32
-
33
- // Adding title and divider for apple and google pay button
34
- const mobilePayTitle = document.createElement("div");
35
- const dividerText = document.createElement("div");
36
- const divider = document.createElement("div");
37
- const container = document.createElement("div");
38
- mobilePayTitle.className = "mobile-pay-title";
39
- mobilePayTitle.innerText = t("Design:expressCheckoutWith");
40
- dividerText.id = "mobile-pay-divider-text";
41
- dividerText.innerText = "or";
42
- divider.id = "mobile-pay-divider";
43
- container.id = "mobile-pay-divider-container";
44
- container.append(dividerText, divider);
45
- payGrid.before(mobilePayTitle);
46
- payGrid.after(container);
47
- };