cronofy-elements 1.48.2 → 1.49.2

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 (349) hide show
  1. package/dist/.gitkeep +0 -0
  2. package/dist/CronofyElements.js +2 -0
  3. package/{build/CronofyElements.v1.48.2.js.LICENSE.txt → dist/CronofyElements.js.LICENSE.txt} +0 -0
  4. package/package.json +10 -7
  5. package/.babelrc +0 -20
  6. package/.eslintrc.yaml +0 -43
  7. package/.prettierignore +0 -4
  8. package/.prettierrc +0 -7
  9. package/Makefile +0 -92
  10. package/brainstorm.md +0 -76
  11. package/build/CronofyElements.v1.48.2.js +0 -2
  12. package/build/npm/CronofyElements.js +0 -2
  13. package/compat.config.js +0 -25
  14. package/demo/agenda.ejs +0 -71
  15. package/demo/availability-viewer.ejs +0 -322
  16. package/demo/calendar-sync.ejs +0 -149
  17. package/demo/crossbrowser.ejs +0 -228
  18. package/demo/date-time-picker.ejs +0 -213
  19. package/demo/demo-styles.css +0 -134
  20. package/demo/index.ejs +0 -249
  21. package/demo/integration.ejs +0 -482
  22. package/demo/load-elements.ejs +0 -12
  23. package/demo/nav.ejs +0 -14
  24. package/demo/rules.ejs +0 -121
  25. package/demo/server.js +0 -425
  26. package/demo/slot-picker.ejs +0 -197
  27. package/git.README.md +0 -71
  28. package/notes.style.md +0 -197
  29. package/postcss.config.js +0 -3
  30. package/script/i18n-export +0 -11
  31. package/script/i18n-helpers/split_write.rb +0 -25
  32. package/script/i18n-import +0 -22
  33. package/script/i18n-reference-update +0 -241
  34. package/src/js/components/Agenda/Agenda.js +0 -243
  35. package/src/js/components/Agenda/AllDayEventsList.js +0 -37
  36. package/src/js/components/Agenda/Calendar.js +0 -100
  37. package/src/js/components/Agenda/CalendarHeader.js +0 -187
  38. package/src/js/components/Agenda/Event.js +0 -34
  39. package/src/js/components/Agenda/EventAllDay.js +0 -76
  40. package/src/js/components/Agenda/EventAttendees.js +0 -30
  41. package/src/js/components/Agenda/EventDetail.js +0 -111
  42. package/src/js/components/Agenda/EventMessages.js +0 -24
  43. package/src/js/components/Agenda/EventMeta.js +0 -48
  44. package/src/js/components/Agenda/EventTime.js +0 -34
  45. package/src/js/components/Agenda/EventWrapper.js +0 -271
  46. package/src/js/components/Agenda/Location.js +0 -29
  47. package/src/js/components/Agenda/Message.js +0 -22
  48. package/src/js/components/Agenda/TimedEventsList.js +0 -29
  49. package/src/js/components/AvailabilityRules/AddButton.js +0 -60
  50. package/src/js/components/AvailabilityRules/AvailabilityRules.js +0 -45
  51. package/src/js/components/AvailabilityRules/Calendar.js +0 -31
  52. package/src/js/components/AvailabilityRules/CalendarListItem.js +0 -53
  53. package/src/js/components/AvailabilityRules/CalendarProfiles.js +0 -67
  54. package/src/js/components/AvailabilityRules/CalendarSelector.js +0 -104
  55. package/src/js/components/AvailabilityRules/Calendars.js +0 -145
  56. package/src/js/components/AvailabilityRules/Checkmark.js +0 -51
  57. package/src/js/components/AvailabilityRules/DayLabels.js +0 -91
  58. package/src/js/components/AvailabilityRules/Footer.js +0 -109
  59. package/src/js/components/AvailabilityRules/Legend.js +0 -57
  60. package/src/js/components/AvailabilityRules/Loading.js +0 -53
  61. package/src/js/components/AvailabilityRules/RemoveButton.js +0 -57
  62. package/src/js/components/AvailabilityRules/Slot.js +0 -195
  63. package/src/js/components/AvailabilityRules/SlotDisplay.js +0 -27
  64. package/src/js/components/AvailabilityRules/Slots.js +0 -81
  65. package/src/js/components/AvailabilityRules/SlotsDisplay.js +0 -68
  66. package/src/js/components/AvailabilityRules/TimeExpander.js +0 -119
  67. package/src/js/components/AvailabilityRules/TimeLabels.js +0 -89
  68. package/src/js/components/AvailabilityRules/TimeZoneDisplay.js +0 -41
  69. package/src/js/components/AvailabilityRules/ToggleIcon.js +0 -41
  70. package/src/js/components/AvailabilityRules/Tooltip.js +0 -63
  71. package/src/js/components/AvailabilityRules/UnknownCalendar.js +0 -33
  72. package/src/js/components/AvailabilityRules/Week.js +0 -115
  73. package/src/js/components/AvailabilityRules/WeekGrid.js +0 -80
  74. package/src/js/components/AvailabilityRules/Wrapper.js +0 -423
  75. package/src/js/components/AvailabilityRules/contexts/drag-context.js +0 -15
  76. package/src/js/components/AvailabilityRules/scss/_base.buttons.scss +0 -58
  77. package/src/js/components/AvailabilityRules/scss/_base.theme.scss +0 -4
  78. package/src/js/components/AvailabilityRules/scss/_components.timezoneselector.scss +0 -74
  79. package/src/js/components/AvailabilityRules/scss/_generic.reset.scss +0 -13
  80. package/src/js/components/AvailabilityRules/scss/_settings.colours.scss +0 -12
  81. package/src/js/components/AvailabilityRules/scss/availabilityrules.scss +0 -5
  82. package/src/js/components/AvailabilityRules/utils/tz-utils.js +0 -61
  83. package/src/js/components/AvailabilityViewer/AvailabilityViewer.js +0 -524
  84. package/src/js/components/AvailabilityViewer/ColumnHeader.js +0 -35
  85. package/src/js/components/AvailabilityViewer/DayColumn.js +0 -36
  86. package/src/js/components/AvailabilityViewer/DayColumnDisplay.js +0 -33
  87. package/src/js/components/AvailabilityViewer/DayColumnWrapper.js +0 -29
  88. package/src/js/components/AvailabilityViewer/DayLabels.js +0 -41
  89. package/src/js/components/AvailabilityViewer/EmptyColumn.js +0 -29
  90. package/src/js/components/AvailabilityViewer/Footer.js +0 -36
  91. package/src/js/components/AvailabilityViewer/GridFreeSelect.js +0 -33
  92. package/src/js/components/AvailabilityViewer/HoverSlot.js +0 -35
  93. package/src/js/components/AvailabilityViewer/HoverTooltip.js +0 -34
  94. package/src/js/components/AvailabilityViewer/LabelColumn.js +0 -53
  95. package/src/js/components/AvailabilityViewer/LabelItem.js +0 -73
  96. package/src/js/components/AvailabilityViewer/Legend.js +0 -79
  97. package/src/js/components/AvailabilityViewer/Loading.js +0 -57
  98. package/src/js/components/AvailabilityViewer/MonthLabels.js +0 -43
  99. package/src/js/components/AvailabilityViewer/Navigation.js +0 -138
  100. package/src/js/components/AvailabilityViewer/Overlay.js +0 -60
  101. package/src/js/components/AvailabilityViewer/Preloading.js +0 -66
  102. package/src/js/components/AvailabilityViewer/SelectedSlot.js +0 -106
  103. package/src/js/components/AvailabilityViewer/SelectedSlots.js +0 -72
  104. package/src/js/components/AvailabilityViewer/SelectionMask.js +0 -44
  105. package/src/js/components/AvailabilityViewer/Slot.js +0 -237
  106. package/src/js/components/AvailabilityViewer/SlotFreeSelect.js +0 -115
  107. package/src/js/components/AvailabilityViewer/Slots.js +0 -57
  108. package/src/js/components/AvailabilityViewer/TimeExpander.js +0 -93
  109. package/src/js/components/AvailabilityViewer/TimeLines.js +0 -74
  110. package/src/js/components/AvailabilityViewer/TimeSelector.js +0 -243
  111. package/src/js/components/AvailabilityViewer/TimeSelectorTrigger.js +0 -42
  112. package/src/js/components/AvailabilityViewer/TimeZoneDisplay.js +0 -28
  113. package/src/js/components/AvailabilityViewer/ToggleIcon.js +0 -41
  114. package/src/js/components/AvailabilityViewer/Tooltip.js +0 -65
  115. package/src/js/components/AvailabilityViewer/Week.js +0 -255
  116. package/src/js/components/AvailabilityViewer/WeekWrapper.js +0 -132
  117. package/src/js/components/AvailabilityViewer/contexts/page-context.js +0 -17
  118. package/src/js/components/AvailabilityViewer/contexts/page-reducer.js +0 -28
  119. package/src/js/components/AvailabilityViewer/contexts/selection-context.js +0 -25
  120. package/src/js/components/AvailabilityViewer/contexts/selection-reducer.js +0 -18
  121. package/src/js/components/CalendarSync/Active.js +0 -57
  122. package/src/js/components/CalendarSync/AddToggle.js +0 -72
  123. package/src/js/components/CalendarSync/CalendarSync.js +0 -215
  124. package/src/js/components/CalendarSync/EditToggle.js +0 -71
  125. package/src/js/components/CalendarSync/Footer.js +0 -31
  126. package/src/js/components/CalendarSync/Inactive.js +0 -66
  127. package/src/js/components/CalendarSync/Loading.js +0 -52
  128. package/src/js/components/CalendarSync/Pending.js +0 -74
  129. package/src/js/components/CalendarSync/ProfileStatus.js +0 -33
  130. package/src/js/components/CalendarSync/Profiles.js +0 -109
  131. package/src/js/components/CalendarSync/ProviderLogo.js +0 -28
  132. package/src/js/components/CalendarSync/Providers.js +0 -80
  133. package/src/js/components/CalendarSync/RemoveLink.js +0 -96
  134. package/src/js/components/CalendarSync/SelectProvider.js +0 -25
  135. package/src/js/components/CalendarSync/contexts/status-reducer.js +0 -74
  136. package/src/js/components/DateTimePicker/Calendar.js +0 -127
  137. package/src/js/components/DateTimePicker/CalendarHeader.js +0 -80
  138. package/src/js/components/DateTimePicker/Confirm.js +0 -106
  139. package/src/js/components/DateTimePicker/DateTimePicker.js +0 -131
  140. package/src/js/components/DateTimePicker/DayButton.js +0 -38
  141. package/src/js/components/DateTimePicker/DayHeadings.js +0 -33
  142. package/src/js/components/DateTimePicker/Details.js +0 -33
  143. package/src/js/components/DateTimePicker/Error.js +0 -39
  144. package/src/js/components/DateTimePicker/Loading.js +0 -20
  145. package/src/js/components/DateTimePicker/LoadingCalendar.js +0 -21
  146. package/src/js/components/DateTimePicker/NoSlotsFound.js +0 -16
  147. package/src/js/components/DateTimePicker/SequencedSlotButton.js +0 -97
  148. package/src/js/components/DateTimePicker/SlotButton.js +0 -55
  149. package/src/js/components/DateTimePicker/SlotsList.js +0 -45
  150. package/src/js/components/DateTimePicker/Wrapper.js +0 -281
  151. package/src/js/components/DateTimePicker/contexts/status-context.js +0 -19
  152. package/src/js/components/DateTimePicker/contexts/status-reducer.js +0 -276
  153. package/src/js/components/DateTimePicker/contexts/theme-context.js +0 -33
  154. package/src/js/components/DateTimePicker/helpers/theming.js +0 -49
  155. package/src/js/components/DateTimePicker/scss/_base.buttons.scss +0 -58
  156. package/src/js/components/DateTimePicker/scss/_base.layout.scss +0 -28
  157. package/src/js/components/DateTimePicker/scss/_base.theme.scss +0 -17
  158. package/src/js/components/DateTimePicker/scss/_components.calendargrid.scss +0 -78
  159. package/src/js/components/DateTimePicker/scss/_components.calendarheader.scss +0 -71
  160. package/src/js/components/DateTimePicker/scss/_components.confirm.scss +0 -40
  161. package/src/js/components/DateTimePicker/scss/_components.details.scss +0 -20
  162. package/src/js/components/DateTimePicker/scss/_components.error.scss +0 -34
  163. package/src/js/components/DateTimePicker/scss/_components.loading.scss +0 -36
  164. package/src/js/components/DateTimePicker/scss/_components.slotslist.scss +0 -43
  165. package/src/js/components/DateTimePicker/scss/_components.timezoneselector.scss +0 -73
  166. package/src/js/components/DateTimePicker/scss/_generic.reset.scss +0 -18
  167. package/src/js/components/DateTimePicker/scss/_settings.colours.scss +0 -17
  168. package/src/js/components/DateTimePicker/scss/datetimepicker.scss +0 -5
  169. package/src/js/components/DateTimePicker/utils/calendar-keyboard.js +0 -109
  170. package/src/js/components/DateTimePicker/utils/calendar.js +0 -125
  171. package/src/js/components/DateTimePicker/utils/slots.js +0 -288
  172. package/src/js/components/SlotPicker/Confirm.js +0 -160
  173. package/src/js/components/SlotPicker/Days.js +0 -58
  174. package/src/js/components/SlotPicker/Slot.js +0 -72
  175. package/src/js/components/SlotPicker/SlotPicker.js +0 -292
  176. package/src/js/components/SlotPicker/Slots.js +0 -66
  177. package/src/js/components/SlotPicker/TimeSlots.js +0 -91
  178. package/src/js/components/generic/Button.js +0 -26
  179. package/src/js/components/generic/Container.js +0 -33
  180. package/src/js/components/generic/Error.js +0 -77
  181. package/src/js/components/generic/Loading.js +0 -51
  182. package/src/js/components/generic/LoadingSpinner.js +0 -30
  183. package/src/js/components/generic/ShadowScrollbars.js +0 -70
  184. package/src/js/components/generic/TimeZoneSelector.js +0 -158
  185. package/src/js/components/generic/TransitionSlide.js +0 -72
  186. package/src/js/contexts/i18n-context.js +0 -25
  187. package/src/js/contexts/log-context.js +0 -18
  188. package/src/js/contexts/tz-context.js +0 -18
  189. package/src/js/env.example.js +0 -8
  190. package/src/js/helpers/colors.js +0 -33
  191. package/src/js/helpers/comparators.AvailabilityViewer.js +0 -27
  192. package/src/js/helpers/connections.js +0 -370
  193. package/src/js/helpers/events.js +0 -166
  194. package/src/js/helpers/functional.js +0 -4
  195. package/src/js/helpers/generator.js +0 -107
  196. package/src/js/helpers/i18n.js +0 -153
  197. package/src/js/helpers/init.Agenda.js +0 -55
  198. package/src/js/helpers/init.AvailabilityRules.js +0 -195
  199. package/src/js/helpers/init.AvailabilityViewer.js +0 -215
  200. package/src/js/helpers/init.CalendarSync.js +0 -83
  201. package/src/js/helpers/init.DateTimePicker.js +0 -219
  202. package/src/js/helpers/init.SlotPicker.js +0 -89
  203. package/src/js/helpers/init.js +0 -308
  204. package/src/js/helpers/logging.js +0 -78
  205. package/src/js/helpers/mocks.js +0 -871
  206. package/src/js/helpers/slots.js +0 -340
  207. package/src/js/helpers/slots.rules.js +0 -220
  208. package/src/js/helpers/theming.js +0 -93
  209. package/src/js/helpers/translations.js +0 -42
  210. package/src/js/helpers/tz-list.js +0 -136
  211. package/src/js/helpers/utils.AvailabilityRules.js +0 -110
  212. package/src/js/helpers/utils.AvailabilityViewer.js +0 -789
  213. package/src/js/helpers/utils.CalendarSync.js +0 -199
  214. package/src/js/helpers/utils.js +0 -76
  215. package/src/js/hooks/useWindowSize.js +0 -20
  216. package/src/js/main.js +0 -133
  217. package/src/js/next.js +0 -37
  218. package/src/js/styles/_settings.utils.scss +0 -82
  219. package/src/js/styles/colors.js +0 -13
  220. package/src/js/styles/global.js +0 -49
  221. package/src/js/styles/utils.js +0 -81
  222. package/src/js/translations/de/agenda.json +0 -12
  223. package/src/js/translations/de/availability_rules.json +0 -18
  224. package/src/js/translations/de/availability_viewer.json +0 -14
  225. package/src/js/translations/de/calendar_sync.json +0 -14
  226. package/src/js/translations/de/core.json +0 -15
  227. package/src/js/translations/de/date_time_picker.json +0 -14
  228. package/src/js/translations/de/slot_picker.json +0 -9
  229. package/src/js/translations/de/time_zones.json +0 -135
  230. package/src/js/translations/en/agenda.json +0 -12
  231. package/src/js/translations/en/availability_rules.json +0 -18
  232. package/src/js/translations/en/availability_viewer.json +0 -14
  233. package/src/js/translations/en/calendar_sync.json +0 -14
  234. package/src/js/translations/en/core.json +0 -23
  235. package/src/js/translations/en/date_time_picker.json +0 -15
  236. package/src/js/translations/en/slot_picker.json +0 -9
  237. package/src/js/translations/en/time_zones.json +0 -17
  238. package/src/js/translations/es/agenda.json +0 -12
  239. package/src/js/translations/es/availability_rules.json +0 -18
  240. package/src/js/translations/es/availability_viewer.json +0 -14
  241. package/src/js/translations/es/calendar_sync.json +0 -14
  242. package/src/js/translations/es/core.json +0 -15
  243. package/src/js/translations/es/date_time_picker.json +0 -14
  244. package/src/js/translations/es/slot_picker.json +0 -9
  245. package/src/js/translations/es/time_zones.json +0 -203
  246. package/src/js/translations/fr/agenda.json +0 -12
  247. package/src/js/translations/fr/availability_rules.json +0 -18
  248. package/src/js/translations/fr/availability_viewer.json +0 -14
  249. package/src/js/translations/fr/calendar_sync.json +0 -14
  250. package/src/js/translations/fr/core.json +0 -15
  251. package/src/js/translations/fr/date_time_picker.json +0 -14
  252. package/src/js/translations/fr/slot_picker.json +0 -9
  253. package/src/js/translations/fr/time_zones.json +0 -161
  254. package/src/js/translations/fr-CA/agenda.json +0 -12
  255. package/src/js/translations/fr-CA/availability_rules.json +0 -18
  256. package/src/js/translations/fr-CA/availability_viewer.json +0 -14
  257. package/src/js/translations/fr-CA/calendar_sync.json +0 -14
  258. package/src/js/translations/fr-CA/core.json +0 -23
  259. package/src/js/translations/fr-CA/date_time_picker.json +0 -14
  260. package/src/js/translations/fr-CA/slot_picker.json +0 -9
  261. package/src/js/translations/fr-CA/time_zones.json +0 -163
  262. package/src/js/translations/it/agenda.json +0 -12
  263. package/src/js/translations/it/availability_rules.json +0 -18
  264. package/src/js/translations/it/availability_viewer.json +0 -14
  265. package/src/js/translations/it/calendar_sync.json +0 -14
  266. package/src/js/translations/it/core.json +0 -15
  267. package/src/js/translations/it/date_time_picker.json +0 -14
  268. package/src/js/translations/it/slot_picker.json +0 -9
  269. package/src/js/translations/it/time_zones.json +0 -126
  270. package/src/js/translations/ja/agenda.json +0 -12
  271. package/src/js/translations/ja/availability_rules.json +0 -18
  272. package/src/js/translations/ja/availability_viewer.json +0 -14
  273. package/src/js/translations/ja/calendar_sync.json +0 -14
  274. package/src/js/translations/ja/core.json +0 -15
  275. package/src/js/translations/ja/date_formats.json +0 -5
  276. package/src/js/translations/ja/date_time_picker.json +0 -14
  277. package/src/js/translations/ja/slot_picker.json +0 -9
  278. package/src/js/translations/ja/time_zones.json +0 -435
  279. package/src/js/translations/nl/agenda.json +0 -12
  280. package/src/js/translations/nl/availability_rules.json +0 -18
  281. package/src/js/translations/nl/availability_viewer.json +0 -14
  282. package/src/js/translations/nl/calendar_sync.json +0 -14
  283. package/src/js/translations/nl/core.json +0 -15
  284. package/src/js/translations/nl/date_time_picker.json +0 -14
  285. package/src/js/translations/nl/slot_picker.json +0 -9
  286. package/src/js/translations/nl/time_zones.json +0 -118
  287. package/src/js/translations/ru/agenda.json +0 -12
  288. package/src/js/translations/ru/availability_rules.json +0 -18
  289. package/src/js/translations/ru/availability_viewer.json +0 -14
  290. package/src/js/translations/ru/calendar_sync.json +0 -14
  291. package/src/js/translations/ru/core.json +0 -15
  292. package/src/js/translations/ru/date_time_picker.json +0 -14
  293. package/src/js/translations/ru/slot_picker.json +0 -9
  294. package/src/js/translations/ru/time_zones.json +0 -435
  295. package/src/js/translations/sv/agenda.json +0 -12
  296. package/src/js/translations/sv/availability_rules.json +0 -18
  297. package/src/js/translations/sv/availability_viewer.json +0 -14
  298. package/src/js/translations/sv/calendar_sync.json +0 -14
  299. package/src/js/translations/sv/core.json +0 -15
  300. package/src/js/translations/sv/date_time_picker.json +0 -14
  301. package/src/js/translations/sv/slot_picker.json +0 -9
  302. package/src/js/translations/sv/time_zones.json +0 -136
  303. package/tests/AvailabilityRules/AvailabilityRules.test.js +0 -39
  304. package/tests/AvailabilityRules/__snapshots__/AvailabilityRules.test.js.snap +0 -1045
  305. package/tests/AvailabilityViewer/Navigation.test.js +0 -130
  306. package/tests/AvailabilityViewer/contexts/page-reducer.test.js +0 -87
  307. package/tests/AvailabilityViewer/reducer.test.js +0 -73
  308. package/tests/CalendarSync/Active.test.js +0 -25
  309. package/tests/CalendarSync/AddToggle.test.js +0 -57
  310. package/tests/CalendarSync/EditToggle.test.js +0 -57
  311. package/tests/CalendarSync/Inactive.test.js +0 -26
  312. package/tests/CalendarSync/Pending.test.js +0 -25
  313. package/tests/CalendarSync/ProviderLogo.test.js +0 -95
  314. package/tests/CalendarSync/__snapshots__/Active.test.js.snap +0 -61
  315. package/tests/CalendarSync/__snapshots__/Inactive.test.js.snap +0 -78
  316. package/tests/CalendarSync/__snapshots__/Pending.test.js.snap +0 -90
  317. package/tests/CalendarSync/__snapshots__/ProviderLogo.test.js.snap +0 -267
  318. package/tests/CalendarSync/init.CalendarSync.test.js +0 -302
  319. package/tests/CalendarSync/mocks/theme.js +0 -14
  320. package/tests/CalendarSync/status-reducer.test.js +0 -435
  321. package/tests/DateTimePicker/SequencedSlotButton.test.js +0 -157
  322. package/tests/DateTimePicker/SlotButton.test.js +0 -118
  323. package/tests/DateTimePicker/contexts/status-reducer.test.js +0 -1036
  324. package/tests/DateTimePicker/dummy-data.js +0 -883
  325. package/tests/DateTimePicker/utils.test.js +0 -515
  326. package/tests/colors.test.js +0 -70
  327. package/tests/components/TimezoneSelector.test.js +0 -124
  328. package/tests/components/main.test.js +0 -203
  329. package/tests/components/rtl-utils.js +0 -32
  330. package/tests/connections.test.js +0 -684
  331. package/tests/events.test.js +0 -472
  332. package/tests/generator.test.js +0 -74
  333. package/tests/i18n.test.js +0 -255
  334. package/tests/init.Agenda.test.js +0 -122
  335. package/tests/init.AvailabilityRules.test.js +0 -279
  336. package/tests/init.AvailabilityViewer.test.js +0 -740
  337. package/tests/init.SlotPicker.test.js +0 -166
  338. package/tests/init.test.js +0 -231
  339. package/tests/logging.test.js +0 -235
  340. package/tests/mocks/i18n.js +0 -3
  341. package/tests/mocks/theme.js +0 -3
  342. package/tests/setupJest.js +0 -8
  343. package/tests/slots.rules.test.js +0 -195
  344. package/tests/slots.test.js +0 -278
  345. package/tests/utils.AvailabilityRules.test.js +0 -221
  346. package/tests/utils.AvailabilityViewer.test.js +0 -1800
  347. package/tests/utils.CalendarSync.test.js +0 -277
  348. package/tests/utils.test.js +0 -119
  349. package/webpack.config.js +0 -114
@@ -1,130 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
-
4
- import { i18n } from "../mocks/i18n";
5
- import { theme } from "../mocks/theme";
6
-
7
- import { PagesProvider } from "../../src/js/components/AvailabilityViewer/contexts/page-context";
8
- import {
9
- I18nContext,
10
- LoggingContext,
11
- StatusContext,
12
- ThemeContext,
13
- } from "../../src/js/components/AvailabilityViewer/AvailabilityViewer";
14
-
15
- import Navigation from "../../src/js/components/AvailabilityViewer/Navigation";
16
-
17
- const wrapper = ({ children, log, status, pages }) => (
18
- <LoggingContext.Provider value={log ?? { warn: () => undefined }}>
19
- <I18nContext.Provider value={i18n}>
20
- <ThemeContext.Provider value={[theme("AvailabilityViewer")]}>
21
- <StatusContext.Provider
22
- value={
23
- status ?? [
24
- { pagesLoaded: [], notificationCallback: () => undefined },
25
- () => undefined,
26
- ]
27
- }
28
- >
29
- <PagesProvider
30
- {...(pages
31
- ? { value: pages[0], dispatch: pages[1] }
32
- : { value: {}, dispatch: () => undefined })}
33
- >
34
- {children}
35
- </PagesProvider>
36
- </StatusContext.Provider>
37
- </ThemeContext.Provider>
38
- </I18nContext.Provider>
39
- </LoggingContext.Provider>
40
- );
41
-
42
- describe("Navigation", () => {
43
- it("displays nothing if pages.total is empty", () => {
44
- const pages = [{ total: 0 }];
45
-
46
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
47
-
48
- expect(container).toBeEmptyDOMElement();
49
- });
50
-
51
- it("displays navigation if pages.total > 0", () => {
52
- const pages = [{ total: 1 }];
53
-
54
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
55
-
56
- const buttonWrapper = container.querySelector(".AvailabilityViewer__navigation");
57
-
58
- expect(buttonWrapper).toBeInTheDocument();
59
- });
60
-
61
- it("disables button is hasNext is false", () => {
62
- const pages = [{ total: 10, hasNext: false }];
63
-
64
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
65
-
66
- const nextButton = container.querySelector(".AvailabilityViewer__button--next");
67
-
68
- expect(nextButton).toBeDisabled();
69
- });
70
-
71
- it("enables next button if hasNext is true", () => {
72
- const pages = [{ total: 10, hasNext: true }];
73
-
74
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
75
-
76
- const nextButton = container.querySelector(".AvailabilityViewer__button--next");
77
-
78
- expect(nextButton).toBeEnabled();
79
- });
80
-
81
- it("calls dispatch to set the next page", () => {
82
- const pagesDispatch = jest.fn();
83
- const pages = [{ total: 10, hasNext: true }, pagesDispatch];
84
-
85
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
86
-
87
- const nextButton = container.querySelector(".AvailabilityViewer__button--next");
88
-
89
- fireEvent.click(nextButton);
90
-
91
- expect(pagesDispatch).toHaveBeenCalledWith({
92
- type: "SET_NEXT_PAGE",
93
- });
94
- });
95
-
96
- it("disables button if hasPrev is false", () => {
97
- const pages = [{ total: 10, hasPrev: false }];
98
-
99
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
100
-
101
- const prevButton = container.querySelector(".AvailabilityViewer__button--prev");
102
-
103
- expect(prevButton).toBeDisabled();
104
- });
105
-
106
- it("enables button if hasPrev is true", () => {
107
- const pages = [{ total: 10, hasPrev: true }];
108
-
109
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
110
-
111
- const prevButton = container.querySelector(".AvailabilityViewer__button--prev");
112
-
113
- expect(prevButton).toBeEnabled();
114
- });
115
-
116
- it("calls dispatch to set the prev page", () => {
117
- const pagesDispatch = jest.fn();
118
- const pages = [{ total: 10, hasPrev: true }, pagesDispatch];
119
-
120
- const { container } = render(<Navigation />, { wrapper: e => wrapper({ ...e, pages }) });
121
-
122
- const prevButton = container.querySelector(".AvailabilityViewer__button--prev");
123
-
124
- fireEvent.click(prevButton);
125
-
126
- expect(pagesDispatch).toHaveBeenCalledWith({
127
- type: "SET_PREV_PAGE",
128
- });
129
- });
130
- });
@@ -1,87 +0,0 @@
1
- import { pageReducer } from "../../../src/js/components/AvailabilityViewer/contexts/page-reducer";
2
-
3
- describe("pageReducer", () => {
4
- describe("SET_PREV_PAGE", () => {
5
- it("sets prev page", () => {
6
- const initialState = {
7
- current: 5,
8
- total: 10,
9
- };
10
-
11
- const action = {
12
- type: "SET_PREV_PAGE",
13
- };
14
-
15
- const actual = pageReducer(initialState, action);
16
-
17
- expect(actual).toEqual({
18
- current: 4,
19
- total: 10,
20
- hasNext: true,
21
- hasPrev: true,
22
- });
23
- });
24
-
25
- it("sets page to 1 if calculated page is less than it", () => {
26
- const initialState = {
27
- current: 1,
28
- total: 10,
29
- };
30
-
31
- const action = {
32
- type: "SET_PREV_PAGE",
33
- };
34
-
35
- const actual = pageReducer(initialState, action);
36
-
37
- expect(actual).toEqual({
38
- current: 1,
39
- total: 10,
40
- hasNext: true,
41
- hasPrev: false,
42
- });
43
- });
44
- });
45
-
46
- describe("SET_NEXT_PAGE", () => {
47
- it("sets next page", () => {
48
- const initialState = {
49
- current: 3,
50
- total: 15,
51
- };
52
-
53
- const action = {
54
- type: "SET_NEXT_PAGE",
55
- };
56
-
57
- const actual = pageReducer(initialState, action);
58
-
59
- expect(actual).toEqual({
60
- current: 4,
61
- total: 15,
62
- hasNext: true,
63
- hasPrev: true,
64
- });
65
- });
66
-
67
- it("sets page to the total if calculated page is greater than it", () => {
68
- const initialState = {
69
- current: 15,
70
- total: 15,
71
- };
72
-
73
- const action = {
74
- type: "SET_NEXT_PAGE",
75
- };
76
-
77
- const actual = pageReducer(initialState, action);
78
-
79
- expect(actual).toEqual({
80
- current: 15,
81
- total: 15,
82
- hasNext: false,
83
- hasPrev: true,
84
- });
85
- });
86
- });
87
- });
@@ -1,73 +0,0 @@
1
- import { selectionReducer } from "../../src/js/components/AvailabilityViewer/contexts/selection-reducer";
2
-
3
- describe("AvailabilityViewer Selection Context Reducer", () => {
4
- describe("SET_SELECTED_SLOTS", () => {
5
- it("should set slot to selectedSlots", () => {
6
- const initialState = {
7
- selectedSlots: {},
8
- };
9
-
10
- const action = {
11
- type: "SET_SELECTED_SLOTS",
12
- selectedSlots: {
13
- "date-1": "value",
14
- },
15
- };
16
-
17
- const actual = selectionReducer(initialState, action);
18
-
19
- expect(actual).toEqual({
20
- selectedSlots: {
21
- "date-1": "value",
22
- },
23
- });
24
- });
25
-
26
- it("should override existing slot in selectedSlots", () => {
27
- const initialState = {
28
- selectedSlots: {
29
- "date-1": "value-1",
30
- "date-2": "value-2",
31
- },
32
- };
33
-
34
- const action = {
35
- type: "SET_SELECTED_SLOTS",
36
- selectedSlots: {
37
- "date-3": "value-3",
38
- "date-4": "value-4",
39
- },
40
- };
41
-
42
- const actual = selectionReducer(initialState, action);
43
-
44
- expect(actual).toEqual({
45
- selectedSlots: {
46
- "date-3": "value-3",
47
- "date-4": "value-4",
48
- },
49
- });
50
- });
51
- });
52
-
53
- describe("CLEAR_SELECTED_SLOTS", () => {
54
- it("should clear items from selectedSlots", () => {
55
- const initialState = {
56
- selectedSlots: {
57
- "date-1": "value",
58
- "date-2": "value",
59
- },
60
- };
61
-
62
- const action = {
63
- type: "CLEAR_SELECTED_SLOTS",
64
- };
65
-
66
- const actual = selectionReducer(initialState, action);
67
-
68
- expect(actual).toEqual({
69
- selectedSlots: {},
70
- });
71
- });
72
- });
73
- });
@@ -1,25 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import "@testing-library/jest-dom";
4
-
5
- import { i18n } from "../mocks/i18n";
6
- import { theme } from "./mocks/theme";
7
- import { I18nContext, ThemeContext } from "../../src/js/components/CalendarSync/CalendarSync";
8
-
9
- import Active from "../../src/js/components/CalendarSync/Active";
10
-
11
- const renderActive = () =>
12
- render(
13
- <I18nContext.Provider value={i18n}>
14
- <ThemeContext.Provider value={theme}>
15
- <Active />
16
- </ThemeContext.Provider>
17
- </I18nContext.Provider>
18
- );
19
-
20
- describe("Active", () => {
21
- it("should render component", () => {
22
- const { container } = renderActive();
23
- expect(container.firstChild).toMatchSnapshot();
24
- });
25
- });
@@ -1,57 +0,0 @@
1
- import { fireEvent, render, screen } from "@testing-library/react";
2
- import {
3
- I18nContext,
4
- StatusContext,
5
- ThemeContext,
6
- } from "../../src/js/components/CalendarSync/CalendarSync";
7
-
8
- import { i18n } from "../mocks/i18n";
9
- import { theme } from "./mocks/theme";
10
-
11
- import AddToggle from "../../src/js/components/CalendarSync/AddToggle";
12
-
13
- const renderAddToggle = children =>
14
- render(
15
- <I18nContext.Provider value={i18n}>
16
- <ThemeContext.Provider value={theme}>{children}</ThemeContext.Provider>
17
- </I18nContext.Provider>
18
- );
19
-
20
- describe("AddToggle", () => {
21
- // User
22
- it.skip("toggles between 'add_to_calendar' and 'back'", () => {
23
- // StatusContext not isolated to test this use case
24
- // Currently, this would require entire CalSync component to be imported which is not ideal
25
- });
26
-
27
- // Developers
28
- it("calls dispatch when pressing 'add_calendar_account' button", () => {
29
- const dispatch = jest.fn();
30
-
31
- renderAddToggle(
32
- <StatusContext.Provider value={[{ adding: false }, dispatch]}>
33
- <AddToggle />
34
- </StatusContext.Provider>
35
- );
36
-
37
- fireEvent.click(screen.getByText(i18n.t("add_calendar_account")));
38
-
39
- expect(dispatch).toHaveBeenCalledTimes(1);
40
- expect(dispatch).toHaveBeenCalledWith({ type: "TOGGLE_ADD_PROFILE" });
41
- });
42
-
43
- it("calls dispatch when pressing 'back' button", () => {
44
- const dispatch = jest.fn();
45
-
46
- renderAddToggle(
47
- <StatusContext.Provider value={[{ adding: true }, dispatch]}>
48
- <AddToggle />
49
- </StatusContext.Provider>
50
- );
51
-
52
- fireEvent.click(screen.getByText(i18n.t("back")));
53
-
54
- expect(dispatch).toHaveBeenCalledTimes(1);
55
- expect(dispatch).toHaveBeenCalledWith({ type: "TOGGLE_ADD_PROFILE" });
56
- });
57
- });
@@ -1,57 +0,0 @@
1
- import { fireEvent, render, screen } from "@testing-library/react";
2
- import {
3
- I18nContext,
4
- StatusContext,
5
- ThemeContext,
6
- } from "../../src/js/components/CalendarSync/CalendarSync";
7
-
8
- import { i18n } from "../mocks/i18n";
9
- import { theme } from "./mocks/theme";
10
-
11
- import EditToggle from "../../src/js/components/CalendarSync/EditToggle";
12
-
13
- const renderAddToggle = children =>
14
- render(
15
- <I18nContext.Provider value={i18n}>
16
- <ThemeContext.Provider value={theme}>{children}</ThemeContext.Provider>
17
- </I18nContext.Provider>
18
- );
19
-
20
- describe("EditToggle", () => {
21
- // User
22
- it.skip("toggles between 'edit_accounts' and 'cancel'", () => {
23
- // StatusContext not isolated to test this use case
24
- // Currently, this would require entire CalSync component to be imported which is not ideal
25
- });
26
-
27
- // Developer
28
- it("calls dispatch when pressing 'edit_accounts' button", () => {
29
- const dispatch = jest.fn();
30
-
31
- renderAddToggle(
32
- <StatusContext.Provider value={[{ editing: false }, dispatch]}>
33
- <EditToggle />
34
- </StatusContext.Provider>
35
- );
36
-
37
- fireEvent.click(screen.getByText(i18n.t("edit_accounts")));
38
-
39
- expect(dispatch).toHaveBeenCalledTimes(1);
40
- expect(dispatch).toHaveBeenCalledWith({ type: "TOGGLE_EDIT_PROFILES" });
41
- });
42
-
43
- it("calls dispatch when pressing 'cancel' button", () => {
44
- const dispatch = jest.fn();
45
-
46
- renderAddToggle(
47
- <StatusContext.Provider value={[{ editing: true }, dispatch]}>
48
- <EditToggle />
49
- </StatusContext.Provider>
50
- );
51
-
52
- fireEvent.click(screen.getByText(i18n.t("cancel")));
53
-
54
- expect(dispatch).toHaveBeenCalledTimes(1);
55
- expect(dispatch).toHaveBeenCalledWith({ type: "TOGGLE_EDIT_PROFILES" });
56
- });
57
- });
@@ -1,26 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import "@testing-library/jest-dom";
4
-
5
- import { i18n } from "../mocks/i18n";
6
- import { theme } from "./mocks/theme";
7
- import { I18nContext, ThemeContext } from "../../src/js/components/CalendarSync/CalendarSync";
8
-
9
- import Inactive from "../../src/js/components/CalendarSync/Inactive";
10
-
11
- const renderInactive = children =>
12
- render(
13
- <I18nContext.Provider value={i18n}>
14
- <ThemeContext.Provider value={theme}>{children}</ThemeContext.Provider>
15
- </I18nContext.Provider>
16
- );
17
-
18
- describe("Inactive", () => {
19
- it("should render component", () => {
20
- const url = "https://example.com";
21
-
22
- const { container } = renderInactive(<Inactive url={url} />);
23
-
24
- expect(container.firstChild).toMatchSnapshot();
25
- });
26
- });
@@ -1,25 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import "@testing-library/jest-dom";
4
-
5
- import { i18n } from "../mocks/i18n";
6
- import { theme } from "./mocks/theme";
7
- import { I18nContext, ThemeContext } from "../../src/js/components/CalendarSync/CalendarSync";
8
-
9
- import Pending from "../../src/js/components/CalendarSync/Pending";
10
-
11
- const renderInactive = () =>
12
- render(
13
- <I18nContext.Provider value={i18n}>
14
- <ThemeContext.Provider value={theme}>
15
- <Pending />
16
- </ThemeContext.Provider>
17
- </I18nContext.Provider>
18
- );
19
-
20
- describe("Pending", () => {
21
- it("should render component", () => {
22
- const { container } = renderInactive();
23
- expect(container.firstChild).toMatchSnapshot();
24
- });
25
- });
@@ -1,95 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import "@testing-library/jest-dom";
4
-
5
- import { theme } from "./mocks/theme";
6
- import { ThemeContext } from "../../src/js/components/CalendarSync/CalendarSync";
7
- import ProviderLogo from "../../src/js/components/CalendarSync/ProviderLogo";
8
-
9
- const renderProviderLogo = children =>
10
- render(<ThemeContext.Provider value={theme}>{children}</ThemeContext.Provider>);
11
-
12
- describe("ProviderLogo", () => {
13
- it("displays nothing if provider doesn't exist", () => {
14
- const { container } = renderProviderLogo(<ProviderLogo />);
15
-
16
- const parent = container.firstChild;
17
- const expectedResponse = null;
18
-
19
- expect(parent.firstChild).toEqual(expectedResponse);
20
- });
21
-
22
- describe("Google", () => {
23
- const provider = "google";
24
-
25
- it("displays fill icon", () => {
26
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} fill />);
27
-
28
- expect(container.firstChild).toMatchSnapshot();
29
- });
30
-
31
- it("displays outlined icon", () => {
32
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} />);
33
-
34
- expect(container.firstChild).toMatchSnapshot();
35
- });
36
- });
37
-
38
- describe("Live Conntect", () => {
39
- const provider = "live_conntect";
40
-
41
- it("displays fill icon", () => {
42
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} fill />);
43
-
44
- expect(container.firstChild).toMatchSnapshot();
45
- });
46
-
47
- it("displays outlined icon", () => {
48
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} />);
49
-
50
- expect(container.firstChild).toMatchSnapshot();
51
- });
52
- });
53
-
54
- describe("Apple", () => {
55
- const provider = "apple";
56
-
57
- it("displays icon", () => {
58
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} fill />);
59
-
60
- expect(container.firstChild).toMatchSnapshot();
61
- });
62
- });
63
-
64
- describe("Office365", () => {
65
- const provider = "office365";
66
-
67
- it("displays fill icon", () => {
68
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} fill />);
69
-
70
- expect(container.firstChild).toMatchSnapshot();
71
- });
72
-
73
- it("displays outlined icon", () => {
74
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} />);
75
-
76
- expect(container.firstChild).toMatchSnapshot();
77
- });
78
- });
79
-
80
- describe("Exchange", () => {
81
- const provider = "exchange";
82
-
83
- it("displays fill icon", () => {
84
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} fill />);
85
-
86
- expect(container.firstChild).toMatchSnapshot();
87
- });
88
-
89
- it("displays outlined icon", () => {
90
- const { container } = renderProviderLogo(<ProviderLogo provider={provider} />);
91
-
92
- expect(container.firstChild).toMatchSnapshot();
93
- });
94
- });
95
- });
@@ -1,61 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`Active should render component 1`] = `
4
- .emotion-0 {
5
- display: -webkit-box;
6
- display: -webkit-flex;
7
- display: -ms-flexbox;
8
- display: flex;
9
- -webkit-align-items: center;
10
- -webkit-box-align: center;
11
- -ms-flex-align: center;
12
- align-items: center;
13
- padding: 10px 0;
14
- }
15
-
16
- .emotion-1 {
17
- display: block;
18
- color: greyMid;
19
- text-transform: uppercase;
20
- font-weight: bold;
21
- -webkit-letter-spacing: 1px;
22
- -moz-letter-spacing: 1px;
23
- -ms-letter-spacing: 1px;
24
- letter-spacing: 1px;
25
- font-size: 10px;
26
- line-height: 1;
27
- }
28
-
29
- .emotion-2 {
30
- display: block;
31
- width: 16px;
32
- height: 16px;
33
- margin-right: 4px;
34
- margin-left: 4px;
35
- background: green;
36
- border-radius: 50%;
37
- }
38
-
39
- .emotion-3 {
40
- fill: white;
41
- }
42
-
43
- <div
44
- class="CalendarSync__status--active emotion-0"
45
- >
46
- <span
47
- class="CalendarSync__status-label emotion-1"
48
- >
49
- active
50
- </span>
51
- <svg
52
- class="CalendarSync__status-icon CalendarSync__status-icon--tick emotion-2"
53
- viewBox="0 0 14 15"
54
- >
55
- <path
56
- class="emotion-3"
57
- d="M3.095 7.892l.65-.927L6.06 8.587l3.57-5.097.926.649-4.218 6.024z"
58
- />
59
- </svg>
60
- </div>
61
- `;