guestbell-forms 3.0.39 → 3.0.41

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 (342) hide show
  1. package/.env.bat +1 -0
  2. package/.eslintrc.json +21 -14
  3. package/build/components/base/input/BaseInput.d.ts +99 -99
  4. package/build/components/base/input/BaseInput.js +4 -0
  5. package/build/components/base/input/BaseInput.js.map +1 -1
  6. package/build/components/base/input/index.d.ts +1 -1
  7. package/build/components/bookingCalendar/BookingCalendar.d.ts +47 -46
  8. package/build/components/bookingCalendar/BookingCalendar.js +38 -14
  9. package/build/components/bookingCalendar/BookingCalendar.js.map +1 -1
  10. package/build/components/bookingCalendar/bookingCalendarControls/BookingCalendarControls.d.ts +17 -17
  11. package/build/components/bookingCalendar/bookingCalendarControls/BookingCalendarControls.js +12 -12
  12. package/build/components/bookingCalendar/bookingCalendarControls/BookingCalendarControls.js.map +1 -1
  13. package/build/components/bookingCalendar/bookingCalendarControls/classes.d.ts +9 -9
  14. package/build/components/bookingCalendar/bookingCalendarControls/index.d.ts +2 -2
  15. package/build/components/bookingCalendar/bookingCalendarDatePicker/BookingCalendarDatePicker.d.ts +13 -13
  16. package/build/components/bookingCalendar/bookingCalendarDatePicker/BookingCalendarDatePicker.js +3 -3
  17. package/build/components/bookingCalendar/bookingCalendarDatePicker/BookingCalendarDatePicker.js.map +1 -1
  18. package/build/components/bookingCalendar/bookingCalendarDatePicker/classes.d.ts +5 -5
  19. package/build/components/bookingCalendar/bookingCalendarDatePicker/index.d.ts +2 -2
  20. package/build/components/bookingCalendar/bookingCalendarGrid/BookingCalendarGrid.d.ts +10 -10
  21. package/build/components/bookingCalendar/bookingCalendarGrid/classes.d.ts +5 -5
  22. package/build/components/bookingCalendar/bookingCalendarItem/BookingCalendarItem.d.ts +57 -57
  23. package/build/components/bookingCalendar/bookingCalendarItem/BookingCalendarItem.js +2 -1
  24. package/build/components/bookingCalendar/bookingCalendarItem/BookingCalendarItem.js.map +1 -1
  25. package/build/components/bookingCalendar/bookingCalendarItem/classes.d.ts +4 -4
  26. package/build/components/bookingCalendar/bookingCalendarItem/index.d.ts +2 -2
  27. package/build/components/bookingCalendar/bookingCalendarLane/BookingCalendarLane.d.ts +16 -16
  28. package/build/components/bookingCalendar/bookingCalendarLane/classes.d.ts +4 -4
  29. package/build/components/bookingCalendar/bookingCalendarLane/index.d.ts +2 -2
  30. package/build/components/bookingCalendar/bookingCalendarLaneHeader/BookingCalendarLaneHeader.d.ts +7 -7
  31. package/build/components/bookingCalendar/bookingCalendarLaneHeader/classes.d.ts +4 -4
  32. package/build/components/bookingCalendar/bookingCalendarLaneHeader/index.d.ts +1 -1
  33. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.d.ts +11 -11
  34. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.js +3 -3
  35. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.js.map +1 -1
  36. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeaderRenderItem.d.ts +4 -5
  37. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeaderRenderItem.js.map +1 -1
  38. package/build/components/bookingCalendar/bookingCalendarLanesHeader/classes.d.ts +5 -5
  39. package/build/components/bookingCalendar/bookingCalendarLanesHeader/index.d.ts +2 -2
  40. package/build/components/bookingCalendar/bookingCalendarRenderItem/BookingCalendarRenderItem.d.ts +9 -9
  41. package/build/components/bookingCalendar/bookingCalendarRenderItem/classes.d.ts +6 -6
  42. package/build/components/bookingCalendar/bookingCalendarRenderItem/index.d.ts +1 -1
  43. package/build/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.d.ts +38 -37
  44. package/build/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.js +7 -4
  45. package/build/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.js.map +1 -1
  46. package/build/components/bookingCalendar/bookingCalendarSelection/classes.d.ts +5 -0
  47. package/build/components/bookingCalendar/bookingCalendarSelection/classes.js +12 -0
  48. package/build/components/bookingCalendar/bookingCalendarSelection/classes.js.map +1 -0
  49. package/build/components/bookingCalendar/bookingCalendarTimeAxis/BookingCalendarTimeAxis.d.ts +11 -11
  50. package/build/components/bookingCalendar/bookingCalendarTimeAxis/classes.d.ts +5 -5
  51. package/build/components/bookingCalendar/classes.d.ts +11 -11
  52. package/build/components/bookingCalendar/common.d.ts +24 -23
  53. package/build/components/bookingCalendar/common.js +3 -4
  54. package/build/components/bookingCalendar/common.js.map +1 -1
  55. package/build/components/bookingCalendar/index.d.ts +3 -3
  56. package/build/components/bookingCalendar/utils.d.ts +55 -50
  57. package/build/components/bookingCalendar/utils.js +2 -1
  58. package/build/components/bookingCalendar/utils.js.map +1 -1
  59. package/build/components/button/Button.d.ts +81 -81
  60. package/build/components/button/Button.js +1 -0
  61. package/build/components/button/Button.js.map +1 -1
  62. package/build/components/button/index.d.ts +2 -2
  63. package/build/components/checkbox/Checkbox.d.ts +23 -23
  64. package/build/components/checkbox/index.d.ts +2 -2
  65. package/build/components/dropdown/Dropdown.d.ts +44 -44
  66. package/build/components/dropdown/index.d.ts +2 -2
  67. package/build/components/dynamicSubmit/DynamicSubmit.d.ts +54 -54
  68. package/build/components/dynamicSubmit/DynamicSubmit.js.map +1 -1
  69. package/build/components/dynamicSubmit/index.d.ts +2 -2
  70. package/build/components/externalValidationComponent/ExternalValidationComponent.d.ts +15 -15
  71. package/build/components/externalValidationComponent/index.d.ts +2 -2
  72. package/build/components/form/Form.d.ts +47 -47
  73. package/build/components/form/FormContext.d.ts +30 -30
  74. package/build/components/form/FormValidationSummary.d.ts +38 -38
  75. package/build/components/form/FormValidationSummary.js.map +1 -1
  76. package/build/components/form/index.d.ts +5 -5
  77. package/build/components/form/withFormContext.d.ts +3 -3
  78. package/build/components/inputGroup/InputGroup.d.ts +15 -17
  79. package/build/components/inputGroup/index.d.ts +2 -2
  80. package/build/components/inputHeader/InputHeader.d.ts +97 -97
  81. package/build/components/inputHeader/InputHeader.js.map +1 -1
  82. package/build/components/inputHeader/InputHeaderContext.d.ts +24 -24
  83. package/build/components/inputHeader/index.d.ts +2 -2
  84. package/build/components/inputHeader/withInputHeaderContext.d.ts +3 -3
  85. package/build/components/money/Money.d.ts +78 -78
  86. package/build/components/money/Money.js.map +1 -1
  87. package/build/components/money/index.d.ts +2 -2
  88. package/build/components/numberInput/NumberInput.d.ts +28 -28
  89. package/build/components/numberInput/index.d.ts +2 -2
  90. package/build/components/openingHours/openingHoursDay/OpeningHoursDay.d.ts +84 -84
  91. package/build/components/openingHours/openingHoursDay/OpeningHoursDay.js +3 -3
  92. package/build/components/openingHours/openingHoursDay/OpeningHoursDay.js.map +1 -1
  93. package/build/components/openingHours/openingHoursDay/index.d.ts +2 -2
  94. package/build/components/openingHours/openingHoursSpecial/OpeningHoursSpecial.d.ts +92 -90
  95. package/build/components/openingHours/openingHoursSpecial/OpeningHoursSpecial.js.map +1 -1
  96. package/build/components/openingHours/openingHoursSpecial/index.d.ts +2 -2
  97. package/build/components/openingHours/openingHoursWeek/OpeningHoursWeek.d.ts +109 -109
  98. package/build/components/openingHours/openingHoursWeek/index.d.ts +2 -2
  99. package/build/components/openingHours/utils/OpeningHoursUtil.d.ts +21 -21
  100. package/build/components/radio/Radio.d.ts +20 -20
  101. package/build/components/radio/index.d.ts +2 -2
  102. package/build/components/radioContainer/RadioContainer.d.ts +17 -16
  103. package/build/components/radioContainer/RadioContainer.js.map +1 -1
  104. package/build/components/radioContainer/index.d.ts +2 -2
  105. package/build/components/select/Select.d.ts +79 -79
  106. package/build/components/select/index.d.ts +2 -2
  107. package/build/components/submit/Submit.d.ts +137 -137
  108. package/build/components/submit/index.d.ts +2 -2
  109. package/build/components/submit/subComponents/SubmitValidationSummary.d.ts +5 -5
  110. package/build/components/tags/Tags.d.ts +92 -92
  111. package/build/components/tags/Tags.js +2 -0
  112. package/build/components/tags/Tags.js.map +1 -1
  113. package/build/components/tags/index.d.ts +2 -2
  114. package/build/components/tags/subComponents/TagsSuggestions.d.ts +34 -34
  115. package/build/components/tags/subComponents/TagsSuggestions.js +2 -2
  116. package/build/components/tags/subComponents/TagsSuggestions.js.map +1 -1
  117. package/build/components/text/Text.d.ts +31 -31
  118. package/build/components/text/index.d.ts +2 -2
  119. package/build/components/textArea/TextArea.d.ts +28 -28
  120. package/build/components/textArea/TextArea.js +1 -0
  121. package/build/components/textArea/TextArea.js.map +1 -1
  122. package/build/components/textArea/index.d.ts +2 -2
  123. package/build/components/themeProvider/ThemeContext.d.ts +9 -9
  124. package/build/components/themeProvider/ThemeProvider.d.ts +8 -7
  125. package/build/components/themeProvider/ThemeProvider.js.map +1 -1
  126. package/build/components/themeProvider/index.d.ts +4 -4
  127. package/build/components/themeProvider/withThemeContext.d.ts +4 -4
  128. package/build/components/time/Time.d.ts +32 -32
  129. package/build/components/time/Time.js +3 -3
  130. package/build/components/time/Time.js.map +1 -1
  131. package/build/components/time/index.d.ts +2 -2
  132. package/build/components/timeSpan/TimeSpan.d.ts +46 -46
  133. package/build/components/timeSpan/TimeSpan.js +6 -6
  134. package/build/components/timeSpan/TimeSpan.js.map +1 -1
  135. package/build/components/timeSpan/index.d.ts +2 -2
  136. package/build/components/utils/Guid.d.ts +2 -2
  137. package/build/components/utils/ShallowEqual.d.ts +16 -16
  138. package/build/components/utils/TimeUtil.d.ts +6 -6
  139. package/build/components/utils/Typescript.d.ts +5 -5
  140. package/build/dist/guestbell-forms.css +154 -170
  141. package/build/dist/guestbell-forms.css.map +1 -1
  142. package/build/dist/guestbell-forms.js +15 -24
  143. package/build/dist/guestbell-forms.js.map +1 -1
  144. package/build/dist/guestbell-forms.min.css +1 -1
  145. package/build/dist/guestbell-forms.min.js +1 -1
  146. package/build/dist/guestbell-forms.min.js.map +1 -1
  147. package/build/dist/report.html +3 -3
  148. package/build/index.d.ts +24 -24
  149. package/build/scss/components/bookingCalendar/bookingCalendar.scss +32 -7
  150. package/build/types/ElementOverrideProp.d.ts +3 -3
  151. package/build/types/Theme.d.ts +4 -4
  152. package/build/types/ThemeOverrides.d.ts +45 -45
  153. package/build/validators/EmailValidator.d.ts +4 -4
  154. package/build/validators/LatitudeValidator.d.ts +4 -4
  155. package/build/validators/LongitudeValidator.d.ts +4 -4
  156. package/build/validators/NumberValidator.d.ts +12 -12
  157. package/build/validators/NumberValidator.js +1 -0
  158. package/build/validators/NumberValidator.js.map +1 -1
  159. package/build/validators/UrlValidator.d.ts +4 -4
  160. package/build/validators/base.d.ts +4 -4
  161. package/build/validators/index.d.ts +6 -6
  162. package/package.json +130 -136
  163. package/src/lib/components/base/input/BaseInput.tsx +526 -0
  164. package/src/lib/components/base/input/index.tsx +1 -0
  165. package/src/lib/components/bookingCalendar/BookingCalendar.tsx +399 -0
  166. package/src/lib/components/bookingCalendar/bookingCalendarControls/BookingCalendarControls.tsx +249 -0
  167. package/src/lib/components/bookingCalendar/bookingCalendarControls/classes.ts +20 -0
  168. package/src/lib/components/bookingCalendar/bookingCalendarControls/index.ts +2 -0
  169. package/src/lib/components/bookingCalendar/bookingCalendarDatePicker/BookingCalendarDatePicker.tsx +104 -0
  170. package/src/lib/components/bookingCalendar/bookingCalendarDatePicker/classes.ts +9 -0
  171. package/src/lib/components/bookingCalendar/bookingCalendarDatePicker/index.ts +2 -0
  172. package/src/lib/components/bookingCalendar/bookingCalendarGrid/BookingCalendarGrid.tsx +56 -0
  173. package/src/lib/components/bookingCalendar/bookingCalendarGrid/classes.ts +9 -0
  174. package/src/lib/components/bookingCalendar/bookingCalendarItem/BookingCalendarItem.tsx +98 -0
  175. package/src/lib/components/bookingCalendar/bookingCalendarItem/classes.ts +7 -0
  176. package/src/lib/components/bookingCalendar/bookingCalendarItem/index.ts +2 -0
  177. package/src/lib/components/bookingCalendar/bookingCalendarLane/BookingCalendarLane.tsx +69 -0
  178. package/src/lib/components/bookingCalendar/bookingCalendarLane/classes.ts +7 -0
  179. package/src/lib/components/bookingCalendar/bookingCalendarLane/index.ts +2 -0
  180. package/src/lib/components/bookingCalendar/bookingCalendarLaneHeader/BookingCalendarLaneHeader.tsx +28 -0
  181. package/src/lib/components/bookingCalendar/bookingCalendarLaneHeader/classes.ts +7 -0
  182. package/src/lib/components/bookingCalendar/bookingCalendarLaneHeader/index.ts +1 -0
  183. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.tsx +57 -0
  184. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeaderRenderItem.tsx +53 -0
  185. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/classes.ts +9 -0
  186. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/index.ts +2 -0
  187. package/src/lib/components/bookingCalendar/bookingCalendarRenderItem/BookingCalendarRenderItem.tsx +57 -0
  188. package/src/lib/components/bookingCalendar/bookingCalendarRenderItem/classes.ts +11 -0
  189. package/src/lib/components/bookingCalendar/bookingCalendarRenderItem/index.ts +1 -0
  190. package/src/lib/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.tsx +225 -0
  191. package/src/lib/components/bookingCalendar/bookingCalendarSelection/classes.ts +10 -0
  192. package/src/lib/components/bookingCalendar/bookingCalendarTimeAxis/BookingCalendarTimeAxis.tsx +53 -0
  193. package/src/lib/components/bookingCalendar/bookingCalendarTimeAxis/classes.ts +9 -0
  194. package/src/lib/components/bookingCalendar/classes.ts +21 -0
  195. package/src/lib/components/bookingCalendar/common.ts +62 -0
  196. package/src/lib/components/bookingCalendar/index.ts +3 -0
  197. package/src/lib/components/bookingCalendar/utils.ts +350 -0
  198. package/src/lib/components/button/Button.tsx +193 -0
  199. package/src/lib/components/button/index.tsx +2 -0
  200. package/src/lib/components/checkbox/Checkbox.tsx +178 -0
  201. package/src/lib/components/checkbox/index.tsx +2 -0
  202. package/src/lib/components/dropdown/Dropdown.tsx +135 -0
  203. package/src/lib/components/dropdown/index.tsx +2 -0
  204. package/src/lib/components/dynamicSubmit/DynamicSubmit.tsx +153 -0
  205. package/src/lib/components/dynamicSubmit/index.tsx +2 -0
  206. package/src/lib/components/externalValidationComponent/ExternalValidationComponent.tsx +78 -0
  207. package/src/lib/components/externalValidationComponent/index.tsx +2 -0
  208. package/src/lib/components/form/Form.tsx +276 -0
  209. package/src/lib/components/form/FormContext.ts +49 -0
  210. package/src/lib/components/form/FormValidationSummary.tsx +122 -0
  211. package/src/lib/components/form/index.tsx +5 -0
  212. package/src/lib/components/form/withFormContext.tsx +20 -0
  213. package/src/lib/components/inputGroup/InputGroup.tsx +60 -0
  214. package/src/lib/components/inputGroup/index.tsx +2 -0
  215. package/src/lib/components/inputHeader/InputHeader.tsx +448 -0
  216. package/src/lib/components/inputHeader/InputHeaderContext.ts +42 -0
  217. package/src/lib/components/inputHeader/index.tsx +2 -0
  218. package/src/lib/components/inputHeader/withInputHeaderContext.tsx +24 -0
  219. package/src/lib/components/money/Money.tsx +298 -0
  220. package/src/lib/components/money/index.tsx +2 -0
  221. package/src/lib/components/numberInput/NumberInput.tsx +186 -0
  222. package/src/lib/components/numberInput/index.tsx +2 -0
  223. package/src/lib/components/openingHours/openingHoursDay/OpeningHoursDay.tsx +394 -0
  224. package/src/lib/components/openingHours/openingHoursDay/index.tsx +2 -0
  225. package/src/lib/components/openingHours/openingHoursSpecial/OpeningHoursSpecial.tsx +227 -0
  226. package/src/lib/components/openingHours/openingHoursSpecial/index.tsx +2 -0
  227. package/src/lib/components/openingHours/openingHoursWeek/OpeningHoursWeek.tsx +283 -0
  228. package/src/lib/components/openingHours/openingHoursWeek/index.tsx +2 -0
  229. package/src/lib/components/openingHours/utils/OpeningHoursUtil.tsx +111 -0
  230. package/src/lib/components/radio/Radio.tsx +87 -0
  231. package/src/lib/components/radio/index.tsx +2 -0
  232. package/src/lib/components/radioContainer/RadioContainer.tsx +50 -0
  233. package/src/lib/components/radioContainer/index.tsx +2 -0
  234. package/src/lib/components/select/Select.tsx +335 -0
  235. package/src/lib/components/select/index.tsx +2 -0
  236. package/src/lib/components/submit/Submit.tsx +117 -0
  237. package/src/lib/components/submit/index.tsx +2 -0
  238. package/src/lib/components/submit/subComponents/SubmitValidationSummary.tsx +55 -0
  239. package/src/lib/components/tags/Tags.tsx +702 -0
  240. package/src/lib/components/tags/index.tsx +2 -0
  241. package/src/lib/components/tags/subComponents/TagsSuggestions.tsx +150 -0
  242. package/src/lib/components/text/Text.tsx +200 -0
  243. package/src/lib/components/text/index.tsx +2 -0
  244. package/src/lib/components/textArea/TextArea.tsx +109 -0
  245. package/src/lib/components/textArea/index.tsx +2 -0
  246. package/src/lib/components/themeProvider/ThemeContext.ts +16 -0
  247. package/src/lib/components/themeProvider/ThemeProvider.tsx +21 -0
  248. package/src/lib/components/themeProvider/index.tsx +4 -0
  249. package/src/lib/components/themeProvider/withThemeContext.tsx +30 -0
  250. package/src/lib/components/time/Time.tsx +296 -0
  251. package/src/lib/components/time/index.tsx +2 -0
  252. package/src/lib/components/timeSpan/TimeSpan.tsx +378 -0
  253. package/src/lib/components/timeSpan/index.tsx +2 -0
  254. package/src/lib/components/utils/Guid.ts +9 -0
  255. package/src/lib/components/utils/ShallowEqual.ts +75 -0
  256. package/src/lib/components/utils/TimeUtil.ts +22 -0
  257. package/src/lib/components/utils/Typescript.ts +11 -0
  258. package/src/lib/declarations/import.d.ts +1 -0
  259. package/src/lib/index.ts +24 -0
  260. package/src/lib/scss/components/base/index.scss +1 -0
  261. package/src/lib/scss/components/base/input/index.scss +1 -0
  262. package/src/lib/scss/components/base/input/input.scss +237 -0
  263. package/src/lib/scss/components/bookingCalendar/bookingCalendar.scss +274 -0
  264. package/src/lib/scss/components/bookingCalendar/index.scss +1 -0
  265. package/src/lib/scss/components/button/buttons.scss +161 -0
  266. package/src/lib/scss/components/button/index.scss +1 -0
  267. package/src/lib/scss/components/checkbox/checkbox.scss +115 -0
  268. package/src/lib/scss/components/checkbox/index.scss +1 -0
  269. package/src/lib/scss/components/dropdown/dropdown.scss +111 -0
  270. package/src/lib/scss/components/dropdown/index.scss +1 -0
  271. package/src/lib/scss/components/dynamicSubmit/dynamicSubmit.scss +1 -0
  272. package/src/lib/scss/components/dynamicSubmit/index.scss +1 -0
  273. package/src/lib/scss/components/form/form.scss +1 -0
  274. package/src/lib/scss/components/form/formValidationSummary.scss +55 -0
  275. package/src/lib/scss/components/form/index.scss +2 -0
  276. package/src/lib/scss/components/index.scss +21 -0
  277. package/src/lib/scss/components/inputGroup/index.scss +1 -0
  278. package/src/lib/scss/components/inputGroup/inputGroup.scss +67 -0
  279. package/src/lib/scss/components/inputHeader/index.scss +1 -0
  280. package/src/lib/scss/components/inputHeader/inputHeader.scss +132 -0
  281. package/src/lib/scss/components/money/index.scss +1 -0
  282. package/src/lib/scss/components/money/money.scss +51 -0
  283. package/src/lib/scss/components/numberInput/index.scss +1 -0
  284. package/src/lib/scss/components/numberInput/numberInput.scss +116 -0
  285. package/src/lib/scss/components/openingHours/index.scss +3 -0
  286. package/src/lib/scss/components/openingHours/openingHoursDay/index.scss +1 -0
  287. package/src/lib/scss/components/openingHours/openingHoursDay/openingHoursDay.scss +127 -0
  288. package/src/lib/scss/components/openingHours/openingHoursSpecial/index.scss +1 -0
  289. package/src/lib/scss/components/openingHours/openingHoursSpecial/openingHoursSpecial.scss +93 -0
  290. package/src/lib/scss/components/openingHours/openingHoursWeek/index.scss +1 -0
  291. package/src/lib/scss/components/openingHours/openingHoursWeek/openingHoursWeek.scss +23 -0
  292. package/src/lib/scss/components/radio/index.scss +1 -0
  293. package/src/lib/scss/components/radio/radio.scss +68 -0
  294. package/src/lib/scss/components/radioContainer/index.scss +1 -0
  295. package/src/lib/scss/components/radioContainer/radioContainer.scss +15 -0
  296. package/src/lib/scss/components/select/index.scss +1 -0
  297. package/src/lib/scss/components/select/select.scss +64 -0
  298. package/src/lib/scss/components/submit/index.scss +1 -0
  299. package/src/lib/scss/components/submit/submitValidationSummary.scss +35 -0
  300. package/src/lib/scss/components/tags/index.scss +1 -0
  301. package/src/lib/scss/components/tags/tags.scss +128 -0
  302. package/src/lib/scss/components/text/index.scss +1 -0
  303. package/src/lib/scss/components/text/text.scss +42 -0
  304. package/src/lib/scss/components/textArea/index.scss +1 -0
  305. package/src/lib/scss/components/textArea/textArea.scss +32 -0
  306. package/src/lib/scss/components/time/index.scss +1 -0
  307. package/src/lib/scss/components/time/time.scss +111 -0
  308. package/src/lib/scss/components/timeSpan/index.scss +1 -0
  309. package/src/lib/scss/components/timeSpan/timeSpan.scss +115 -0
  310. package/src/lib/scss/index.scss +8 -0
  311. package/src/lib/scss/styles/base.scss +7 -0
  312. package/src/lib/scss/styles/index.scss +2 -0
  313. package/src/lib/scss/styles/react-tippy.scss +4 -0
  314. package/src/lib/scss/variables/_buttons.scss +6 -0
  315. package/src/lib/scss/variables/_colors.scss +1 -0
  316. package/src/lib/scss/variables/_common.scss +12 -0
  317. package/src/lib/tsconfig.json +19 -0
  318. package/src/lib/types/ElementOverrideProp.ts +3 -0
  319. package/src/lib/types/Theme.ts +5 -0
  320. package/src/lib/types/ThemeOverrides.ts +46 -0
  321. package/src/lib/validators/EmailValidator.ts +15 -0
  322. package/src/lib/validators/LatitudeValidator.ts +25 -0
  323. package/src/lib/validators/LongitudeValidator.ts +25 -0
  324. package/src/lib/validators/NumberValidator.ts +50 -0
  325. package/src/lib/validators/UrlValidator.ts +20 -0
  326. package/src/lib/validators/base.ts +15 -0
  327. package/src/lib/validators/index.ts +6 -0
  328. package/src/stories/Basic.stories.ts +17 -0
  329. package/src/stories/Basic.tsx +1065 -0
  330. package/src/stories/Schedule.stories.ts +16 -0
  331. package/src/stories/Schedule.tsx +85 -0
  332. package/src/stories/ValidationPage.tsx +417 -0
  333. package/tsconfig.json +9 -22
  334. package/typedoc.json +6 -0
  335. package/webpack/webpack.config.base.js +139 -0
  336. package/webpack/webpack.config.dev.js +78 -0
  337. package/webpack/webpack.config.gh-pages.js +78 -0
  338. package/webpack/webpack.config.js +21 -0
  339. package/webpack/webpack.config.min.js +100 -0
  340. package/.vscode/launch.json +0 -15
  341. package/.vscode/settings.json +0 -27
  342. package/.vscode/tasks.json +0 -12
@@ -0,0 +1,399 @@
1
+ import * as React from 'react';
2
+ import {
3
+ BookingCalendarClasses,
4
+ bookingCalendarDefaultClasses,
5
+ } from './classes';
6
+ import classNames from 'classnames';
7
+ import {
8
+ BookingCalendarDateRange,
9
+ BookingCalendarItemT,
10
+ defaultGetMomentFormatFunction,
11
+ GetNewMomentFunctionType,
12
+ defaultGetNewMomentFunction,
13
+ defaultGridAvailableSteps,
14
+ GetMomentFormatFunctionType,
15
+ ZoomLevel,
16
+ } from './common';
17
+ import {
18
+ BookingCalendarControls as DefaultBookingCalendarControls,
19
+ BookingCalendarControlsProps,
20
+ } from './bookingCalendarControls/BookingCalendarControls';
21
+ import {
22
+ generateGridItems,
23
+ LaneSourceData,
24
+ splitBookingsToLanes,
25
+ } from './utils';
26
+ import {
27
+ BookingCalendarLane as DefaultBookingCalendarLane,
28
+ BookingCalendarLaneProps,
29
+ } from './bookingCalendarLane/BookingCalendarLane';
30
+ import moment, { Moment, Duration } from 'moment';
31
+ import {
32
+ BookingCalendarItemProps,
33
+ bookingCalendarItemDefaultClasses,
34
+ } from './bookingCalendarItem';
35
+ import { BookingCalendarRenderItemProps } from './bookingCalendarRenderItem';
36
+ import {
37
+ BookingCalendarGrid as DefaultBookingCalendarGrid,
38
+ BookingCalendarGridProps,
39
+ } from './bookingCalendarGrid/BookingCalendarGrid';
40
+ import {
41
+ BookingCalendarLaneHeader as DefaultBookingCalendarLaneHeader,
42
+ BookingCalendarLaneHeaderProps,
43
+ } from './bookingCalendarLaneHeader';
44
+ import {
45
+ BookingCalendarLanesHeader as DefaultBookingCalendarLanesHeader,
46
+ BookingCalendarLanesHeaderProps,
47
+ bookingCalendarLanesHeaderDefaultClasses,
48
+ } from './bookingCalendarLanesHeader';
49
+ import {
50
+ BookingCalendarDatePicker as DefaultBookingCalendarDatePicker,
51
+ BookingCalendarDatePickerProps,
52
+ } from './bookingCalendarDatePicker';
53
+ import { BookingCalendarTimeAxis } from './bookingCalendarTimeAxis/BookingCalendarTimeAxis';
54
+ import useDimensions from 'react-cool-dimensions';
55
+ import BookingCalendarSelection, {
56
+ BookingCalendarSelectionData,
57
+ } from './bookingCalendarSelection/BookingCalendarSelection';
58
+ import { bookingCalendarLaneDefaultClasses } from './bookingCalendarLane';
59
+ import { bookingCalendarSelectionDefaultClasses } from './bookingCalendarSelection/classes';
60
+
61
+ export interface BookingCalendarProps<T extends BookingCalendarItemT, TLaneData>
62
+ extends BookingCalendarClasses {
63
+ bookings: T[];
64
+ from: Moment;
65
+ till: Moment;
66
+ getMomentFormatFunction?: GetMomentFormatFunctionType;
67
+ getNewMomentFunction?: GetNewMomentFunctionType;
68
+ onRangeChange?: (range: BookingCalendarDateRange) => void;
69
+ step?: Duration;
70
+ showZoomAllButton?: boolean;
71
+ showGrid?: boolean;
72
+ gridAvailableSteps?: Duration[];
73
+ goalGridWidthPx?: number;
74
+ minLanesCount?: number;
75
+ lanesSource?: LaneSourceData<T, TLaneData>[];
76
+ unmatchedLanesToFront?: boolean;
77
+ children?: React.ReactNode;
78
+ bookingCalendarTopLeftHeader?: React.ReactNode;
79
+ filteringButton?: React.ReactNode;
80
+
81
+ zoomLevels?: ZoomLevel[];
82
+ filterBookingsToZoom?: (booking: T) => boolean;
83
+
84
+ showSelection?: boolean;
85
+ minSelectionSize?: number;
86
+ onSelection?: (
87
+ items: T[],
88
+ from: Moment,
89
+ till: Moment,
90
+ e: React.MouseEvent<HTMLElement>
91
+ ) => void;
92
+ selectionContent?: React.ReactNode;
93
+
94
+ BookingCalendarItem?: React.ComponentType<BookingCalendarItemProps<T>>;
95
+ BookingCalendarRenderItem?: React.ComponentType<
96
+ BookingCalendarRenderItemProps<T>
97
+ >;
98
+ BookingCalendarLane?: React.ComponentType<BookingCalendarLaneProps<T>>;
99
+ BookingCalendarControls?: React.ComponentType<
100
+ BookingCalendarControlsProps<T>
101
+ >;
102
+ BookingCalendarGrid?: React.ComponentType<BookingCalendarGridProps>;
103
+ BookingCalendarLaneHeader?: React.ComponentType<
104
+ BookingCalendarLaneHeaderProps<TLaneData>
105
+ >;
106
+ BookingCalendarLanesHeader?: React.ComponentType<
107
+ BookingCalendarLanesHeaderProps<T>
108
+ >;
109
+ BookingCalendarDatePicker?:
110
+ | React.ComponentType<BookingCalendarDatePickerProps<T>>
111
+ | React.ReactNode;
112
+ }
113
+
114
+ const defaultStep = moment.duration(1, 'day');
115
+
116
+ export function BookingCalendar<T extends BookingCalendarItemT, TLaneData>(
117
+ props: BookingCalendarProps<T, TLaneData>
118
+ ) {
119
+ const {
120
+ bookings,
121
+ className,
122
+ laneContainerClassName,
123
+ laneHeaderContainerClassName,
124
+ lanesHeaderContainerClassName,
125
+ lanesHeaderHeaderContainerClassName,
126
+ controlsClasses,
127
+ tableClassName,
128
+ from,
129
+ till,
130
+ onRangeChange,
131
+ step = defaultStep,
132
+ showGrid = true,
133
+ showSelection = true,
134
+ onSelection,
135
+ minSelectionSize = 10,
136
+ selectionContent,
137
+ showZoomAllButton = true,
138
+ gridAvailableSteps = defaultGridAvailableSteps,
139
+ getMomentFormatFunction = defaultGetMomentFormatFunction,
140
+ getNewMomentFunction = defaultGetNewMomentFunction,
141
+ goalGridWidthPx = 60,
142
+ minLanesCount,
143
+ lanesSource,
144
+ unmatchedLanesToFront = true,
145
+ filterBookingsToZoom,
146
+ zoomLevels,
147
+ BookingCalendarControls = DefaultBookingCalendarControls,
148
+ BookingCalendarItem,
149
+ BookingCalendarLane = DefaultBookingCalendarLane,
150
+ BookingCalendarRenderItem,
151
+ BookingCalendarGrid = DefaultBookingCalendarGrid,
152
+ BookingCalendarLaneHeader = DefaultBookingCalendarLaneHeader,
153
+ BookingCalendarLanesHeader = DefaultBookingCalendarLanesHeader,
154
+ BookingCalendarDatePicker = DefaultBookingCalendarDatePicker,
155
+ bookingCalendarTopLeftHeader,
156
+ filteringButton,
157
+ children,
158
+ } = props;
159
+ const lanes = React.useMemo(
160
+ () =>
161
+ splitBookingsToLanes<T, TLaneData>(
162
+ bookings,
163
+ from,
164
+ minLanesCount,
165
+ lanesSource,
166
+ unmatchedLanesToFront
167
+ ),
168
+ [bookings, from, minLanesCount, lanesSource, unmatchedLanesToFront]
169
+ );
170
+ const { observe, entry } = useDimensions<HTMLDivElement>();
171
+ const width = entry?.target?.scrollWidth ?? 0;
172
+ const { items: gridItems, bestStep } = React.useMemo(
173
+ () =>
174
+ generateGridItems(
175
+ from,
176
+ till,
177
+ step,
178
+ width,
179
+ gridAvailableSteps,
180
+ goalGridWidthPx,
181
+ from?.clone()?.startOf('day')
182
+ ),
183
+ [from, till, step, width, gridAvailableSteps, goalGridWidthPx]
184
+ );
185
+ const containerRef = React.useRef<HTMLDivElement>();
186
+ const onSelected = React.useCallback(
187
+ (data: BookingCalendarSelectionData, e: React.MouseEvent<HTMLElement>) => {
188
+ if (!from || !till || !width || !onRangeChange) {
189
+ return;
190
+ }
191
+ const screenSpaceStartX = Math.min(data.origin[0], data.target[0]);
192
+ const screenSpaceEndX = Math.max(data.origin[0], data.target[0]);
193
+ const screenSpaceStartY = Math.min(data.origin[1], data.target[1]);
194
+ const screenSpaceEndY = Math.max(data.origin[1], data.target[1]);
195
+ const durationMs = till.valueOf() - from.valueOf();
196
+ const toTimeSpace = (num: number) => (num / (width || 1)) * durationMs;
197
+ const timeSpaceStart = from
198
+ .clone()
199
+ .add(toTimeSpace(screenSpaceStartX), 'ms');
200
+ const timeSpaceEnd = from.clone().add(toTimeSpace(screenSpaceEndX), 'ms');
201
+ if (onSelection) {
202
+ const itemSelector = `.${bookingCalendarLaneDefaultClasses.className}:not(.${bookingCalendarLanesHeaderDefaultClasses.laneClassName}) > .${bookingCalendarItemDefaultClasses.className}`;
203
+ const allItems = Array.from(
204
+ containerRef?.current?.querySelectorAll(itemSelector)
205
+ );
206
+ const selectionAreaBB = containerRef?.current
207
+ ?.querySelector(`.${bookingCalendarSelectionDefaultClasses.root}`)
208
+ .getBoundingClientRect();
209
+ const selectedItems = allItems.filter((item) => {
210
+ const itemBB = item.getBoundingClientRect();
211
+ const itemLeft = itemBB.left - selectionAreaBB.left;
212
+ const itemTop = itemBB.top - selectionAreaBB.top;
213
+ const itemRight = itemBB.right - selectionAreaBB.left;
214
+ const itemBottom = itemBB.bottom - selectionAreaBB.top;
215
+ // check if at least one corner of the item is inside the screenSpace
216
+ return (
217
+ (screenSpaceStartX <= itemLeft &&
218
+ itemLeft <= screenSpaceEndX &&
219
+ screenSpaceStartY <= itemTop &&
220
+ itemTop <= screenSpaceEndY) ||
221
+ (screenSpaceStartX <= itemRight &&
222
+ itemRight <= screenSpaceEndX &&
223
+ screenSpaceStartY <= itemTop &&
224
+ itemTop <= screenSpaceEndY) ||
225
+ (screenSpaceStartX <= itemLeft &&
226
+ itemLeft <= screenSpaceEndX &&
227
+ screenSpaceStartY <= itemBottom &&
228
+ itemBottom <= screenSpaceEndY) ||
229
+ (screenSpaceStartX <= itemRight &&
230
+ itemRight <= screenSpaceEndX &&
231
+ screenSpaceStartY <= itemBottom &&
232
+ itemBottom <= screenSpaceEndY)
233
+ );
234
+ });
235
+ const selectedIds = selectedItems.map((item) =>
236
+ item.getAttribute('data-id')
237
+ );
238
+ onSelection(
239
+ bookings?.filter((b) => selectedIds.includes(b.id?.toString())),
240
+ timeSpaceStart,
241
+ timeSpaceEnd,
242
+ e
243
+ );
244
+ }
245
+ },
246
+ [
247
+ from,
248
+ till,
249
+ width,
250
+ onRangeChange,
251
+ onSelection,
252
+ onSelection ? bookings : null,
253
+ ]
254
+ );
255
+ return (
256
+ <div
257
+ className={classNames(bookingCalendarDefaultClasses.className, className)}
258
+ ref={containerRef}
259
+ >
260
+ <BookingCalendarControls<T>
261
+ {...controlsClasses}
262
+ items={bookings}
263
+ from={from}
264
+ till={till}
265
+ onRangeChange={onRangeChange}
266
+ step={step}
267
+ filterBookingsToZoom={filterBookingsToZoom}
268
+ zoomLevels={zoomLevels}
269
+ filteringButton={filteringButton}
270
+ showZoomAllButton={showZoomAllButton}
271
+ bookingCalendarDatePicker={
272
+ <>
273
+ {typeof BookingCalendarDatePicker === 'function' ? (
274
+ <BookingCalendarDatePicker
275
+ from={from}
276
+ till={till}
277
+ onRangeChange={onRangeChange}
278
+ getNewMomentFunction={getNewMomentFunction}
279
+ />
280
+ ) : (
281
+ BookingCalendarDatePicker
282
+ )}
283
+ </>
284
+ }
285
+ />
286
+ <div
287
+ className={classNames(
288
+ bookingCalendarDefaultClasses.tableClassName,
289
+ tableClassName
290
+ )}
291
+ >
292
+ {showGrid && (
293
+ <BookingCalendarGrid
294
+ items={gridItems}
295
+ dataRowsCount={lanes.length}
296
+ width={width}
297
+ />
298
+ )}
299
+ {showSelection && (
300
+ <BookingCalendarSelection
301
+ dataRowsCount={lanes.length}
302
+ onSelected={onSelected}
303
+ minSelectionSize={minSelectionSize}
304
+ >
305
+ {selectionContent}
306
+ </BookingCalendarSelection>
307
+ )}
308
+ <div
309
+ className={classNames(
310
+ bookingCalendarDefaultClasses.lanesHeaderHeaderContainerClassName,
311
+ lanesHeaderHeaderContainerClassName
312
+ )}
313
+ >
314
+ {bookingCalendarTopLeftHeader}
315
+ </div>
316
+ <div
317
+ className={classNames(
318
+ bookingCalendarDefaultClasses.lanesHeaderContainerClassName,
319
+ lanesHeaderContainerClassName
320
+ )}
321
+ ref={observe}
322
+ >
323
+ <BookingCalendarLanesHeader<T>
324
+ {...controlsClasses}
325
+ from={from}
326
+ till={till}
327
+ onRangeChange={onRangeChange}
328
+ step={step}
329
+ />
330
+ </div>
331
+
332
+ {lanes.map((lane, laneIndex) => {
333
+ const LaneBookingCalendarLaneHeader =
334
+ lane.BookingCalendarLaneHeader ?? BookingCalendarLaneHeader;
335
+ const LaneBookingCalendarLane =
336
+ lane.BookingCalendarLane ?? BookingCalendarLane;
337
+ return (
338
+ <React.Fragment key={laneIndex}>
339
+ <div
340
+ className={classNames(
341
+ bookingCalendarDefaultClasses.laneHeaderContainerClassName,
342
+ laneHeaderContainerClassName,
343
+ lane.rowClassName,
344
+ {
345
+ [`${bookingCalendarDefaultClasses.laneHeaderContainerClassName}--last`]:
346
+ laneIndex === lanes.length - 1,
347
+ [`${bookingCalendarDefaultClasses.laneHeaderContainerClassName}--first`]:
348
+ laneIndex === 0,
349
+ }
350
+ )}
351
+ >
352
+ <LaneBookingCalendarLaneHeader<TLaneData>
353
+ laneKey={lane.laneKey ?? laneIndex}
354
+ data={lane.data}
355
+ />
356
+ </div>
357
+ <div
358
+ className={classNames(
359
+ bookingCalendarDefaultClasses.laneContainerClassName,
360
+ laneContainerClassName,
361
+ lane.rowClassName,
362
+ {
363
+ [`${bookingCalendarDefaultClasses.laneContainerClassName}--last`]:
364
+ laneIndex === lanes.length - 1,
365
+ [`${bookingCalendarDefaultClasses.laneContainerClassName}--first`]:
366
+ laneIndex === 0,
367
+ }
368
+ )}
369
+ >
370
+ <LaneBookingCalendarLane
371
+ laneIndex={laneIndex}
372
+ items={lane.items}
373
+ from={from}
374
+ till={till}
375
+ BookingCalendarItem={
376
+ lane.BookingCalendarItem ?? BookingCalendarItem
377
+ }
378
+ BookingCalendarRenderItem={
379
+ lane.BookingCalendarRenderItem ?? BookingCalendarRenderItem
380
+ }
381
+ step={step}
382
+ />
383
+ </div>
384
+ </React.Fragment>
385
+ );
386
+ })}
387
+ <div />
388
+ <div>
389
+ <BookingCalendarTimeAxis
390
+ items={gridItems}
391
+ bestStep={bestStep}
392
+ getMomentFormatFunction={getMomentFormatFunction}
393
+ />
394
+ </div>
395
+ </div>
396
+ {children}
397
+ </div>
398
+ );
399
+ }
@@ -0,0 +1,249 @@
1
+ import classNames from 'classnames';
2
+ import * as React from 'react';
3
+ import {
4
+ BookingCalendarDateRange,
5
+ BookingCalendarItemT,
6
+ ZoomLevel,
7
+ } from '../common';
8
+ import moment, { Duration, Moment } from 'moment';
9
+ import { BookingCalendarControlsClasses } from './classes';
10
+ import { bookingCalendarControlsDefaultClasses } from './classes';
11
+ import { Button } from '../../button/Button';
12
+ import * as LeftArrowLongIcon from 'material-design-icons/navigation/svg/production/ic_arrow_back_24px.svg';
13
+ import * as LeftArrowIcon from 'material-design-icons/hardware/svg/production/ic_keyboard_arrow_left_24px.svg';
14
+ import * as RightArrowLongIcon from 'material-design-icons/navigation/svg/production/ic_arrow_forward_24px.svg';
15
+ import * as RightArrowIcon from 'material-design-icons/hardware/svg/production/ic_keyboard_arrow_right_24px.svg';
16
+ import * as UnfoldLessIcon from 'material-design-icons/navigation/svg/production/ic_unfold_less_24px.svg';
17
+ import * as DateRangeIcon from 'material-design-icons/action/svg/production/ic_date_range_24px.svg';
18
+
19
+ import Menu from '@mui/material/Menu';
20
+ import MenuItem from '@mui/material/MenuItem';
21
+
22
+ export interface BookingCalendarControlsProps<T extends BookingCalendarItemT>
23
+ extends BookingCalendarControlsClasses {
24
+ items: T[];
25
+ step: Duration;
26
+ from: Moment;
27
+ till: Moment;
28
+ zoomLevels?: ZoomLevel[];
29
+ onRangeChange?: (range: BookingCalendarDateRange) => void;
30
+ filterBookingsToZoom?: (booking: T) => boolean;
31
+ bookingCalendarDatePicker?: React.ReactNode;
32
+ filteringButton?: React.ReactNode;
33
+ showZoomAllButton?: boolean;
34
+ }
35
+
36
+ export function BookingCalendarControls<T extends BookingCalendarItemT>(
37
+ props: BookingCalendarControlsProps<T>
38
+ ) {
39
+ const {
40
+ className,
41
+ monthLabelClassName,
42
+ buttonsContainerClassName,
43
+ zoomBookingsButtonClassName,
44
+ zoomLevelsContainerClassName,
45
+ zoomLevelsButtonClassName,
46
+ zoomLevels,
47
+ step,
48
+ from,
49
+ till,
50
+ onRangeChange,
51
+ items,
52
+ filterBookingsToZoom = () => true,
53
+ bookingCalendarDatePicker,
54
+ filteringButton,
55
+ showZoomAllButton,
56
+ } = props;
57
+ if (!step || !from || !till) {
58
+ return null;
59
+ }
60
+ const onStepFactory = React.useCallback(
61
+ (_step: Duration) => () =>
62
+ onRangeChange({
63
+ from: from.clone().add(_step),
64
+ till: till.clone().add(_step),
65
+ }),
66
+ [from, till, onRangeChange]
67
+ );
68
+ const onBigStepLeftClick = React.useCallback(
69
+ onStepFactory(moment.duration(-7, 'days')),
70
+ [onStepFactory, till, from]
71
+ );
72
+ const onSmallStepLeftClick = React.useCallback(
73
+ onStepFactory(moment.duration(-1, 'day')),
74
+ [onStepFactory, step]
75
+ );
76
+ const onBigStepRightClick = React.useCallback(
77
+ onStepFactory(moment.duration(7, 'days')),
78
+ [onStepFactory, till, from]
79
+ );
80
+ const onSmallStepRightClick = React.useCallback(
81
+ onStepFactory(moment.duration(1, 'day')),
82
+ [onStepFactory, step]
83
+ );
84
+ const filteredItems = React.useMemo(
85
+ () => items?.filter(filterBookingsToZoom),
86
+ [filterBookingsToZoom, items]
87
+ );
88
+ const onZoomBookingsClick = React.useCallback(() => {
89
+ const minFromMs =
90
+ Math.min(
91
+ ...filteredItems
92
+ ?.filter(filterBookingsToZoom)
93
+ .map((a) => a.from.valueOf())
94
+ ) ?? from?.valueOf();
95
+ const minFrom = from.clone().subtract(from.valueOf() - minFromMs, 'ms');
96
+ const maxTillMs =
97
+ Math.max(
98
+ ...filteredItems
99
+ ?.filter(filterBookingsToZoom)
100
+ .map((a) => a.till.valueOf())
101
+ ) ?? till?.valueOf();
102
+ const maxTill = till.clone().subtract(till.valueOf() - maxTillMs, 'ms');
103
+ onRangeChange({
104
+ from: minFrom,
105
+ till: maxTill,
106
+ });
107
+ }, [from, till, filteredItems]);
108
+ const [anchorEl, setAnchorEl] = React.useState<null | HTMLElement>(null);
109
+ const open = Boolean(anchorEl);
110
+ const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {
111
+ setAnchorEl(event.currentTarget);
112
+ };
113
+ const handleClose = () => {
114
+ setAnchorEl(null);
115
+ };
116
+ const selectedLevel = React.useMemo(
117
+ () =>
118
+ zoomLevels?.find(
119
+ (level) =>
120
+ till.valueOf() - from.valueOf() === level.step.asMilliseconds()
121
+ ),
122
+ [zoomLevels, till, from]
123
+ );
124
+ return (
125
+ <div
126
+ className={classNames(
127
+ bookingCalendarControlsDefaultClasses.className,
128
+ className
129
+ )}
130
+ >
131
+ {bookingCalendarDatePicker && (
132
+ <div
133
+ className={classNames(
134
+ bookingCalendarControlsDefaultClasses.monthLabelClassName,
135
+ monthLabelClassName
136
+ )}
137
+ >
138
+ {bookingCalendarDatePicker}
139
+ </div>
140
+ )}
141
+ {zoomLevels?.length > 0 && (
142
+ <div
143
+ className={classNames(
144
+ bookingCalendarControlsDefaultClasses.zoomLevelsContainerClassName,
145
+ zoomLevelsContainerClassName
146
+ )}
147
+ >
148
+ <Button
149
+ id="zoom-level-button"
150
+ className={classNames(
151
+ bookingCalendarControlsDefaultClasses.zoomLevelsButtonClassName,
152
+ zoomLevelsButtonClassName
153
+ )}
154
+ aria-controls={open ? 'zoom-level-menu' : undefined}
155
+ aria-haspopup="true"
156
+ aria-expanded={open ? 'true' : undefined}
157
+ onClick={handleClick}
158
+ noShadow={true}
159
+ >
160
+ <DateRangeIcon />
161
+ {selectedLevel ? ` ${selectedLevel.label}` : ''}
162
+ </Button>
163
+ <Menu
164
+ id="zoom-level-menu"
165
+ anchorEl={anchorEl}
166
+ open={open}
167
+ onClose={handleClose}
168
+ MenuListProps={{
169
+ 'aria-labelledby': 'zoom-level-button',
170
+ }}
171
+ >
172
+ {zoomLevels.map((level, index) => (
173
+ <MenuItem
174
+ data-level={index}
175
+ key={index}
176
+ onClick={() => {
177
+ onRangeChange({
178
+ from: from.clone().startOf('day'),
179
+ till: from.clone().startOf('day').add(level.step),
180
+ });
181
+ setAnchorEl(null);
182
+ }}
183
+ selected={
184
+ till.valueOf() - from.valueOf() ===
185
+ level.step.asMilliseconds()
186
+ }
187
+ >
188
+ {level.label}
189
+ </MenuItem>
190
+ ))}
191
+ </Menu>
192
+ {/*zoomLevels.map((level, index) => (
193
+ <Button
194
+ type={
195
+ till.valueOf() - from.valueOf() === level.step.asMilliseconds()
196
+ ? 'primary'
197
+ : undefined
198
+ }
199
+ // blank={true}
200
+ noShadow={true}
201
+ key={index}
202
+ onClick={() =>
203
+ onRangeChange({
204
+ from: from.clone().startOf('day'),
205
+ till: from.clone().startOf('day').add(level.step),
206
+ })
207
+ }
208
+ >
209
+ {level.label}
210
+ </Button>
211
+ ))*/}
212
+ </div>
213
+ )}
214
+ <div
215
+ className={classNames(
216
+ bookingCalendarControlsDefaultClasses.buttonsContainerClassName,
217
+ buttonsContainerClassName
218
+ )}
219
+ >
220
+ <Button noShadow={true} onClick={onBigStepLeftClick}>
221
+ <LeftArrowLongIcon />
222
+ </Button>
223
+ <Button noShadow={true} onClick={onSmallStepLeftClick}>
224
+ <LeftArrowIcon />
225
+ </Button>
226
+ <Button noShadow={true} onClick={onSmallStepRightClick}>
227
+ <RightArrowIcon />
228
+ </Button>
229
+ <Button noShadow={true} onClick={onBigStepRightClick}>
230
+ <RightArrowLongIcon />
231
+ </Button>
232
+ {showZoomAllButton && (
233
+ <Button
234
+ className={classNames(
235
+ bookingCalendarControlsDefaultClasses.zoomBookingsButtonClassName,
236
+ zoomBookingsButtonClassName
237
+ )}
238
+ noShadow={true}
239
+ disabled={!filteredItems?.length}
240
+ onClick={onZoomBookingsClick}
241
+ >
242
+ <UnfoldLessIcon />
243
+ </Button>
244
+ )}
245
+ {filteringButton}
246
+ </div>
247
+ </div>
248
+ );
249
+ }
@@ -0,0 +1,20 @@
1
+ export interface BookingCalendarControlsClasses {
2
+ className?: string;
3
+ monthLabelClassName?: string;
4
+ zoomLevelsContainerClassName?: string;
5
+ buttonsContainerClassName?: string;
6
+ zoomBookingsButtonClassName?: string;
7
+ zoomLevelsButtonClassName?: string;
8
+ }
9
+
10
+ export const bookingCalendarControlsDefaultClasses: BookingCalendarControlsClasses =
11
+ {
12
+ className: 'bookingCalendar__controls',
13
+ monthLabelClassName: 'bookingCalendar__controls__monthLabel',
14
+ buttonsContainerClassName: 'bookingCalendar__controls__buttonsContainer',
15
+ zoomLevelsContainerClassName:
16
+ 'bookingCalendar__controls__zoomLevelsContainer',
17
+ zoomBookingsButtonClassName:
18
+ 'bookingCalendar__controls__zoomBookingsButton',
19
+ zoomLevelsButtonClassName: 'bookingCalendar__controls__zoomLevelsButton',
20
+ };
@@ -0,0 +1,2 @@
1
+ export * from './BookingCalendarControls';
2
+ export * from './classes';