@licklist/design 0.70.5-dev.2 → 0.70.5

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 (167) hide show
  1. package/dist/affiliate/form/AffiliateForm.d.ts.map +1 -1
  2. package/dist/assets/iframe/available.svg +4 -4
  3. package/dist/assets/iframe/available.svg.js +18 -16
  4. package/dist/auth/Login/LoginComponent.js +1 -2
  5. package/dist/availability-indicator/AvailabilityIndicator.d.ts +1 -3
  6. package/dist/availability-indicator/AvailabilityIndicator.d.ts.map +1 -1
  7. package/dist/availability-indicator/AvailabilityIndicator.js +18 -112
  8. package/dist/calendar/Calendar.d.ts +0 -2
  9. package/dist/calendar/Calendar.d.ts.map +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 +2 -3
  13. package/dist/calendar/utils/index.d.ts +2 -8
  14. package/dist/calendar/utils/index.d.ts.map +1 -1
  15. package/dist/calendar/utils/index.js +21 -9
  16. package/dist/date-time-button/DateContent.d.ts.map +1 -1
  17. package/dist/date-time-button/DateContent.js +3 -3
  18. package/dist/date-time-button/DateTimeButton.d.ts +1 -3
  19. package/dist/date-time-button/DateTimeButton.d.ts.map +1 -1
  20. package/dist/date-time-button/DateTimeButton.js +1 -2
  21. package/dist/events/edit-event-modal/component/SelectEventProductSet/component/EditEventProductSet.js +2 -3
  22. package/dist/events/edit-event-modal/utils/getDefaultProductSet.d.ts.map +1 -1
  23. package/dist/events/edit-event-modal/utils/getDefaultProductSet.js +1 -0
  24. package/dist/iframe/activity-card/ActivityCard.d.ts +1 -3
  25. package/dist/iframe/activity-card/ActivityCard.d.ts.map +1 -1
  26. package/dist/iframe/activity-card/ActivityCard.js +3 -5
  27. package/dist/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.d.ts.map +1 -1
  28. package/dist/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.js +0 -13
  29. package/dist/iframe/payment/order-items-table/utils/paymentSummary.d.ts.map +1 -1
  30. package/dist/iframe/ryft/RyftPaymentForm.d.ts.map +1 -1
  31. package/dist/iframe/ryft/RyftPaymentForm.js +12 -25
  32. package/dist/iframe/ryft/utils/ryft-form.d.ts.map +1 -1
  33. package/dist/iframe/ryft/utils/ryft-form.js +5 -4
  34. package/dist/layout/DropDown.d.ts +1 -2
  35. package/dist/layout/DropDown.d.ts.map +1 -1
  36. package/dist/notification/email-template/control/EmailTemplateControl.d.ts.map +1 -1
  37. package/dist/notification/email-template/control/EmailTemplateControl.js +0 -3
  38. package/dist/product-set/form/ProductCategoriesControl.d.ts.map +1 -1
  39. package/dist/product-set/form/ProductCategoriesControl.js +2 -48
  40. package/dist/product-set/form/ProductSetForm.d.ts +1 -4
  41. package/dist/product-set/form/ProductSetForm.d.ts.map +1 -1
  42. package/dist/product-set/form/ProductSetForm.js +1 -1
  43. package/dist/product-set/form/ProductZonesControl.d.ts.map +1 -1
  44. package/dist/product-set/form/ProductZonesControl.js +2 -0
  45. package/dist/product-set/form/ProductsControl.js +0 -1
  46. package/dist/product-set/form/SelectCategoryModal.d.ts +0 -12
  47. package/dist/product-set/form/SelectCategoryModal.d.ts.map +1 -1
  48. package/dist/product-set/form/SelectCategoryModal.js +1 -1
  49. package/dist/product-set/form/SubProductsControl.d.ts.map +1 -1
  50. package/dist/product-set/form/SubProductsControl.js +3 -0
  51. package/dist/product-set/form/VenueMapsControl.d.ts.map +1 -1
  52. package/dist/product-set/form/VenueMapsControl.js +3 -0
  53. package/dist/product-set/product/ProductControl.d.ts.map +1 -1
  54. package/dist/product-set/product/advanced-options/AdvancedOptions.js +1 -1
  55. package/dist/product-set/product/booking-management/ProductBookingManagementControl.d.ts.map +1 -1
  56. package/dist/product-set/product/booking-management/ProductBookingManagementControl.js +0 -6
  57. package/dist/product-set/product/deposit/ProductDepositControl.d.ts.map +1 -1
  58. package/dist/product-set/product/deposit/ProductDepositControl.js +0 -3
  59. package/dist/product-set/product/duration/ProductDurationControl.d.ts.map +1 -1
  60. package/dist/product-set/product/duration/ProductDurationControl.js +0 -6
  61. package/dist/product-set/product/price/ProductPriceControl.d.ts.map +1 -1
  62. package/dist/product-set/product/price/ProductPriceControl.js +0 -3
  63. package/dist/product-set/product/quantity/ProductQuantityConstantControl.d.ts.map +1 -1
  64. package/dist/product-set/product/quantity/ProductQuantityConstantControl.js +0 -6
  65. package/dist/product-set/product/quantity/ProductQuantityControl.d.ts.map +1 -1
  66. package/dist/product-set/product/quantity/ProductQuantityControl.js +0 -6
  67. package/dist/product-set/product/quantity/ProductQuantityRechargingControl.d.ts.map +1 -1
  68. package/dist/product-set/product/quantity/ProductQuantityRechargingControl.js +1 -4
  69. package/dist/product-set/product-category/ProductCategoryControl.d.ts.map +1 -1
  70. package/dist/product-set/product-category/ProductCategoryControl.js +0 -12
  71. package/dist/recurrence-input/RecurrenceEndInput.d.ts.map +1 -1
  72. package/dist/recurrence-input/RecurrenceEndInput.js +0 -3
  73. package/dist/recurring-date-picker-input/RecurrenceEndInput.d.ts.map +1 -1
  74. package/dist/resource/form/components/CapacityControl.d.ts.map +1 -1
  75. package/dist/resource/form/components/CapacityControl.js +0 -3
  76. package/dist/resource/form/components/SortControl.d.ts.map +1 -1
  77. package/dist/resource/form/components/SortControl.js +0 -3
  78. package/dist/sales/booking/results/components/ResultCard.d.ts.map +1 -1
  79. package/dist/sales/booking/results/components/ResultCard.js +2 -0
  80. package/dist/sales/coupon/control/CouponFormControl.d.ts.map +1 -1
  81. package/dist/sales/coupon/control/CouponFormControl.js +0 -21
  82. package/dist/setting/admin/PaymentFeeForm.d.ts.map +1 -1
  83. package/dist/setting/admin/PaymentFeeForm.js +1 -16
  84. package/dist/setting/dashboard/DashboardSettingForm.d.ts.map +1 -1
  85. package/dist/setting/dashboard/DashboardSettingForm.js +1 -4
  86. package/dist/snippet/snippet-template/preview/Preview.d.ts.map +1 -1
  87. package/dist/snippet/snippet-template/preview/Preview.js +3 -11
  88. package/dist/sortable-tree/SortableTreeItem.d.ts +1 -2
  89. package/dist/sortable-tree/SortableTreeItem.d.ts.map +1 -1
  90. package/dist/sortable-tree/SortableTreeItem.js +4 -10
  91. package/dist/static/CurrencyNumberInput.d.ts.map +1 -1
  92. package/dist/static/CurrencyNumberInput.js +0 -3
  93. package/dist/static/form-number-input/FormNumberInput.d.ts.map +1 -1
  94. package/dist/static/form-number-input/FormNumberInput.js +0 -3
  95. package/dist/static/number-input/NumberInput.d.ts.map +1 -1
  96. package/dist/static/number-input/NumberInput.js +0 -3
  97. package/dist/styles/availability-indicator/AvailabilityIndicator.scss +0 -9
  98. package/dist/styles/date-time-button/DateTimeButton.scss +1 -1
  99. package/dist/styles/iframe-external-modal/IframeExternalModal.scss +2 -2
  100. package/dist/styles/product-set/ProductSetForm.scss +0 -22
  101. package/dist/styles/ryft-payment-form/RyftPaymentForm.scss +3 -1
  102. package/dist/styles/sales/BookingFilter.scss +3 -2
  103. package/dist/styles/sales/BookingResults.scss +1 -1
  104. package/dist/styles/sales/BookingTabs.scss +29 -26
  105. package/dist/zone/form/components/GameDurationControl.d.ts.map +1 -1
  106. package/dist/zone/form/components/GameDurationControl.js +0 -3
  107. package/dist/zone/form/components/SortControl.d.ts.map +1 -1
  108. package/dist/zone/form/components/SortControl.js +0 -3
  109. package/package.json +6 -8
  110. package/src/affiliate/form/AffiliateForm.tsx +0 -1
  111. package/src/assets/iframe/available.svg +4 -4
  112. package/src/auth/Login/LoginComponent.tsx +1 -1
  113. package/src/availability-indicator/AvailabilityIndicator.tsx +16 -91
  114. package/src/calendar/Calendar.tsx +0 -2
  115. package/src/calendar/components/CalendarDates/CalendarDates.tsx +0 -3
  116. package/src/calendar/utils/index.ts +26 -17
  117. package/src/date-time-button/DateContent.tsx +3 -3
  118. package/src/date-time-button/DateTimeButton.tsx +0 -4
  119. package/src/events/edit-event-modal/utils/getDefaultProductSet.ts +1 -0
  120. package/src/iframe/activity-card/ActivityCard.tsx +2 -15
  121. package/src/iframe/order-process/components/CategoryProduct/components/NumberInput/NumberInput.tsx +0 -9
  122. package/src/iframe/payment/order-items-table/utils/paymentSummary.tsx +0 -1
  123. package/src/iframe/ryft/RyftPaymentForm.tsx +3 -14
  124. package/src/iframe/ryft/utils/ryft-form.ts +5 -6
  125. package/src/layout/DropDown.tsx +1 -1
  126. package/src/notification/email-template/control/EmailTemplateControl.tsx +0 -1
  127. package/src/product-set/form/ProductCategoriesControl.tsx +1 -37
  128. package/src/product-set/form/ProductSetForm.tsx +2 -6
  129. package/src/product-set/form/ProductZonesControl.tsx +4 -1
  130. package/src/product-set/form/SelectCategoryModal.tsx +2 -2
  131. package/src/product-set/form/SubProductsControl.tsx +3 -0
  132. package/src/product-set/form/VenueMapsControl.tsx +3 -0
  133. package/src/product-set/product/ProductControl.tsx +1 -0
  134. package/src/product-set/product/advanced-options/AdvancedOptions.tsx +1 -1
  135. package/src/product-set/product/booking-management/ProductBookingManagementControl.tsx +0 -2
  136. package/src/product-set/product/deposit/ProductDepositControl.tsx +0 -1
  137. package/src/product-set/product/duration/ProductDurationControl.tsx +0 -2
  138. package/src/product-set/product/price/ProductPriceControl.tsx +0 -1
  139. package/src/product-set/product/quantity/ProductQuantityConstantControl.tsx +0 -2
  140. package/src/product-set/product/quantity/ProductQuantityControl.tsx +0 -2
  141. package/src/product-set/product/quantity/ProductQuantityRechargingControl.tsx +0 -1
  142. package/src/product-set/product-category/ProductCategoryControl.tsx +0 -4
  143. package/src/product-set/product-zone/ProductZoneControl.tsx +1 -1
  144. package/src/recurrence-input/RecurrenceEndInput.tsx +0 -1
  145. package/src/recurring-date-picker-input/RecurrenceEndInput.tsx +0 -1
  146. package/src/resource/form/components/CapacityControl.tsx +0 -1
  147. package/src/resource/form/components/SortControl.tsx +0 -1
  148. package/src/sales/booking/results/components/ResultCard.tsx +2 -0
  149. package/src/sales/coupon/control/CouponFormControl.tsx +0 -7
  150. package/src/setting/admin/PaymentFeeForm.tsx +0 -5
  151. package/src/setting/dashboard/DashboardSettingForm.tsx +0 -1
  152. package/src/snippet/snippet-template/preview/Preview.tsx +5 -13
  153. package/src/sortable-tree/SortableTreeItem.tsx +0 -6
  154. package/src/static/CurrencyNumberInput.tsx +0 -1
  155. package/src/static/form-number-input/FormNumberInput.tsx +0 -1
  156. package/src/static/number-input/NumberInput.tsx +0 -1
  157. package/src/styles/availability-indicator/AvailabilityIndicator.scss +0 -9
  158. package/src/styles/date-time-button/DateTimeButton.scss +1 -1
  159. package/src/styles/iframe-external-modal/IframeExternalModal.scss +2 -2
  160. package/src/styles/product-set/ProductSetForm.scss +0 -22
  161. package/src/styles/ryft-payment-form/RyftPaymentForm.scss +3 -1
  162. package/src/styles/sales/BookingFilter.scss +3 -2
  163. package/src/styles/sales/BookingResults.scss +1 -1
  164. package/src/styles/sales/BookingTabs.scss +29 -26
  165. package/src/zone/form/components/GameDurationControl.tsx +0 -1
  166. package/src/zone/form/components/SortControl.tsx +0 -1
  167. package/yarn.lock +88 -97
@@ -6,7 +6,6 @@
6
6
 
7
7
  .main-filter-section {
8
8
  display: flex;
9
- gap: 1rem;
10
9
  justify-content: center;
11
10
 
12
11
  .search {
@@ -47,6 +46,7 @@
47
46
 
48
47
  .buttons {
49
48
  display: flex;
49
+ margin-left: 1rem;
50
50
 
51
51
  .btn {
52
52
  padding: 0;
@@ -122,6 +122,8 @@
122
122
  flex-direction: column;
123
123
 
124
124
  .buttons {
125
+ margin-top: 1rem;
126
+ margin-left: 0;
125
127
  justify-content: space-between;
126
128
  }
127
129
  }
@@ -172,7 +174,6 @@
172
174
 
173
175
  .additional-filter-container {
174
176
  flex-wrap: nowrap;
175
- align-items: baseline;
176
177
 
177
178
  @include media-breakpoint-down(md) {
178
179
  flex-wrap: wrap;
@@ -5,7 +5,7 @@
5
5
  flex-wrap: wrap;
6
6
 
7
7
  .result-card {
8
- height: 14rem;
8
+ height: 14.25rem;
9
9
  border: 1px solid $gray-400;
10
10
  max-width: calc(50% - 0.75rem);
11
11
  flex: 0 0 calc(50% - 0.75rem);
@@ -1,19 +1,12 @@
1
- .booking-tabs-panel {
1
+ .booking-tabs-pane {
2
2
  display: flex;
3
3
  flex-direction: row;
4
+ justify-content: space-between;
4
5
  align-items: center;
5
- gap: 1rem;
6
+ height: 2.75rem;
6
7
  background-color: $white;
7
8
 
8
9
  .booking-tabs {
9
- display: flex;
10
- gap: 0.5rem;
11
-
12
- @include media-breakpoint-down(md) {
13
- flex-direction: column;
14
- align-self: center;
15
- }
16
-
17
10
  svg {
18
11
  g > rect:first-child {
19
12
  fill: $white;
@@ -27,29 +20,40 @@
27
20
  }
28
21
  }
29
22
  }
23
+
24
+ @include media-breakpoint-down(sm) {
25
+ width: 4rem;
26
+ }
30
27
  }
31
28
 
32
29
  .content {
33
30
  display: flex;
34
- flex-grow: 1;
35
- gap: 1rem;
36
31
  justify-content: space-between;
37
- align-items: center;
32
+ width: 85%;
33
+ flex-direction: row;
38
34
 
39
35
  @include media-breakpoint-down(sm) {
36
+ display: flex;
40
37
  flex-direction: column;
41
38
  align-items: start;
42
- gap: 0.5rem;
39
+ height: 4rem;
40
+ }
41
+
42
+ .booking {
43
+ @include media-breakpoint-down(sm) {
44
+ height: 13rem;
45
+ }
43
46
  }
44
47
  }
45
48
 
46
49
  .separator {
47
- align-self: stretch;
50
+ height: 2.75rem;
48
51
  border-right: 2px solid #dcdcdc;
49
52
  }
50
53
 
51
54
  .children {
52
55
  flex: 1;
56
+ margin-left: 1rem;
53
57
 
54
58
  @include media-breakpoint-down(sm) {
55
59
  display: flex;
@@ -60,13 +64,12 @@
60
64
 
61
65
  .buttons {
62
66
  display: flex;
63
- align-items: center;
64
67
 
65
68
  .btn {
66
69
  display: flex;
67
70
  align-items: center;
68
- padding-top: 0.5rem;
69
- padding-bottom: 0.5rem;
71
+ height: 100%;
72
+ height: 2.125rem;
70
73
  }
71
74
 
72
75
  .btn-outline-primary {
@@ -93,19 +96,13 @@
93
96
  }
94
97
  }
95
98
 
96
- @include media-breakpoint-down(lg) {
97
- flex-direction: column;
98
- align-items: stretch;
99
- gap: 0.5rem;
100
- }
101
-
102
99
  @include media-breakpoint-down(sm) {
103
- flex-direction: row;
100
+ display: flex;
101
+ flex-direction: column;
104
102
  align-items: start;
105
103
  gap: 0.5rem;
106
104
  margin-top: 0.5rem;
107
105
  white-space: nowrap;
108
- flex-wrap: wrap;
109
106
  }
110
107
  }
111
108
 
@@ -116,4 +113,10 @@
116
113
  margin-top: 1rem;
117
114
  height: 100%;
118
115
  }
116
+
117
+ .booking {
118
+ @include media-breakpoint-down(sm) {
119
+ height: 13rem;
120
+ }
121
+ }
119
122
  }
@@ -1 +1 @@
1
- {"version":3,"file":"GameDurationControl.d.ts","sourceRoot":"","sources":["../../../../src/zone/form/components/GameDurationControl.tsx"],"names":[],"mappings":"AAOA,KAAK,wBAAwB,GAAG;IAC9B,SAAS,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,mBAAmB,mBAE7B,wBAAwB,4CAgC1B,CAAA"}
1
+ {"version":3,"file":"GameDurationControl.d.ts","sourceRoot":"","sources":["../../../../src/zone/form/components/GameDurationControl.tsx"],"names":[],"mappings":"AAOA,KAAK,wBAAwB,GAAG;IAC9B,SAAS,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,mBAAmB,mBAE7B,wBAAwB,4CA+B1B,CAAA"}
@@ -77,9 +77,6 @@ var GameDurationControl = function(param) {
77
77
  required: false,
78
78
  min: 1
79
79
  })), {
80
- onWheel: function(event) {
81
- return event.currentTarget.blur();
82
- },
83
80
  placeholder: t('Design:duration'),
84
81
  isInvalid: Boolean(errors.defaultDuration),
85
82
  disabled: isLoading
@@ -1 +1 @@
1
- {"version":3,"file":"SortControl.d.ts","sourceRoot":"","sources":["../../../../src/zone/form/components/SortControl.tsx"],"names":[],"mappings":"AAOA,KAAK,gBAAgB,GAAG;IACtB,SAAS,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,WAAW,kBAAmB,gBAAgB,4CAoC1D,CAAA"}
1
+ {"version":3,"file":"SortControl.d.ts","sourceRoot":"","sources":["../../../../src/zone/form/components/SortControl.tsx"],"names":[],"mappings":"AAOA,KAAK,gBAAgB,GAAG;IACtB,SAAS,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,WAAW,kBAAmB,gBAAgB,4CAmC1D,CAAA"}
@@ -77,9 +77,6 @@ var SortControl = function(param) {
77
77
  required: false,
78
78
  min: 1
79
79
  })), {
80
- onWheel: function(event) {
81
- return event.currentTarget.blur();
82
- },
83
80
  placeholder: t('Design:ordering'),
84
81
  isInvalid: Boolean(errors.sort),
85
82
  disabled: isLoading
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@licklist/design",
3
- "version": "0.70.5-dev.2",
3
+ "version": "0.70.5",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "git+ssh://git@bitbucket.org/artelogicsoft/licklist_design.git"
@@ -42,9 +42,9 @@
42
42
  ]
43
43
  },
44
44
  "peerDependencies": {
45
- "@licklist/core": "0.31.1-dev.4",
45
+ "@licklist/core": "0.30.3",
46
46
  "@licklist/eslint-config": "0.5.6",
47
- "@licklist/plugins": "0.34.0-dev.4",
47
+ "@licklist/plugins": "0.33.6",
48
48
  "lodash": "4.17.21",
49
49
  "luxon": "3.5.0",
50
50
  "react": "17.0.2",
@@ -61,9 +61,9 @@
61
61
  "@dnd-kit/utilities": "2.0.0",
62
62
  "@fortawesome/fontawesome-svg-core": "1.2.34",
63
63
  "@fortawesome/free-solid-svg-icons": "5.15.2",
64
- "@licklist/core": "0.31.1-dev.4",
64
+ "@licklist/core": "0.30.3",
65
65
  "@licklist/eslint-config": "0.5.6",
66
- "@licklist/plugins": "0.34.0-dev.4",
66
+ "@licklist/plugins": "0.33.6",
67
67
  "@mantine/core": "6.0.22",
68
68
  "@mantine/hooks": "6.0.22",
69
69
  "@mdx-js/react": "1.6.22",
@@ -202,10 +202,8 @@
202
202
  "yarn tsc"
203
203
  ]
204
204
  },
205
- "packageManager": "yarn@4.4.0",
206
205
  "volta": {
207
206
  "node": "20.9.0",
208
207
  "yarn": "4.4.0"
209
- },
210
- "stableVersion": "0.69.1-dev.3"
208
+ }
211
209
  }
@@ -76,7 +76,6 @@ export const AffiliateForm = ({
76
76
  const copyToClipboard = () =>
77
77
  // eslint-disable-next-line consistent-return
78
78
  window.navigator.clipboard.writeText(formValues.link)
79
-
80
79
  return (
81
80
  <FormProvider {...form}>
82
81
  <Form onSubmit={form.handleSubmit(handleSubmit)}>
@@ -1,5 +1,5 @@
1
- <svg viewBox="auto" fill="none" xmlns="http://www.w3.org/2000/svg">
2
- <rect x="14%" y="0" width="63%" height="29%" rx="15%" fill="#4CF973" stroke="white"/>
3
- <rect x="14%" y="33%" width="63%" height="29%" rx="15%" fill="#4CF973" stroke="white"/>
4
- <rect x="14%" y="66%" width="63%" height="29%" rx="15%" fill="#4CF973" stroke="white"/>
1
+ <svg width="7" height="11" viewBox="0 0 7 11" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <rect x="0.943939" y="1.03658" width="5.25188" height="3.04878" rx="1.5" fill="#4CF973" stroke="white"/>
3
+ <rect x="0.943939" y="4.10976" width="5.25188" height="3.04878" rx="1.5" fill="#4CF973" stroke="white"/>
4
+ <rect x="0.943939" y="7.18292" width="5.25188" height="3.04878" rx="1.5" fill="#4CF973" stroke="white"/>
5
5
  </svg>
@@ -44,7 +44,7 @@ const LoginComponent = ({
44
44
  const handleError = (error: any) => {
45
45
  notification.danger({
46
46
  title: 'Error',
47
- message: error?.response?.data?.message || error.message,
47
+ message: error.message,
48
48
  })
49
49
  }
50
50
 
@@ -1,15 +1,9 @@
1
1
  import { FunctionComponent, SVGProps } from 'react'
2
2
  import { useTranslation } from 'react-i18next'
3
3
  import { ZoneResourcesAvailability } from '@licklist/core/dist/DataMapper/Order/ZoneResourcesAvailabilityDataMapper'
4
- import {
5
- AVAILABILITY_FORMAT_NUMBER,
6
- AvailabilityFormat,
7
- } from '@licklist/core/dist/DataMapper/Provider/SnippetDataMapper'
8
- import { useWindowDimensions } from '@licklist/plugins'
9
4
  import { ReactComponent as AvailableIcon } from '../assets/iframe/available.svg'
10
5
  import { ReactComponent as LimitedIcon } from '../assets/iframe/limited.svg'
11
6
  import { ReactComponent as SoldOutIcon } from '../assets/iframe/soldOut.svg'
12
- import { TAB_WIDTH } from '../iframe/page/components/PageBody/constants'
13
7
 
14
8
  const LOTS_OF_SPACE_LIMIT = 0.2
15
9
  const LIMITED_LIMIT = 0.8
@@ -19,94 +13,38 @@ type Config = {
19
13
  Icon: FunctionComponent<SVGProps<SVGSVGElement>>
20
14
  }
21
15
 
22
- type GetIconsAndLabelsWithArgumentResult = Config & {
23
- argument?: number
24
- }
25
-
26
- interface GetIconsAndLabels extends ZoneResourcesAvailability {
27
- availabilityFormat?: AvailabilityFormat | null
28
- }
29
- interface GetAppropreateLabelFormat extends GetIconsAndLabels {
30
- label?: string
31
- }
32
-
33
- const getLabelsWithArgument = ({
16
+ const getIconsAndLabels = ({
34
17
  bookedResources,
35
18
  totalResources,
36
- availabilityFormat,
37
- label,
38
- }: GetAppropreateLabelFormat): {
39
- label: string
40
- argument?: number
41
- } => {
42
- const availableResources = totalResources - bookedResources
43
-
44
- if (availabilityFormat !== AVAILABILITY_FORMAT_NUMBER) {
45
- return { label }
19
+ }: ZoneResourcesAvailability): Config => {
20
+ if (bookedResources === totalResources) {
21
+ return { label: 'soldOut', Icon: SoldOutIcon }
46
22
  }
47
23
 
48
- return availableResources === 1
49
- ? { label: 'availableSingleResource' }
50
- : { label: 'availableMultipleResources', argument: availableResources }
51
- }
52
-
53
- const getIconsAndLabelsWithArgument = ({
54
- bookedResources,
55
- totalResources,
56
- availabilityFormat,
57
- }: GetIconsAndLabels): GetIconsAndLabelsWithArgumentResult => {
58
24
  // lots of space if less than 80% booked
59
25
  if (bookedResources / totalResources <= LOTS_OF_SPACE_LIMIT) {
60
- return {
61
- ...getLabelsWithArgument({
62
- bookedResources,
63
- totalResources,
64
- availabilityFormat,
65
- label: 'lotsOfSpace',
66
- }),
67
- Icon: AvailableIcon,
68
- }
26
+ return { label: 'lotsOfSpace', Icon: AvailableIcon }
69
27
  }
70
28
 
71
29
  if (bookedResources / totalResources >= LIMITED_LIMIT) {
72
- return {
73
- ...getLabelsWithArgument({
74
- bookedResources,
75
- totalResources,
76
- availabilityFormat,
77
- label: 'limited',
78
- }),
79
- Icon: LimitedIcon,
80
- }
30
+ return { label: 'limited', Icon: LimitedIcon }
81
31
  }
82
32
 
83
- return {
84
- ...getLabelsWithArgument({
85
- bookedResources,
86
- totalResources,
87
- availabilityFormat,
88
- label: 'available',
89
- }),
90
- Icon: AvailableIcon,
91
- }
33
+ return { label: 'available', Icon: AvailableIcon }
92
34
  }
93
35
 
94
36
  type AvailabilityIndicatorProps = {
95
37
  resources: ZoneResourcesAvailability
96
38
  isUnavailable?: boolean
97
39
  isSoldOut?: boolean
98
- availabilityFormat?: AvailabilityFormat | null
99
40
  }
100
41
 
101
42
  export const AvailabilityIndicator = ({
102
43
  resources,
103
44
  isUnavailable,
104
- isSoldOut: _isSoldOut,
105
- availabilityFormat,
45
+ isSoldOut,
106
46
  }: AvailabilityIndicatorProps) => {
107
47
  const { t } = useTranslation('Design')
108
- const isSoldOut =
109
- _isSoldOut || resources.bookedResources === resources.totalResources
110
48
 
111
49
  if (isUnavailable) {
112
50
  return <Indicator Icon={SoldOutIcon} label={t('notAvailable')} />
@@ -116,27 +54,14 @@ export const AvailabilityIndicator = ({
116
54
  return <Indicator Icon={SoldOutIcon} label={t('soldOut')} />
117
55
  }
118
56
 
119
- const { Icon, label, argument } = getIconsAndLabelsWithArgument({
120
- ...resources,
121
- availabilityFormat,
122
- })
57
+ const { Icon, label } = getIconsAndLabels(resources)
123
58
 
124
- return (
125
- <Indicator
126
- Icon={Icon}
127
- label={t(label, argument ? { argument } : undefined)}
128
- />
129
- )
59
+ return <Indicator Icon={Icon} label={t(label)} />
130
60
  }
131
61
 
132
- const Indicator = ({ Icon, label }: Config) => {
133
- const { width } = useWindowDimensions()
134
- const iconSizes =
135
- width > TAB_WIDTH ? { height: 15, width: 11 } : { height: 11, width: 7 }
136
- return (
137
- <div className='availability-indicator'>
138
- <Icon height={iconSizes.height} width={iconSizes.width} viewBox='auto' />
139
- <div className='indicator-label'>{label}</div>
140
- </div>
141
- )
142
- }
62
+ const Indicator = ({ Icon, label }: Config) => (
63
+ <div className='availability-indicator'>
64
+ <Icon />
65
+ <div>{label}</div>
66
+ </div>
67
+ )
@@ -1,6 +1,5 @@
1
1
  import { Dispatch, ReactElement, SetStateAction } from 'react'
2
2
  import { DateTime } from 'luxon'
3
- import { AvailabilityFormat } from '@licklist/core/dist/DataMapper/Provider/SnippetDataMapper'
4
3
  import { DateTimeButtonProps } from 'src/date-time-button'
5
4
  import { CalendarButtons } from './components/CalendarButtons'
6
5
  import { CalendarDates } from './components/CalendarDates'
@@ -22,7 +21,6 @@ export type CalendarProps = {
22
21
  fromPrice?: string | ReactElement | null
23
22
  isLoading?: boolean
24
23
  initialDate?: DateTime
25
- availabilityFormat?: AvailabilityFormat | null
26
24
  getDateTimeButtonProps: (
27
25
  date: DateTime,
28
26
  ) => Pick<DateTimeButtonProps, 'resources' | 'showResources' | 'isDisabled'>
@@ -11,7 +11,6 @@ export type CalendarDatesProps = Pick<
11
11
  | 'setSelectedDate'
12
12
  | 'fromPrice'
13
13
  | 'getDateTimeButtonProps'
14
- | 'availabilityFormat'
15
14
  >
16
15
 
17
16
  export const CalendarDates = ({
@@ -19,7 +18,6 @@ export const CalendarDates = ({
19
18
  selectedDate,
20
19
  setSelectedDate,
21
20
  fromPrice,
22
- availabilityFormat,
23
21
  getDateTimeButtonProps,
24
22
  }: CalendarDatesProps) => {
25
23
  const fillCalendarDates = useMemo(() => {
@@ -58,7 +56,6 @@ export const CalendarDates = ({
58
56
  onSelect={() => setSelectedDate(date)}
59
57
  price={fromPrice}
60
58
  variant={Variant.month}
61
- availabilityFormat={availabilityFormat}
62
59
  {...props}
63
60
  />
64
61
  )
@@ -1,31 +1,40 @@
1
- import { TimeZone } from '@licklist/core/dist/DataMapper/Common/TimeZoneDataMapper'
2
1
  import { DateTime, Interval } from 'luxon'
3
2
 
4
- type Builder = (args: {
5
- initialDate?: DateTime
6
- timeZone: TimeZone['name']
7
- }) => DateTime[]
8
-
9
- export const getMonthCalendarDates: Builder = ({
10
- initialDate: _initialDate,
11
- timeZone,
12
- }): DateTime[] => {
13
- const initialDate = _initialDate || DateTime.now().setZone(timeZone)
14
-
3
+ export const getMonthCalendarDates = (
4
+ initialDate: DateTime,
5
+ timeZone?: string,
6
+ ): DateTime[] => {
15
7
  const startOfMonth = initialDate.startOf('month')
16
8
  const endOfMonth = initialDate.endOf('month')
17
9
 
18
- return Interval.fromDateTimes(startOfMonth, endOfMonth)
10
+ const dateTimes = Interval.fromDateTimes(startOfMonth, endOfMonth)
19
11
  .splitBy({ day: 1 })
20
12
  .map((d) => d.start)
21
- }
22
13
 
23
- export const getWeekCalendarDates: Builder = ({ timeZone }): DateTime[] => {
24
- const initialDate = DateTime.now().setZone(timeZone)
14
+ if (timeZone) {
15
+ return dateTimes.map((date) =>
16
+ date.setZone(timeZone, { keepLocalTime: true }),
17
+ )
18
+ }
25
19
 
20
+ return dateTimes
21
+ }
22
+
23
+ export const getWeekCalendarDates = (
24
+ initialDate: DateTime,
25
+ timeZone?: string,
26
+ ): DateTime[] => {
26
27
  const lastDay = initialDate.plus({ days: 7 })
27
28
 
28
- return Interval.fromDateTimes(initialDate, lastDay)
29
+ const dateTimes = Interval.fromDateTimes(initialDate, lastDay)
29
30
  .splitBy({ day: 1 })
30
31
  .map((d) => d.start)
32
+
33
+ if (timeZone) {
34
+ return dateTimes.map((date) =>
35
+ date.setZone(timeZone, { keepLocalTime: true }),
36
+ )
37
+ }
38
+
39
+ return dateTimes
31
40
  }
@@ -6,9 +6,9 @@ import {
6
6
  } from '@licklist/core/dist/Config'
7
7
  import { getDayWithOrdinal } from '@licklist/plugins/dist/utils/formatDate'
8
8
  import clsx from 'clsx'
9
+ import { isToday, isTomorrow } from 'date-fns'
9
10
  import { DateTime } from 'luxon'
10
11
  import { useTranslation } from 'react-i18next'
11
- import { isToday, isTomorrow } from '@licklist/plugins/dist'
12
12
  import { DateTimeButtonProps, Variant } from './DateTimeButton'
13
13
 
14
14
  type DateContentProps = Pick<
@@ -55,9 +55,9 @@ export const DateContent = ({
55
55
  }
56
56
 
57
57
  const getDate = (date: DateTime): string => {
58
- if (isToday(date)) return 'today'
58
+ if (isToday(date.toJSDate())) return 'today'
59
59
 
60
- if (isTomorrow(date)) return 'tomorrow'
60
+ if (isTomorrow(date.toJSDate())) return 'tomorrow'
61
61
 
62
62
  return date.toFormat(DAY_OF_WEEK)
63
63
  }
@@ -2,7 +2,6 @@ import { ReactElement } from 'react'
2
2
  import clsx from 'clsx'
3
3
  import { DateTime } from 'luxon'
4
4
  import { ZoneResourcesAvailability } from '@licklist/core/dist/DataMapper/Order/ZoneResourcesAvailabilityDataMapper'
5
- import { AvailabilityFormat } from '@licklist/core/dist/DataMapper/Provider/SnippetDataMapper'
6
5
  import { AvailabilityIndicator } from '../availability-indicator'
7
6
  import { DateContent } from './DateContent'
8
7
 
@@ -22,7 +21,6 @@ export type DateTimeButtonProps = {
22
21
  resources?: ZoneResourcesAvailability | null
23
22
  showResources?: boolean
24
23
  variant: Variant
25
- availabilityFormat?: AvailabilityFormat | null
26
24
  }
27
25
 
28
26
  export const DateTimeButton = ({
@@ -35,7 +33,6 @@ export const DateTimeButton = ({
35
33
  resources,
36
34
  showResources,
37
35
  variant = Variant.week,
38
- availabilityFormat,
39
36
  }: DateTimeButtonProps) => {
40
37
  const isSoldOut =
41
38
  _isSoldOut ||
@@ -72,7 +69,6 @@ export const DateTimeButton = ({
72
69
  {price && !isDisabled && <div className='price'>{price}</div>}
73
70
  {showResources && resources && (
74
71
  <AvailabilityIndicator
75
- availabilityFormat={availabilityFormat}
76
72
  resources={resources}
77
73
  isUnavailable={_isDisabled || isPast}
78
74
  isSoldOut={isSoldOut}
@@ -39,6 +39,7 @@ export const getDefaultValues = (
39
39
  ...product,
40
40
  subProducts: subProducts?.map(({ ...subProducts }) => ({
41
41
  ...subProducts,
42
+ originalProductId: null,
42
43
  productCategoryId: undefined,
43
44
  })),
44
45
  productCategoryId: undefined,
@@ -2,7 +2,6 @@ import { ReactNode } from 'react'
2
2
  import clsx from 'clsx'
3
3
  import { Image } from '@licklist/core/dist/DataMapper/Media/ImageDataMapper'
4
4
  import { ZoneResourcesAvailability } from '@licklist/core/dist/DataMapper/Order/ZoneResourcesAvailabilityDataMapper'
5
- import { AvailabilityFormat } from '@licklist/core/dist/DataMapper/Provider/SnippetDataMapper'
6
5
  import { AvailabilityIndicator } from '../../availability-indicator'
7
6
 
8
7
  export const LAYOUT_GRID = 'grid'
@@ -19,7 +18,6 @@ export type ActivityCardProps = {
19
18
  availableTimes?: string | null
20
19
  image?: Image | null
21
20
  resources?: ZoneResourcesAvailability
22
- availabilityFormat?: AvailabilityFormat | null
23
21
  }
24
22
 
25
23
  export const ActivityCard = ({
@@ -32,7 +30,6 @@ export const ActivityCard = ({
32
30
  onSelect,
33
31
  isSelected,
34
32
  layout = LAYOUT_GRID,
35
- availabilityFormat,
36
33
  resources,
37
34
  }: ActivityCardProps) => {
38
35
  if (layout === LAYOUT_GRID) {
@@ -53,12 +50,7 @@ export const ActivityCard = ({
53
50
  {description && (
54
51
  <div className='mt-2 activity-card-description'>{description}</div>
55
52
  )}
56
- {resources && (
57
- <AvailabilityIndicator
58
- resources={resources}
59
- availabilityFormat={availabilityFormat}
60
- />
61
- )}
53
+ {resources && <AvailabilityIndicator resources={resources} />}
62
54
  </div>
63
55
  </button>
64
56
  )
@@ -84,12 +76,7 @@ export const ActivityCard = ({
84
76
  {description && (
85
77
  <div className='mt-2 activity-card-description'>{description}</div>
86
78
  )}
87
- {resources && (
88
- <AvailabilityIndicator
89
- resources={resources}
90
- availabilityFormat={availabilityFormat}
91
- />
92
- )}
79
+ {resources && <AvailabilityIndicator resources={resources} />}
93
80
  </div>
94
81
 
95
82
  <hr className='list-activity-card-hr' />
@@ -89,7 +89,6 @@ export const NumberInput = forwardRef<HTMLInputElement, NumberInputProps>(
89
89
  <FormControl
90
90
  type='number'
91
91
  onChange={(e) => handleChangeValue(Number(e.target.value))}
92
- onWheel={(event) => event.currentTarget.blur()}
93
92
  value={value}
94
93
  min={0}
95
94
  max={max}
@@ -102,14 +101,6 @@ export const NumberInput = forwardRef<HTMLInputElement, NumberInputProps>(
102
101
  <button
103
102
  type='button'
104
103
  onClick={handleArrowUpClick}
105
- onWheel={(event) => event.currentTarget.blur()}
106
- onFocus={(event) =>
107
- event.target.addEventListener(
108
- 'wheel',
109
- (event) => event.preventDefault(),
110
- { passive: false },
111
- )
112
- }
113
104
  className={`payment-number-input__btn-up ${
114
105
  plusButtonGreyedOut && 'disabled-number-input-button'
115
106
  }`}
@@ -61,7 +61,6 @@ const processedPaymentSummary = ({
61
61
  const total = calculateTotalPrice(order, externalPaymentDetail)
62
62
 
63
63
  const totalDiscount = calculateTotalDiscount(order.payments)
64
-
65
64
  let summaryItems: SummaryItem[] = [
66
65
  {
67
66
  translateKey: AMOUNT_TOTAL,