guestbell-forms 3.0.38 → 3.0.40

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 (336) 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 +45 -46
  8. package/build/components/bookingCalendar/BookingCalendar.js +4 -5
  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/classes.d.ts +4 -4
  24. package/build/components/bookingCalendar/bookingCalendarItem/index.d.ts +2 -2
  25. package/build/components/bookingCalendar/bookingCalendarLane/BookingCalendarLane.d.ts +16 -16
  26. package/build/components/bookingCalendar/bookingCalendarLane/classes.d.ts +4 -4
  27. package/build/components/bookingCalendar/bookingCalendarLane/index.d.ts +2 -2
  28. package/build/components/bookingCalendar/bookingCalendarLaneHeader/BookingCalendarLaneHeader.d.ts +7 -7
  29. package/build/components/bookingCalendar/bookingCalendarLaneHeader/classes.d.ts +4 -4
  30. package/build/components/bookingCalendar/bookingCalendarLaneHeader/index.d.ts +1 -1
  31. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.d.ts +11 -11
  32. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.js +3 -3
  33. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.js.map +1 -1
  34. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeaderRenderItem.d.ts +4 -5
  35. package/build/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeaderRenderItem.js.map +1 -1
  36. package/build/components/bookingCalendar/bookingCalendarLanesHeader/classes.d.ts +5 -5
  37. package/build/components/bookingCalendar/bookingCalendarLanesHeader/index.d.ts +2 -2
  38. package/build/components/bookingCalendar/bookingCalendarRenderItem/BookingCalendarRenderItem.d.ts +9 -9
  39. package/build/components/bookingCalendar/bookingCalendarRenderItem/classes.d.ts +6 -6
  40. package/build/components/bookingCalendar/bookingCalendarRenderItem/index.d.ts +1 -1
  41. package/build/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.d.ts +38 -37
  42. package/build/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.js +2 -0
  43. package/build/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.js.map +1 -1
  44. package/build/components/bookingCalendar/bookingCalendarTimeAxis/BookingCalendarTimeAxis.d.ts +11 -11
  45. package/build/components/bookingCalendar/bookingCalendarTimeAxis/classes.d.ts +5 -5
  46. package/build/components/bookingCalendar/classes.d.ts +11 -11
  47. package/build/components/bookingCalendar/common.d.ts +23 -23
  48. package/build/components/bookingCalendar/common.js +3 -4
  49. package/build/components/bookingCalendar/common.js.map +1 -1
  50. package/build/components/bookingCalendar/index.d.ts +3 -3
  51. package/build/components/bookingCalendar/utils.d.ts +52 -50
  52. package/build/components/bookingCalendar/utils.js.map +1 -1
  53. package/build/components/button/Button.d.ts +81 -81
  54. package/build/components/button/Button.js +1 -0
  55. package/build/components/button/Button.js.map +1 -1
  56. package/build/components/button/index.d.ts +2 -2
  57. package/build/components/checkbox/Checkbox.d.ts +23 -23
  58. package/build/components/checkbox/index.d.ts +2 -2
  59. package/build/components/dropdown/Dropdown.d.ts +44 -44
  60. package/build/components/dropdown/index.d.ts +2 -2
  61. package/build/components/dynamicSubmit/DynamicSubmit.d.ts +54 -54
  62. package/build/components/dynamicSubmit/DynamicSubmit.js.map +1 -1
  63. package/build/components/dynamicSubmit/index.d.ts +2 -2
  64. package/build/components/externalValidationComponent/ExternalValidationComponent.d.ts +15 -15
  65. package/build/components/externalValidationComponent/index.d.ts +2 -2
  66. package/build/components/form/Form.d.ts +47 -47
  67. package/build/components/form/FormContext.d.ts +30 -30
  68. package/build/components/form/FormValidationSummary.d.ts +38 -38
  69. package/build/components/form/FormValidationSummary.js.map +1 -1
  70. package/build/components/form/index.d.ts +5 -5
  71. package/build/components/form/withFormContext.d.ts +3 -3
  72. package/build/components/inputGroup/InputGroup.d.ts +15 -17
  73. package/build/components/inputGroup/index.d.ts +2 -2
  74. package/build/components/inputHeader/InputHeader.d.ts +97 -97
  75. package/build/components/inputHeader/InputHeader.js.map +1 -1
  76. package/build/components/inputHeader/InputHeaderContext.d.ts +24 -24
  77. package/build/components/inputHeader/index.d.ts +2 -2
  78. package/build/components/inputHeader/withInputHeaderContext.d.ts +3 -3
  79. package/build/components/money/Money.d.ts +78 -78
  80. package/build/components/money/Money.js.map +1 -1
  81. package/build/components/money/index.d.ts +2 -2
  82. package/build/components/numberInput/NumberInput.d.ts +28 -28
  83. package/build/components/numberInput/index.d.ts +2 -2
  84. package/build/components/openingHours/openingHoursDay/OpeningHoursDay.d.ts +84 -84
  85. package/build/components/openingHours/openingHoursDay/OpeningHoursDay.js +3 -3
  86. package/build/components/openingHours/openingHoursDay/OpeningHoursDay.js.map +1 -1
  87. package/build/components/openingHours/openingHoursDay/index.d.ts +2 -2
  88. package/build/components/openingHours/openingHoursSpecial/OpeningHoursSpecial.d.ts +92 -90
  89. package/build/components/openingHours/openingHoursSpecial/OpeningHoursSpecial.js.map +1 -1
  90. package/build/components/openingHours/openingHoursSpecial/index.d.ts +2 -2
  91. package/build/components/openingHours/openingHoursWeek/OpeningHoursWeek.d.ts +109 -109
  92. package/build/components/openingHours/openingHoursWeek/index.d.ts +2 -2
  93. package/build/components/openingHours/utils/OpeningHoursUtil.d.ts +21 -21
  94. package/build/components/radio/Radio.d.ts +20 -20
  95. package/build/components/radio/index.d.ts +2 -2
  96. package/build/components/radioContainer/RadioContainer.d.ts +17 -16
  97. package/build/components/radioContainer/RadioContainer.js.map +1 -1
  98. package/build/components/radioContainer/index.d.ts +2 -2
  99. package/build/components/select/Select.d.ts +79 -79
  100. package/build/components/select/index.d.ts +2 -2
  101. package/build/components/submit/Submit.d.ts +137 -137
  102. package/build/components/submit/index.d.ts +2 -2
  103. package/build/components/submit/subComponents/SubmitValidationSummary.d.ts +5 -5
  104. package/build/components/tags/Tags.d.ts +92 -92
  105. package/build/components/tags/Tags.js +2 -0
  106. package/build/components/tags/Tags.js.map +1 -1
  107. package/build/components/tags/index.d.ts +2 -2
  108. package/build/components/tags/subComponents/TagsSuggestions.d.ts +34 -34
  109. package/build/components/tags/subComponents/TagsSuggestions.js +2 -2
  110. package/build/components/tags/subComponents/TagsSuggestions.js.map +1 -1
  111. package/build/components/text/Text.d.ts +31 -31
  112. package/build/components/text/index.d.ts +2 -2
  113. package/build/components/textArea/TextArea.d.ts +28 -28
  114. package/build/components/textArea/TextArea.js +1 -0
  115. package/build/components/textArea/TextArea.js.map +1 -1
  116. package/build/components/textArea/index.d.ts +2 -2
  117. package/build/components/themeProvider/ThemeContext.d.ts +9 -9
  118. package/build/components/themeProvider/ThemeProvider.d.ts +8 -7
  119. package/build/components/themeProvider/ThemeProvider.js.map +1 -1
  120. package/build/components/themeProvider/index.d.ts +4 -4
  121. package/build/components/themeProvider/withThemeContext.d.ts +4 -4
  122. package/build/components/time/Time.d.ts +32 -32
  123. package/build/components/time/Time.js +3 -3
  124. package/build/components/time/Time.js.map +1 -1
  125. package/build/components/time/index.d.ts +2 -2
  126. package/build/components/timeSpan/TimeSpan.d.ts +46 -46
  127. package/build/components/timeSpan/TimeSpan.js +6 -6
  128. package/build/components/timeSpan/TimeSpan.js.map +1 -1
  129. package/build/components/timeSpan/index.d.ts +2 -2
  130. package/build/components/utils/Guid.d.ts +2 -2
  131. package/build/components/utils/ShallowEqual.d.ts +16 -16
  132. package/build/components/utils/TimeUtil.d.ts +6 -6
  133. package/build/components/utils/Typescript.d.ts +5 -5
  134. package/build/dist/guestbell-forms.css +157 -171
  135. package/build/dist/guestbell-forms.css.map +1 -1
  136. package/build/dist/guestbell-forms.js +15 -24
  137. package/build/dist/guestbell-forms.js.map +1 -1
  138. package/build/dist/guestbell-forms.min.css +1 -1
  139. package/build/dist/guestbell-forms.min.js +1 -1
  140. package/build/dist/guestbell-forms.min.js.map +1 -1
  141. package/build/dist/report.html +3 -3
  142. package/build/index.d.ts +24 -24
  143. package/build/scss/components/bookingCalendar/bookingCalendar.scss +30 -7
  144. package/build/scss/components/inputHeader/inputHeader.scss +7 -1
  145. package/build/types/ElementOverrideProp.d.ts +3 -3
  146. package/build/types/Theme.d.ts +4 -4
  147. package/build/types/ThemeOverrides.d.ts +45 -45
  148. package/build/validators/EmailValidator.d.ts +4 -4
  149. package/build/validators/LatitudeValidator.d.ts +4 -4
  150. package/build/validators/LongitudeValidator.d.ts +4 -4
  151. package/build/validators/NumberValidator.d.ts +12 -12
  152. package/build/validators/NumberValidator.js +1 -0
  153. package/build/validators/NumberValidator.js.map +1 -1
  154. package/build/validators/UrlValidator.d.ts +4 -4
  155. package/build/validators/base.d.ts +4 -4
  156. package/build/validators/index.d.ts +6 -6
  157. package/package.json +130 -136
  158. package/src/lib/components/base/input/BaseInput.tsx +526 -0
  159. package/src/lib/components/base/input/index.tsx +1 -0
  160. package/src/lib/components/bookingCalendar/BookingCalendar.tsx +327 -0
  161. package/src/lib/components/bookingCalendar/bookingCalendarControls/BookingCalendarControls.tsx +249 -0
  162. package/src/lib/components/bookingCalendar/bookingCalendarControls/classes.ts +20 -0
  163. package/src/lib/components/bookingCalendar/bookingCalendarControls/index.ts +2 -0
  164. package/src/lib/components/bookingCalendar/bookingCalendarDatePicker/BookingCalendarDatePicker.tsx +104 -0
  165. package/src/lib/components/bookingCalendar/bookingCalendarDatePicker/classes.ts +9 -0
  166. package/src/lib/components/bookingCalendar/bookingCalendarDatePicker/index.ts +2 -0
  167. package/src/lib/components/bookingCalendar/bookingCalendarGrid/BookingCalendarGrid.tsx +56 -0
  168. package/src/lib/components/bookingCalendar/bookingCalendarGrid/classes.ts +9 -0
  169. package/src/lib/components/bookingCalendar/bookingCalendarItem/BookingCalendarItem.tsx +97 -0
  170. package/src/lib/components/bookingCalendar/bookingCalendarItem/classes.ts +7 -0
  171. package/src/lib/components/bookingCalendar/bookingCalendarItem/index.ts +2 -0
  172. package/src/lib/components/bookingCalendar/bookingCalendarLane/BookingCalendarLane.tsx +69 -0
  173. package/src/lib/components/bookingCalendar/bookingCalendarLane/classes.ts +7 -0
  174. package/src/lib/components/bookingCalendar/bookingCalendarLane/index.ts +2 -0
  175. package/src/lib/components/bookingCalendar/bookingCalendarLaneHeader/BookingCalendarLaneHeader.tsx +28 -0
  176. package/src/lib/components/bookingCalendar/bookingCalendarLaneHeader/classes.ts +7 -0
  177. package/src/lib/components/bookingCalendar/bookingCalendarLaneHeader/index.ts +1 -0
  178. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeader.tsx +57 -0
  179. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/BookingCalendarLanesHeaderRenderItem.tsx +53 -0
  180. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/classes.ts +9 -0
  181. package/src/lib/components/bookingCalendar/bookingCalendarLanesHeader/index.ts +2 -0
  182. package/src/lib/components/bookingCalendar/bookingCalendarRenderItem/BookingCalendarRenderItem.tsx +57 -0
  183. package/src/lib/components/bookingCalendar/bookingCalendarRenderItem/classes.ts +11 -0
  184. package/src/lib/components/bookingCalendar/bookingCalendarRenderItem/index.ts +1 -0
  185. package/src/lib/components/bookingCalendar/bookingCalendarSelection/BookingCalendarSelection.tsx +217 -0
  186. package/src/lib/components/bookingCalendar/bookingCalendarTimeAxis/BookingCalendarTimeAxis.tsx +53 -0
  187. package/src/lib/components/bookingCalendar/bookingCalendarTimeAxis/classes.ts +9 -0
  188. package/src/lib/components/bookingCalendar/classes.ts +21 -0
  189. package/src/lib/components/bookingCalendar/common.ts +61 -0
  190. package/src/lib/components/bookingCalendar/index.ts +3 -0
  191. package/src/lib/components/bookingCalendar/utils.ts +348 -0
  192. package/src/lib/components/button/Button.tsx +193 -0
  193. package/src/lib/components/button/index.tsx +2 -0
  194. package/src/lib/components/checkbox/Checkbox.tsx +178 -0
  195. package/src/lib/components/checkbox/index.tsx +2 -0
  196. package/src/lib/components/dropdown/Dropdown.tsx +135 -0
  197. package/src/lib/components/dropdown/index.tsx +2 -0
  198. package/src/lib/components/dynamicSubmit/DynamicSubmit.tsx +153 -0
  199. package/src/lib/components/dynamicSubmit/index.tsx +2 -0
  200. package/src/lib/components/externalValidationComponent/ExternalValidationComponent.tsx +78 -0
  201. package/src/lib/components/externalValidationComponent/index.tsx +2 -0
  202. package/src/lib/components/form/Form.tsx +276 -0
  203. package/src/lib/components/form/FormContext.ts +49 -0
  204. package/src/lib/components/form/FormValidationSummary.tsx +122 -0
  205. package/src/lib/components/form/index.tsx +5 -0
  206. package/src/lib/components/form/withFormContext.tsx +20 -0
  207. package/src/lib/components/inputGroup/InputGroup.tsx +60 -0
  208. package/src/lib/components/inputGroup/index.tsx +2 -0
  209. package/src/lib/components/inputHeader/InputHeader.tsx +448 -0
  210. package/src/lib/components/inputHeader/InputHeaderContext.ts +42 -0
  211. package/src/lib/components/inputHeader/index.tsx +2 -0
  212. package/src/lib/components/inputHeader/withInputHeaderContext.tsx +24 -0
  213. package/src/lib/components/money/Money.tsx +298 -0
  214. package/src/lib/components/money/index.tsx +2 -0
  215. package/src/lib/components/numberInput/NumberInput.tsx +186 -0
  216. package/src/lib/components/numberInput/index.tsx +2 -0
  217. package/src/lib/components/openingHours/openingHoursDay/OpeningHoursDay.tsx +394 -0
  218. package/src/lib/components/openingHours/openingHoursDay/index.tsx +2 -0
  219. package/src/lib/components/openingHours/openingHoursSpecial/OpeningHoursSpecial.tsx +227 -0
  220. package/src/lib/components/openingHours/openingHoursSpecial/index.tsx +2 -0
  221. package/src/lib/components/openingHours/openingHoursWeek/OpeningHoursWeek.tsx +283 -0
  222. package/src/lib/components/openingHours/openingHoursWeek/index.tsx +2 -0
  223. package/src/lib/components/openingHours/utils/OpeningHoursUtil.tsx +111 -0
  224. package/src/lib/components/radio/Radio.tsx +87 -0
  225. package/src/lib/components/radio/index.tsx +2 -0
  226. package/src/lib/components/radioContainer/RadioContainer.tsx +50 -0
  227. package/src/lib/components/radioContainer/index.tsx +2 -0
  228. package/src/lib/components/select/Select.tsx +335 -0
  229. package/src/lib/components/select/index.tsx +2 -0
  230. package/src/lib/components/submit/Submit.tsx +117 -0
  231. package/src/lib/components/submit/index.tsx +2 -0
  232. package/src/lib/components/submit/subComponents/SubmitValidationSummary.tsx +55 -0
  233. package/src/lib/components/tags/Tags.tsx +702 -0
  234. package/src/lib/components/tags/index.tsx +2 -0
  235. package/src/lib/components/tags/subComponents/TagsSuggestions.tsx +150 -0
  236. package/src/lib/components/text/Text.tsx +200 -0
  237. package/src/lib/components/text/index.tsx +2 -0
  238. package/src/lib/components/textArea/TextArea.tsx +109 -0
  239. package/src/lib/components/textArea/index.tsx +2 -0
  240. package/src/lib/components/themeProvider/ThemeContext.ts +16 -0
  241. package/src/lib/components/themeProvider/ThemeProvider.tsx +21 -0
  242. package/src/lib/components/themeProvider/index.tsx +4 -0
  243. package/src/lib/components/themeProvider/withThemeContext.tsx +30 -0
  244. package/src/lib/components/time/Time.tsx +296 -0
  245. package/src/lib/components/time/index.tsx +2 -0
  246. package/src/lib/components/timeSpan/TimeSpan.tsx +378 -0
  247. package/src/lib/components/timeSpan/index.tsx +2 -0
  248. package/src/lib/components/utils/Guid.ts +9 -0
  249. package/src/lib/components/utils/ShallowEqual.ts +75 -0
  250. package/src/lib/components/utils/TimeUtil.ts +22 -0
  251. package/src/lib/components/utils/Typescript.ts +11 -0
  252. package/src/lib/declarations/import.d.ts +1 -0
  253. package/src/lib/index.ts +24 -0
  254. package/src/lib/scss/components/base/index.scss +1 -0
  255. package/src/lib/scss/components/base/input/index.scss +1 -0
  256. package/src/lib/scss/components/base/input/input.scss +237 -0
  257. package/src/lib/scss/components/bookingCalendar/bookingCalendar.scss +272 -0
  258. package/src/lib/scss/components/bookingCalendar/index.scss +1 -0
  259. package/src/lib/scss/components/button/buttons.scss +161 -0
  260. package/src/lib/scss/components/button/index.scss +1 -0
  261. package/src/lib/scss/components/checkbox/checkbox.scss +115 -0
  262. package/src/lib/scss/components/checkbox/index.scss +1 -0
  263. package/src/lib/scss/components/dropdown/dropdown.scss +111 -0
  264. package/src/lib/scss/components/dropdown/index.scss +1 -0
  265. package/src/lib/scss/components/dynamicSubmit/dynamicSubmit.scss +1 -0
  266. package/src/lib/scss/components/dynamicSubmit/index.scss +1 -0
  267. package/src/lib/scss/components/form/form.scss +1 -0
  268. package/src/lib/scss/components/form/formValidationSummary.scss +55 -0
  269. package/src/lib/scss/components/form/index.scss +2 -0
  270. package/src/lib/scss/components/index.scss +21 -0
  271. package/src/lib/scss/components/inputGroup/index.scss +1 -0
  272. package/src/lib/scss/components/inputGroup/inputGroup.scss +67 -0
  273. package/src/lib/scss/components/inputHeader/index.scss +1 -0
  274. package/src/lib/scss/components/inputHeader/inputHeader.scss +132 -0
  275. package/src/lib/scss/components/money/index.scss +1 -0
  276. package/src/lib/scss/components/money/money.scss +51 -0
  277. package/src/lib/scss/components/numberInput/index.scss +1 -0
  278. package/src/lib/scss/components/numberInput/numberInput.scss +116 -0
  279. package/src/lib/scss/components/openingHours/index.scss +3 -0
  280. package/src/lib/scss/components/openingHours/openingHoursDay/index.scss +1 -0
  281. package/src/lib/scss/components/openingHours/openingHoursDay/openingHoursDay.scss +127 -0
  282. package/src/lib/scss/components/openingHours/openingHoursSpecial/index.scss +1 -0
  283. package/src/lib/scss/components/openingHours/openingHoursSpecial/openingHoursSpecial.scss +93 -0
  284. package/src/lib/scss/components/openingHours/openingHoursWeek/index.scss +1 -0
  285. package/src/lib/scss/components/openingHours/openingHoursWeek/openingHoursWeek.scss +23 -0
  286. package/src/lib/scss/components/radio/index.scss +1 -0
  287. package/src/lib/scss/components/radio/radio.scss +68 -0
  288. package/src/lib/scss/components/radioContainer/index.scss +1 -0
  289. package/src/lib/scss/components/radioContainer/radioContainer.scss +15 -0
  290. package/src/lib/scss/components/select/index.scss +1 -0
  291. package/src/lib/scss/components/select/select.scss +64 -0
  292. package/src/lib/scss/components/submit/index.scss +1 -0
  293. package/src/lib/scss/components/submit/submitValidationSummary.scss +35 -0
  294. package/src/lib/scss/components/tags/index.scss +1 -0
  295. package/src/lib/scss/components/tags/tags.scss +128 -0
  296. package/src/lib/scss/components/text/index.scss +1 -0
  297. package/src/lib/scss/components/text/text.scss +42 -0
  298. package/src/lib/scss/components/textArea/index.scss +1 -0
  299. package/src/lib/scss/components/textArea/textArea.scss +32 -0
  300. package/src/lib/scss/components/time/index.scss +1 -0
  301. package/src/lib/scss/components/time/time.scss +111 -0
  302. package/src/lib/scss/components/timeSpan/index.scss +1 -0
  303. package/src/lib/scss/components/timeSpan/timeSpan.scss +115 -0
  304. package/src/lib/scss/index.scss +8 -0
  305. package/src/lib/scss/styles/base.scss +7 -0
  306. package/src/lib/scss/styles/index.scss +2 -0
  307. package/src/lib/scss/styles/react-tippy.scss +4 -0
  308. package/src/lib/scss/variables/_buttons.scss +6 -0
  309. package/src/lib/scss/variables/_colors.scss +1 -0
  310. package/src/lib/scss/variables/_common.scss +12 -0
  311. package/src/lib/tsconfig.json +19 -0
  312. package/src/lib/types/ElementOverrideProp.ts +3 -0
  313. package/src/lib/types/Theme.ts +5 -0
  314. package/src/lib/types/ThemeOverrides.ts +46 -0
  315. package/src/lib/validators/EmailValidator.ts +15 -0
  316. package/src/lib/validators/LatitudeValidator.ts +25 -0
  317. package/src/lib/validators/LongitudeValidator.ts +25 -0
  318. package/src/lib/validators/NumberValidator.ts +50 -0
  319. package/src/lib/validators/UrlValidator.ts +20 -0
  320. package/src/lib/validators/base.ts +15 -0
  321. package/src/lib/validators/index.ts +6 -0
  322. package/src/stories/Basic.stories.ts +17 -0
  323. package/src/stories/Basic.tsx +1065 -0
  324. package/src/stories/Schedule.stories.ts +16 -0
  325. package/src/stories/Schedule.tsx +73 -0
  326. package/src/stories/ValidationPage.tsx +417 -0
  327. package/tsconfig.json +9 -22
  328. package/typedoc.json +6 -0
  329. package/webpack/webpack.config.base.js +139 -0
  330. package/webpack/webpack.config.dev.js +78 -0
  331. package/webpack/webpack.config.gh-pages.js +78 -0
  332. package/webpack/webpack.config.js +21 -0
  333. package/webpack/webpack.config.min.js +100 -0
  334. package/.vscode/launch.json +0 -15
  335. package/.vscode/settings.json +0 -27
  336. package/.vscode/tasks.json +0 -12
@@ -0,0 +1,327 @@
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 { BookingCalendarItemProps } from './bookingCalendarItem';
32
+ import { BookingCalendarRenderItemProps } from './bookingCalendarRenderItem';
33
+ import {
34
+ BookingCalendarGrid as DefaultBookingCalendarGrid,
35
+ BookingCalendarGridProps,
36
+ } from './bookingCalendarGrid/BookingCalendarGrid';
37
+ import {
38
+ BookingCalendarLaneHeader as DefaultBookingCalendarLaneHeader,
39
+ BookingCalendarLaneHeaderProps,
40
+ } from './bookingCalendarLaneHeader';
41
+ import {
42
+ BookingCalendarLanesHeader as DefaultBookingCalendarLanesHeader,
43
+ BookingCalendarLanesHeaderProps,
44
+ } from './bookingCalendarLanesHeader';
45
+ import {
46
+ BookingCalendarDatePicker as DefaultBookingCalendarDatePicker,
47
+ BookingCalendarDatePickerProps,
48
+ } from './bookingCalendarDatePicker';
49
+ import { BookingCalendarTimeAxis } from './bookingCalendarTimeAxis/BookingCalendarTimeAxis';
50
+ import useDimensions from 'react-cool-dimensions';
51
+ import BookingCalendarSelection, {
52
+ BookingCalendarSelectionData,
53
+ } from './bookingCalendarSelection/BookingCalendarSelection';
54
+
55
+ export interface BookingCalendarProps<T extends BookingCalendarItemT, TLaneData>
56
+ extends BookingCalendarClasses {
57
+ bookings: T[];
58
+ from: Moment;
59
+ till: Moment;
60
+ getMomentFormatFunction?: GetMomentFormatFunctionType;
61
+ getNewMomentFunction?: GetNewMomentFunctionType;
62
+ onRangeChange?: (range: BookingCalendarDateRange) => void;
63
+ step?: Duration;
64
+ showZoomAllButton?: boolean;
65
+ showGrid?: boolean;
66
+ showSelection?: boolean;
67
+ minSelectionSize?: number;
68
+ gridAvailableSteps?: Duration[];
69
+ goalGridWidthPx?: number;
70
+ minLanesCount?: number;
71
+ lanesSource?: LaneSourceData<T, TLaneData>[];
72
+ unmatchedLanesToFront?: boolean;
73
+ children?: React.ReactNode;
74
+ bookingCalendarTopLeftHeader?: React.ReactNode;
75
+ filteringButton?: React.ReactNode;
76
+
77
+ zoomLevels?: ZoomLevel[];
78
+ filterBookingsToZoom?: (booking: T) => boolean;
79
+
80
+ BookingCalendarItem?: React.ComponentType<BookingCalendarItemProps<T>>;
81
+ BookingCalendarRenderItem?: React.ComponentType<
82
+ BookingCalendarRenderItemProps<T>
83
+ >;
84
+ BookingCalendarLane?: React.ComponentType<BookingCalendarLaneProps<T>>;
85
+ BookingCalendarControls?: React.ComponentType<
86
+ BookingCalendarControlsProps<T>
87
+ >;
88
+ BookingCalendarGrid?: React.ComponentType<BookingCalendarGridProps>;
89
+ BookingCalendarLaneHeader?: React.ComponentType<
90
+ BookingCalendarLaneHeaderProps<TLaneData>
91
+ >;
92
+ BookingCalendarLanesHeader?: React.ComponentType<
93
+ BookingCalendarLanesHeaderProps<T>
94
+ >;
95
+ BookingCalendarDatePicker?:
96
+ | React.ComponentType<BookingCalendarDatePickerProps<T>>
97
+ | React.ReactNode;
98
+ }
99
+
100
+ const defaultStep = moment.duration(1, 'day');
101
+
102
+ export function BookingCalendar<T extends BookingCalendarItemT, TLaneData>(
103
+ props: BookingCalendarProps<T, TLaneData>
104
+ ) {
105
+ const {
106
+ bookings,
107
+ className,
108
+ laneContainerClassName,
109
+ laneHeaderContainerClassName,
110
+ lanesHeaderContainerClassName,
111
+ lanesHeaderHeaderContainerClassName,
112
+ controlsClasses,
113
+ tableClassName,
114
+ from,
115
+ till,
116
+ onRangeChange,
117
+ step = defaultStep,
118
+ showGrid = true,
119
+ showSelection = true,
120
+ showZoomAllButton = true,
121
+ gridAvailableSteps = defaultGridAvailableSteps,
122
+ getMomentFormatFunction = defaultGetMomentFormatFunction,
123
+ getNewMomentFunction = defaultGetNewMomentFunction,
124
+ goalGridWidthPx = 60,
125
+ minSelectionSize = 10,
126
+ minLanesCount,
127
+ lanesSource,
128
+ unmatchedLanesToFront = true,
129
+ filterBookingsToZoom,
130
+ zoomLevels,
131
+ BookingCalendarControls = DefaultBookingCalendarControls,
132
+ BookingCalendarItem,
133
+ BookingCalendarLane = DefaultBookingCalendarLane,
134
+ BookingCalendarRenderItem,
135
+ BookingCalendarGrid = DefaultBookingCalendarGrid,
136
+ BookingCalendarLaneHeader = DefaultBookingCalendarLaneHeader,
137
+ BookingCalendarLanesHeader = DefaultBookingCalendarLanesHeader,
138
+ BookingCalendarDatePicker = DefaultBookingCalendarDatePicker,
139
+ bookingCalendarTopLeftHeader,
140
+ filteringButton,
141
+ children,
142
+ } = props;
143
+ const lanes = React.useMemo(
144
+ () =>
145
+ splitBookingsToLanes<T, TLaneData>(
146
+ bookings,
147
+ from,
148
+ minLanesCount,
149
+ lanesSource,
150
+ unmatchedLanesToFront
151
+ ),
152
+ [bookings, from, minLanesCount, lanesSource, unmatchedLanesToFront]
153
+ );
154
+ const { observe, entry } = useDimensions<HTMLDivElement>();
155
+ const width = entry?.target?.scrollWidth ?? 0;
156
+ const { items: gridItems, bestStep } = React.useMemo(
157
+ () =>
158
+ generateGridItems(
159
+ from,
160
+ till,
161
+ step,
162
+ width,
163
+ gridAvailableSteps,
164
+ goalGridWidthPx,
165
+ from?.clone()?.startOf('day')
166
+ ),
167
+ [from, till, step, width, gridAvailableSteps, goalGridWidthPx]
168
+ );
169
+ const onSelected = React.useCallback(
170
+ (data: BookingCalendarSelectionData) => {
171
+ if (!from || !till || !width || !onRangeChange) {
172
+ return;
173
+ }
174
+ const screenSpaceStartX = Math.min(data.origin[0], data.target[0]);
175
+ const screenSpaceEndX = Math.max(data.origin[0], data.target[0]);
176
+ const durationMs = till.valueOf() - from.valueOf();
177
+ const toTimeSpace = (num: number) => (num / (width || 1)) * durationMs;
178
+ const timeSpaceStart = from
179
+ .clone()
180
+ .add(toTimeSpace(screenSpaceStartX), 'ms');
181
+ const timeSpaceEnd = from.clone().add(toTimeSpace(screenSpaceEndX), 'ms');
182
+ onRangeChange({ from: timeSpaceStart, till: timeSpaceEnd });
183
+ },
184
+ [from, till, width, onRangeChange]
185
+ );
186
+ return (
187
+ <div
188
+ className={classNames(bookingCalendarDefaultClasses.className, className)}
189
+ >
190
+ <BookingCalendarControls<T>
191
+ {...controlsClasses}
192
+ items={bookings}
193
+ from={from}
194
+ till={till}
195
+ onRangeChange={onRangeChange}
196
+ step={step}
197
+ filterBookingsToZoom={filterBookingsToZoom}
198
+ zoomLevels={zoomLevels}
199
+ filteringButton={filteringButton}
200
+ showZoomAllButton={showZoomAllButton}
201
+ bookingCalendarDatePicker={
202
+ <>
203
+ {typeof BookingCalendarDatePicker === 'function' ? (
204
+ <BookingCalendarDatePicker
205
+ from={from}
206
+ till={till}
207
+ onRangeChange={onRangeChange}
208
+ getNewMomentFunction={getNewMomentFunction}
209
+ />
210
+ ) : (
211
+ BookingCalendarDatePicker
212
+ )}
213
+ </>
214
+ }
215
+ />
216
+ <div
217
+ className={classNames(
218
+ bookingCalendarDefaultClasses.tableClassName,
219
+ tableClassName
220
+ )}
221
+ >
222
+ {showGrid && (
223
+ <BookingCalendarGrid
224
+ items={gridItems}
225
+ dataRowsCount={lanes.length}
226
+ width={width}
227
+ />
228
+ )}
229
+ {showSelection && (
230
+ <BookingCalendarSelection
231
+ dataRowsCount={lanes.length}
232
+ onSelected={onSelected}
233
+ minSelectionSize={minSelectionSize}
234
+ />
235
+ )}
236
+ <div
237
+ className={classNames(
238
+ bookingCalendarDefaultClasses.lanesHeaderHeaderContainerClassName,
239
+ lanesHeaderHeaderContainerClassName
240
+ )}
241
+ >
242
+ {bookingCalendarTopLeftHeader}
243
+ </div>
244
+ <div
245
+ className={classNames(
246
+ bookingCalendarDefaultClasses.lanesHeaderContainerClassName,
247
+ lanesHeaderContainerClassName
248
+ )}
249
+ ref={observe}
250
+ >
251
+ <BookingCalendarLanesHeader<T>
252
+ {...controlsClasses}
253
+ from={from}
254
+ till={till}
255
+ onRangeChange={onRangeChange}
256
+ step={step}
257
+ />
258
+ </div>
259
+
260
+ {lanes.map((lane, laneIndex) => {
261
+ const LaneBookingCalendarLaneHeader =
262
+ lane.BookingCalendarLaneHeader ?? BookingCalendarLaneHeader;
263
+ const LaneBookingCalendarLane =
264
+ lane.BookingCalendarLane ?? BookingCalendarLane;
265
+ return (
266
+ <React.Fragment key={laneIndex}>
267
+ <div
268
+ className={classNames(
269
+ bookingCalendarDefaultClasses.laneHeaderContainerClassName,
270
+ laneHeaderContainerClassName,
271
+ lane.rowClassName,
272
+ {
273
+ [`${bookingCalendarDefaultClasses.laneHeaderContainerClassName}--last`]:
274
+ laneIndex === lanes.length - 1,
275
+ [`${bookingCalendarDefaultClasses.laneHeaderContainerClassName}--first`]:
276
+ laneIndex === 0,
277
+ }
278
+ )}
279
+ >
280
+ <LaneBookingCalendarLaneHeader<TLaneData>
281
+ laneKey={lane.laneKey ?? laneIndex}
282
+ data={lane.data}
283
+ />
284
+ </div>
285
+ <div
286
+ className={classNames(
287
+ bookingCalendarDefaultClasses.laneContainerClassName,
288
+ laneContainerClassName,
289
+ lane.rowClassName,
290
+ {
291
+ [`${bookingCalendarDefaultClasses.laneContainerClassName}--last`]:
292
+ laneIndex === lanes.length - 1,
293
+ [`${bookingCalendarDefaultClasses.laneContainerClassName}--first`]:
294
+ laneIndex === 0,
295
+ }
296
+ )}
297
+ >
298
+ <LaneBookingCalendarLane
299
+ laneIndex={laneIndex}
300
+ items={lane.items}
301
+ from={from}
302
+ till={till}
303
+ BookingCalendarItem={
304
+ lane.BookingCalendarItem ?? BookingCalendarItem
305
+ }
306
+ BookingCalendarRenderItem={
307
+ lane.BookingCalendarRenderItem ?? BookingCalendarRenderItem
308
+ }
309
+ step={step}
310
+ />
311
+ </div>
312
+ </React.Fragment>
313
+ );
314
+ })}
315
+ <div />
316
+ <div>
317
+ <BookingCalendarTimeAxis
318
+ items={gridItems}
319
+ bestStep={bestStep}
320
+ getMomentFormatFunction={getMomentFormatFunction}
321
+ />
322
+ </div>
323
+ </div>
324
+ {children}
325
+ </div>
326
+ );
327
+ }
@@ -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';
@@ -0,0 +1,104 @@
1
+ import * as React from 'react';
2
+ import classNames from 'classnames';
3
+ import {
4
+ BookingCalendarDatePickerClasses,
5
+ bookingCalendarDatePickerDefaultClasses,
6
+ } from './classes';
7
+ import { Moment } from 'moment';
8
+ import {
9
+ BookingCalendarDateRange,
10
+ BookingCalendarItemT,
11
+ GetNewMomentFunctionType,
12
+ defaultGetNewMomentFunction,
13
+ } from '../common';
14
+ import { Button } from '../../button/Button';
15
+ import * as EventIcon from 'material-design-icons/action/svg/production/ic_event_24px.svg';
16
+ try {
17
+ var DatePicker = require('react-datepicker').default;
18
+ } catch {
19
+ DatePicker = undefined;
20
+ }
21
+ // import DatePicker from 'react-datepicker';
22
+
23
+ export interface BookingCalendarDatePickerBaseProps<
24
+ T extends BookingCalendarItemT
25
+ > {
26
+ from: Moment;
27
+ till: Moment;
28
+ onRangeChange?: (range: BookingCalendarDateRange) => void;
29
+ getNewMomentFunction?: GetNewMomentFunctionType;
30
+ }
31
+
32
+ export interface BookingCalendarDatePickerProps<T extends BookingCalendarItemT>
33
+ extends BookingCalendarDatePickerClasses,
34
+ BookingCalendarDatePickerBaseProps<T> {}
35
+
36
+ export function BookingCalendarDatePicker<T extends BookingCalendarItemT>(
37
+ props: BookingCalendarDatePickerProps<T>
38
+ ) {
39
+ const {
40
+ className,
41
+ buttonClassName,
42
+ from,
43
+ till,
44
+ onRangeChange,
45
+ getNewMomentFunction = defaultGetNewMomentFunction,
46
+ } = props;
47
+ const [shownModal, setShownModal] = React.useState<null | 'start' | 'end'>();
48
+ const calendarRef = React.useRef<typeof DatePicker>();
49
+ const onButtonClick = React.useCallback(() => {
50
+ setShownModal('start');
51
+ calendarRef.current.setOpen(true);
52
+ }, []);
53
+ return (
54
+ <div
55
+ className={classNames(
56
+ bookingCalendarDatePickerDefaultClasses.className,
57
+ className
58
+ )}
59
+ >
60
+ <Button
61
+ className={classNames(
62
+ bookingCalendarDatePickerDefaultClasses.buttonClassName,
63
+ buttonClassName
64
+ )}
65
+ noShadow={true}
66
+ onClick={onButtonClick}
67
+ >
68
+ <EventIcon /> {from?.format('MMMM, YYYY')}
69
+ </Button>
70
+ <DatePicker
71
+ ref={calendarRef}
72
+ customInput={<span />}
73
+ selected={from?.toDate()}
74
+ // selectsRange={true}
75
+ selectsStart={shownModal !== 'end'}
76
+ selectsEnd={shownModal === 'end'}
77
+ startDate={from?.toDate()}
78
+ endDate={till?.toDate()}
79
+ shouldCloseOnSelect={shownModal === 'end'}
80
+ //dateFormat={DAY_FORMAT}
81
+ onChange={(dt: Date) => {
82
+ if (shownModal !== 'end') {
83
+ const dtm = getNewMomentFunction(dt);
84
+ let validTill = till.clone();
85
+ if (dtm.isAfter(till)) {
86
+ validTill = dtm.clone().add(1, 'day');
87
+ }
88
+ onRangeChange({ from: dtm, till: validTill });
89
+ setShownModal('end');
90
+ } else {
91
+ let dtm = getNewMomentFunction(dt).startOf('day').add(1, 'day');
92
+ let validFrom = from.clone();
93
+ if (dtm.isBefore(from)) {
94
+ validFrom = dtm.clone().add(-1, 'day');
95
+ }
96
+ onRangeChange({ from: validFrom, till: dtm });
97
+ setShownModal(null);
98
+ }
99
+ }}
100
+ withPortal={true}
101
+ />
102
+ </div>
103
+ );
104
+ }