@nylas/web-elements 1.1.0-canary.19.c → 1.1.0-canary.19.e

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 (876) hide show
  1. package/dist/cjs/add-circle-icon_2.cjs.entry.js +1 -1
  2. package/dist/cjs/archive-icon_7.cjs.entry.js +7 -7
  3. package/dist/cjs/arrow-icon.cjs.entry.js +1 -1
  4. package/dist/cjs/bold-icon_3.cjs.entry.js +3 -3
  5. package/dist/cjs/button-component_4.cjs.entry.js +203 -0
  6. package/dist/cjs/button-component_4.cjs.entry.js.map +1 -0
  7. package/dist/cjs/calendar-agenda-fill-icon_35.cjs.entry.js +6943 -0
  8. package/dist/cjs/calendar-agenda-fill-icon_35.cjs.entry.js.map +1 -0
  9. package/dist/cjs/chevron-icon_3.cjs.entry.js +11 -3
  10. package/dist/cjs/chevron-icon_3.cjs.entry.js.map +1 -1
  11. package/dist/cjs/clock-icon_2.cjs.entry.js +1 -1
  12. package/dist/cjs/{constants-3e962931.js → constants-7cc75333.js} +106 -1
  13. package/dist/cjs/{constants-3e962931.js.map → constants-7cc75333.js.map} +1 -1
  14. package/dist/cjs/copy-icon_4.cjs.entry.js +72 -0
  15. package/dist/cjs/copy-icon_4.cjs.entry.js.map +1 -0
  16. package/dist/cjs/document-refresh-icon.cjs.entry.js +1 -1
  17. package/dist/cjs/forward-icon_6.cjs.entry.js +7 -7
  18. package/dist/cjs/globe-icon.cjs.entry.js +1 -1
  19. package/dist/cjs/google-logo-icon_4.cjs.entry.js +192 -51
  20. package/dist/cjs/google-logo-icon_4.cjs.entry.js.map +1 -1
  21. package/dist/cjs/index-7af03e3f.js +20 -16
  22. package/dist/cjs/index.cjs.js +1 -1
  23. package/dist/cjs/info-icon_2.cjs.entry.js +2 -2
  24. package/dist/cjs/input-dropdown_2.cjs.entry.js +2 -2
  25. package/dist/cjs/loader.cjs.js +1 -1
  26. package/dist/cjs/loading-icon.cjs.entry.js +1 -1
  27. package/dist/cjs/multi-select-dropdown.cjs.entry.js +144 -0
  28. package/dist/cjs/multi-select-dropdown.cjs.entry.js.map +1 -0
  29. package/dist/cjs/{nylas-api-request-a1751a40.js → nylas-api-request-393b08a0.js} +2 -1
  30. package/dist/cjs/nylas-api-request-393b08a0.js.map +1 -0
  31. package/dist/cjs/nylas-booked-event-card_10.cjs.entry.js +66 -35
  32. package/dist/cjs/nylas-booked-event-card_10.cjs.entry.js.map +1 -1
  33. package/dist/cjs/nylas-custom-booking-flow.cjs.entry.js +1 -1
  34. package/dist/cjs/nylas-form-card.cjs.entry.js +1 -1
  35. package/dist/cjs/nylas-if-state.cjs.entry.js +1 -1
  36. package/dist/cjs/nylas-list-folders.cjs.entry.js +1 -1
  37. package/dist/cjs/nylas-list-threads.cjs.entry.js +1 -1
  38. package/dist/cjs/nylas-login.cjs.entry.js +1 -1
  39. package/dist/cjs/nylas-mailbox-toolbar-button.cjs.entry.js +1 -1
  40. package/dist/cjs/nylas-mailbox.cjs.entry.js +1 -1
  41. package/dist/cjs/nylas-provider.cjs.entry.js +3 -3
  42. package/dist/cjs/nylas-scheduler-editor.cjs.entry.js +26 -9
  43. package/dist/cjs/nylas-scheduler-editor.cjs.entry.js.map +1 -1
  44. package/dist/cjs/nylas-scheduling.cjs.entry.js +3 -3
  45. package/dist/cjs/nylas-scheduling.cjs.entry.js.map +1 -1
  46. package/dist/cjs/nylas-threads-refresh.cjs.entry.js +2 -2
  47. package/dist/cjs/nylas-threads-search.cjs.entry.js +1 -1
  48. package/dist/cjs/nylas-time-window-picker.cjs.entry.js +1 -1
  49. package/dist/cjs/nylas-view-thread.cjs.entry.js +1 -1
  50. package/dist/cjs/nylas-web-elements.cjs.js +1 -1
  51. package/dist/cjs/play-icon_2.cjs.entry.js +2 -2
  52. package/dist/cjs/refresh-icon.cjs.entry.js +1 -1
  53. package/dist/cjs/{scheduler-config-store-9f19c7a9.js → scheduler-config-store-5bfc8cb8.js} +3 -1
  54. package/dist/cjs/scheduler-config-store-5bfc8cb8.js.map +1 -0
  55. package/dist/cjs/{scheduler-store-0f7328f1.js → scheduler-store-b5cf2e82.js} +43 -7
  56. package/dist/cjs/scheduler-store-b5cf2e82.js.map +1 -0
  57. package/dist/cjs/textarea-component.cjs.entry.js +3 -1
  58. package/dist/cjs/textarea-component.cjs.entry.js.map +1 -1
  59. package/dist/cjs/translate-icon.cjs.entry.js +1 -1
  60. package/dist/cjs/warning-icon.cjs.entry.js +1 -1
  61. package/dist/collection/collection-manifest.json +14 -0
  62. package/dist/collection/common/constants.js +102 -0
  63. package/dist/collection/common/constants.js.map +1 -1
  64. package/dist/collection/common/icons/add-circle.js +1 -1
  65. package/dist/collection/common/icons/archive.js +1 -1
  66. package/dist/collection/common/icons/arrow.js +1 -1
  67. package/dist/collection/common/icons/bold.js +1 -1
  68. package/dist/collection/common/icons/calendar-agenda-fill.js +63 -0
  69. package/dist/collection/common/icons/calendar-agenda-fill.js.map +1 -0
  70. package/dist/collection/common/icons/calendar-agenda.js +63 -0
  71. package/dist/collection/common/icons/calendar-agenda.js.map +1 -0
  72. package/dist/collection/common/icons/copy.js +63 -0
  73. package/dist/collection/common/icons/copy.js.map +1 -0
  74. package/dist/collection/common/icons/delete.js +63 -0
  75. package/dist/collection/common/icons/delete.js.map +1 -0
  76. package/dist/collection/common/icons/document-refresh.js +1 -1
  77. package/dist/collection/common/icons/dragable.js +63 -0
  78. package/dist/collection/common/icons/dragable.js.map +1 -0
  79. package/dist/collection/common/icons/edit.js +63 -0
  80. package/dist/collection/common/icons/edit.js.map +1 -0
  81. package/dist/collection/common/icons/eye.js +63 -0
  82. package/dist/collection/common/icons/eye.js.map +1 -0
  83. package/dist/collection/common/icons/flow.js +1 -1
  84. package/dist/collection/common/icons/folder.js +1 -1
  85. package/dist/collection/common/icons/forward.js +1 -1
  86. package/dist/collection/common/icons/globe.js +1 -1
  87. package/dist/collection/common/icons/google-logo.js +1 -1
  88. package/dist/collection/common/icons/google-meet.js +63 -0
  89. package/dist/collection/common/icons/google-meet.js.map +1 -0
  90. package/dist/collection/common/icons/inbox.js +1 -1
  91. package/dist/collection/common/icons/info.js +1 -1
  92. package/dist/collection/common/icons/italic.js +1 -1
  93. package/dist/collection/common/icons/loading.js +1 -1
  94. package/dist/collection/common/icons/location-off.js +1 -1
  95. package/dist/collection/common/icons/location.js +1 -1
  96. package/dist/collection/common/icons/microsof-teams.js +63 -0
  97. package/dist/collection/common/icons/microsof-teams.js.map +1 -0
  98. package/dist/collection/common/icons/microsoft-logo.js +1 -1
  99. package/dist/collection/common/icons/nylas-logo.js +1 -1
  100. package/dist/collection/common/icons/people.js +1 -1
  101. package/dist/collection/common/icons/person.js +1 -1
  102. package/dist/collection/common/icons/play.js +1 -1
  103. package/dist/collection/common/icons/plus.js +63 -0
  104. package/dist/collection/common/icons/plus.js.map +1 -0
  105. package/dist/collection/common/icons/refresh.js +1 -1
  106. package/dist/collection/common/icons/reply-all.js +1 -1
  107. package/dist/collection/common/icons/reply.js +1 -1
  108. package/dist/collection/common/icons/search.js +1 -1
  109. package/dist/collection/common/icons/sent.js +1 -1
  110. package/dist/collection/common/icons/spam.js +1 -1
  111. package/dist/collection/common/icons/star.js +1 -1
  112. package/dist/collection/common/icons/stop.js +1 -1
  113. package/dist/collection/common/icons/translate.js +1 -1
  114. package/dist/collection/common/icons/trash.js +1 -1
  115. package/dist/collection/common/icons/underline.js +1 -1
  116. package/dist/collection/common/icons/warning.js +1 -1
  117. package/dist/collection/common/icons/zoom.js +63 -0
  118. package/dist/collection/common/icons/zoom.js.map +1 -0
  119. package/dist/collection/common/nylas-api-request.js +1 -0
  120. package/dist/collection/common/nylas-api-request.js.map +1 -1
  121. package/dist/collection/common/types.js.map +1 -1
  122. package/dist/collection/components/design-system/button-component/button-component.css +4 -0
  123. package/dist/collection/components/design-system/button-component/button-component.js +1 -1
  124. package/dist/collection/components/design-system/checkbox-component/checkbox-component.css +15 -1
  125. package/dist/collection/components/design-system/checkbox-component/checkbox-component.js +46 -6
  126. package/dist/collection/components/design-system/checkbox-component/checkbox-component.js.map +1 -1
  127. package/dist/collection/components/design-system/input-component/input-component.css +9 -1
  128. package/dist/collection/components/design-system/input-component/input-component.js +20 -8
  129. package/dist/collection/components/design-system/input-component/input-component.js.map +1 -1
  130. package/dist/collection/components/design-system/input-dropdown/input-dropdown.js +1 -1
  131. package/dist/collection/components/design-system/multi-select-dropdown/multi-select-dropdown.css +8 -1
  132. package/dist/collection/components/design-system/multi-select-dropdown/multi-select-dropdown.js +21 -2
  133. package/dist/collection/components/design-system/multi-select-dropdown/multi-select-dropdown.js.map +1 -1
  134. package/dist/collection/components/design-system/radio-button-group/radio-button-group.css +57 -1
  135. package/dist/collection/components/design-system/radio-button-group/radio-button-group.js +69 -10
  136. package/dist/collection/components/design-system/radio-button-group/radio-button-group.js.map +1 -1
  137. package/dist/collection/components/design-system/select-dropdown/select-dropdown.js +45 -2
  138. package/dist/collection/components/design-system/select-dropdown/select-dropdown.js.map +1 -1
  139. package/dist/collection/components/design-system/textarea-component/textarea-component.js +23 -3
  140. package/dist/collection/components/design-system/textarea-component/textarea-component.js.map +1 -1
  141. package/dist/collection/components/design-system/time-period-selector/time-period-selector.js +1 -1
  142. package/dist/collection/components/design-system/toggle-switch/toggle-switch.css +1 -1
  143. package/dist/collection/components/design-system/toggle-switch/toggle-switch.js +5 -5
  144. package/dist/collection/components/design-system/toggle-switch/toggle-switch.js.map +1 -1
  145. package/dist/collection/components/design-system/tooltip-component/toolitp-component.js +1 -1
  146. package/dist/collection/components/mailbox/nylas-composer/nylas-composer.js +1 -1
  147. package/dist/collection/components/mailbox/nylas-list-folders/nylas-list-folders.js +1 -1
  148. package/dist/collection/components/mailbox/nylas-list-threads/nylas-list-threads.js +1 -1
  149. package/dist/collection/components/mailbox/nylas-mailbox/nylas-mailbox.js +1 -1
  150. package/dist/collection/components/mailbox/nylas-mailbox-toolbar-button/nylas-mailbox-toolbar-button.js +1 -1
  151. package/dist/collection/components/mailbox/nylas-summarize-message-button/nylas-summarize-message-button.js +2 -2
  152. package/dist/collection/components/mailbox/nylas-threads-refresh/nylas-threads-refresh.js +2 -2
  153. package/dist/collection/components/mailbox/nylas-threads-search/nylas-threads-search.js +1 -1
  154. package/dist/collection/components/mailbox/nylas-view-email/nylas-view-email.js +1 -1
  155. package/dist/collection/components/mailbox/nylas-view-thread/nylas-view-thread.js +1 -1
  156. package/dist/collection/components/nylas-if-state/nylas-if-state.js +1 -1
  157. package/dist/collection/components/nylas-login/nylas-login.js +1 -1
  158. package/dist/collection/components/nylas-provider/nylas-provider.js +1 -1
  159. package/dist/collection/components/scheduler/nylas-booked-event-card/nylas-booked-event-card.js +23 -4
  160. package/dist/collection/components/scheduler/nylas-booked-event-card/nylas-booked-event-card.js.map +1 -1
  161. package/dist/collection/components/scheduler/nylas-booked-event-card/test/nylas-booked-event-card.spec.js +1 -0
  162. package/dist/collection/components/scheduler/nylas-booked-event-card/test/nylas-booked-event-card.spec.js.map +1 -1
  163. package/dist/collection/components/scheduler/nylas-booking-form/nylas-booking-form.js +37 -21
  164. package/dist/collection/components/scheduler/nylas-booking-form/nylas-booking-form.js.map +1 -1
  165. package/dist/collection/components/scheduler/nylas-cancel-booking-form/nylas-cancel-booking-form.js +42 -3
  166. package/dist/collection/components/scheduler/nylas-cancel-booking-form/nylas-cancel-booking-form.js.map +1 -1
  167. package/dist/collection/components/scheduler/nylas-cancel-booking-form/test/nylas-cancel-booking-form.spec.js +11 -0
  168. package/dist/collection/components/scheduler/nylas-cancel-booking-form/test/nylas-cancel-booking-form.spec.js.map +1 -1
  169. package/dist/collection/components/scheduler/nylas-cancelled-event-card/nylas-cancelled-event-card.js +2 -2
  170. package/dist/collection/components/scheduler/nylas-date-picker/nylas-date-picker.js +1 -1
  171. package/dist/collection/components/scheduler/nylas-notification/nylas-notification.js +1 -1
  172. package/dist/collection/components/scheduler/nylas-scheduling/nylas-scheduling.css +4 -1
  173. package/dist/collection/components/scheduler/nylas-scheduling/nylas-scheduling.js +3 -3
  174. package/dist/collection/components/scheduler/nylas-scheduling/nylas-scheduling.js.map +1 -1
  175. package/dist/collection/components/scheduler/nylas-selected-event-card/nylas-selected-event-card.js +1 -1
  176. package/dist/collection/components/scheduler/nylas-timeslot-picker/nylas-timeslot-picker.css +2 -2
  177. package/dist/collection/components/scheduler/nylas-timeslot-picker/nylas-timeslot-picker.js +8 -7
  178. package/dist/collection/components/scheduler/nylas-timeslot-picker/nylas-timeslot-picker.js.map +1 -1
  179. package/dist/collection/components/scheduler-editor/nylas-additional-participants/nylas-additional-participants.css +16 -2
  180. package/dist/collection/components/scheduler-editor/nylas-additional-participants/nylas-additional-participants.js +31 -12
  181. package/dist/collection/components/scheduler-editor/nylas-additional-participants/nylas-additional-participants.js.map +1 -1
  182. package/dist/collection/components/scheduler-editor/nylas-availability-picker/nylas-availability-picker.css +3 -0
  183. package/dist/collection/components/scheduler-editor/nylas-availability-picker/nylas-availability-picker.js +2 -2
  184. package/dist/collection/components/scheduler-editor/nylas-availability-picker/nylas-availability-picker.js.map +1 -1
  185. package/dist/collection/components/scheduler-editor/nylas-booking-calendar-picker/nylas-booking-calendar-picker.css +3 -0
  186. package/dist/collection/components/scheduler-editor/nylas-booking-calendar-picker/nylas-booking-calendar-picker.js +22 -6
  187. package/dist/collection/components/scheduler-editor/nylas-booking-calendar-picker/nylas-booking-calendar-picker.js.map +1 -1
  188. package/dist/collection/components/scheduler-editor/nylas-booking-form-config/nylas-booking-form-config.css +233 -0
  189. package/dist/collection/components/scheduler-editor/nylas-booking-form-config/nylas-booking-form-config.js +388 -0
  190. package/dist/collection/components/scheduler-editor/nylas-booking-form-config/nylas-booking-form-config.js.map +1 -0
  191. package/dist/collection/components/scheduler-editor/nylas-calendar-picker/nylas-calendar-picker.css +3 -20
  192. package/dist/collection/components/scheduler-editor/nylas-calendar-picker/nylas-calendar-picker.js +19 -9
  193. package/dist/collection/components/scheduler-editor/nylas-calendar-picker/nylas-calendar-picker.js.map +1 -1
  194. package/dist/collection/components/scheduler-editor/nylas-cancellation-policy/nylas-cancellation-policy.js +1 -1
  195. package/dist/collection/components/scheduler-editor/nylas-connected-calendars/nylas-connected-calendars.css +105 -0
  196. package/dist/collection/components/scheduler-editor/nylas-connected-calendars/nylas-connected-calendars.js +298 -0
  197. package/dist/collection/components/scheduler-editor/nylas-connected-calendars/nylas-connected-calendars.js.map +1 -0
  198. package/dist/collection/components/scheduler-editor/nylas-custom-booking-flow/nylas-custom-booking-flow.js +1 -1
  199. package/dist/collection/components/scheduler-editor/nylas-customize-booking-settings/nylas-customize-booking-settings.js +5 -5
  200. package/dist/collection/components/scheduler-editor/nylas-customize-booking-settings/nylas-customize-booking-settings.js.map +1 -1
  201. package/dist/collection/components/scheduler-editor/nylas-editor-tabs/nylas-editor-tabs.css +3 -0
  202. package/dist/collection/components/scheduler-editor/nylas-editor-tabs/nylas-editor-tabs.js +106 -20
  203. package/dist/collection/components/scheduler-editor/nylas-editor-tabs/nylas-editor-tabs.js.map +1 -1
  204. package/dist/collection/components/scheduler-editor/nylas-editor-tabs/tab-contents.js +7 -7
  205. package/dist/collection/components/scheduler-editor/nylas-editor-tabs/tab-contents.js.map +1 -1
  206. package/dist/collection/components/scheduler-editor/nylas-event-info/nylas-event-info.js +1 -1
  207. package/dist/collection/components/scheduler-editor/nylas-event-limits/nylas-event-limits.js +1 -1
  208. package/dist/collection/components/scheduler-editor/nylas-event-limits/nylas-event-limits.js.map +1 -1
  209. package/dist/collection/components/scheduler-editor/nylas-event-location/nylas-event-location.js +161 -11
  210. package/dist/collection/components/scheduler-editor/nylas-event-location/nylas-event-location.js.map +1 -1
  211. package/dist/collection/components/scheduler-editor/nylas-event-title/nylas-event-title.js +1 -1
  212. package/dist/collection/components/scheduler-editor/nylas-event-title/nylas-event-title.js.map +1 -1
  213. package/dist/collection/components/scheduler-editor/nylas-form-card/nylas-form-card.js +1 -1
  214. package/dist/collection/components/scheduler-editor/nylas-limit-future-bookings/nylas-limit-future-bookings.js +1 -1
  215. package/dist/collection/components/scheduler-editor/nylas-limit-future-bookings/nylas-limit-future-bookings.js.map +1 -1
  216. package/dist/collection/components/scheduler-editor/nylas-list-configurations/nylas-list-configurations.css +79 -3
  217. package/dist/collection/components/scheduler-editor/nylas-list-configurations/nylas-list-configurations.js +125 -22
  218. package/dist/collection/components/scheduler-editor/nylas-list-configurations/nylas-list-configurations.js.map +1 -1
  219. package/dist/collection/components/scheduler-editor/nylas-min-booking-notice/nylas-min-booking-notice.js +1 -1
  220. package/dist/collection/components/scheduler-editor/nylas-min-booking-notice/nylas-min-booking-notice.js.map +1 -1
  221. package/dist/collection/components/scheduler-editor/nylas-min-cancellation-notice/nylas-min-cancellation-notice.js +1 -1
  222. package/dist/collection/components/scheduler-editor/nylas-min-cancellation-notice/nylas-min-cancellation-notice.js.map +1 -1
  223. package/dist/collection/components/scheduler-editor/nylas-participant-booking-calendars/nylas-participant-booking-calendars.css +105 -0
  224. package/dist/collection/components/scheduler-editor/nylas-participant-booking-calendars/nylas-participant-booking-calendars.js +324 -0
  225. package/dist/collection/components/scheduler-editor/nylas-participant-booking-calendars/nylas-participant-booking-calendars.js.map +1 -0
  226. package/dist/collection/components/scheduler-editor/nylas-participants-custom-availability/nylas-participants-custom-availability.js +39 -5
  227. package/dist/collection/components/scheduler-editor/nylas-participants-custom-availability/nylas-participants-custom-availability.js.map +1 -1
  228. package/dist/collection/components/scheduler-editor/nylas-scheduler-editor/ExpressFlow.js +4 -3
  229. package/dist/collection/components/scheduler-editor/nylas-scheduler-editor/ExpressFlow.js.map +1 -1
  230. package/dist/collection/components/scheduler-editor/nylas-scheduler-editor/nylas-scheduler-editor.js +59 -9
  231. package/dist/collection/components/scheduler-editor/nylas-scheduler-editor/nylas-scheduler-editor.js.map +1 -1
  232. package/dist/collection/components/scheduler-editor/nylas-time-window-picker/nylas-time-window-picker.js +1 -1
  233. package/dist/collection/components/scheduler-editor/nylas-timeslot-interval/nylas-timeslot-interval.js +16 -16
  234. package/dist/collection/components/scheduler-editor/nylas-timeslot-interval/nylas-timeslot-interval.js.map +1 -1
  235. package/dist/collection/connector/shared/api/scheduler-config.js +4 -2
  236. package/dist/collection/connector/shared/api/scheduler-config.js.map +1 -1
  237. package/dist/collection/connector/shared/api/scheduler.js +41 -6
  238. package/dist/collection/connector/shared/api/scheduler.js.map +1 -1
  239. package/dist/collection/stores/scheduler-config-store.js +2 -0
  240. package/dist/collection/stores/scheduler-config-store.js.map +1 -1
  241. package/dist/collection/stores/scheduler-store.js +1 -0
  242. package/dist/collection/stores/scheduler-store.js.map +1 -1
  243. package/dist/collection/types/index.js.map +1 -1
  244. package/dist/components/add-circle.js +1 -1
  245. package/dist/components/archive.js +1 -1
  246. package/dist/components/arrow.js +1 -1
  247. package/dist/components/bold.js +1 -1
  248. package/dist/components/button-component2.js +2 -2
  249. package/dist/components/button-component2.js.map +1 -1
  250. package/dist/components/calendar-agenda-fill-icon.d.ts +11 -0
  251. package/dist/components/calendar-agenda-fill-icon.js +8 -0
  252. package/dist/components/calendar-agenda-fill-icon.js.map +1 -0
  253. package/dist/components/calendar-agenda-fill.js +37 -0
  254. package/dist/components/calendar-agenda-fill.js.map +1 -0
  255. package/dist/components/calendar-agenda-icon.d.ts +11 -0
  256. package/dist/components/calendar-agenda-icon.js +8 -0
  257. package/dist/components/calendar-agenda-icon.js.map +1 -0
  258. package/dist/components/calendar-agenda.js +37 -0
  259. package/dist/components/calendar-agenda.js.map +1 -0
  260. package/dist/components/checkbox-component2.js +18 -4
  261. package/dist/components/checkbox-component2.js.map +1 -1
  262. package/dist/components/constants.js +102 -1
  263. package/dist/components/constants.js.map +1 -1
  264. package/dist/components/copy-icon.d.ts +11 -0
  265. package/dist/components/copy-icon.js +8 -0
  266. package/dist/components/copy-icon.js.map +1 -0
  267. package/dist/components/copy.js +37 -0
  268. package/dist/components/copy.js.map +1 -0
  269. package/dist/components/delete-icon.d.ts +11 -0
  270. package/dist/components/delete-icon.js +8 -0
  271. package/dist/components/delete-icon.js.map +1 -0
  272. package/dist/components/delete.js +37 -0
  273. package/dist/components/delete.js.map +1 -0
  274. package/dist/components/document-refresh-icon.js +1 -1
  275. package/dist/components/dragable-icon.d.ts +11 -0
  276. package/dist/components/dragable-icon.js +8 -0
  277. package/dist/components/dragable-icon.js.map +1 -0
  278. package/dist/components/dragable.js +37 -0
  279. package/dist/components/dragable.js.map +1 -0
  280. package/dist/components/edit-icon.d.ts +11 -0
  281. package/dist/components/edit-icon.js +8 -0
  282. package/dist/components/edit-icon.js.map +1 -0
  283. package/dist/components/edit.js +37 -0
  284. package/dist/components/edit.js.map +1 -0
  285. package/dist/components/eye-icon.d.ts +11 -0
  286. package/dist/components/eye-icon.js +8 -0
  287. package/dist/components/eye-icon.js.map +1 -0
  288. package/dist/components/eye.js +37 -0
  289. package/dist/components/eye.js.map +1 -0
  290. package/dist/components/flow.js +1 -1
  291. package/dist/components/folder.js +1 -1
  292. package/dist/components/forward.js +1 -1
  293. package/dist/components/globe.js +1 -1
  294. package/dist/components/google-logo.js +1 -1
  295. package/dist/components/google-meet-icon.d.ts +11 -0
  296. package/dist/components/google-meet-icon.js +8 -0
  297. package/dist/components/google-meet-icon.js.map +1 -0
  298. package/dist/components/google-meet.js +37 -0
  299. package/dist/components/google-meet.js.map +1 -0
  300. package/dist/components/inbox.js +1 -1
  301. package/dist/components/info.js +1 -1
  302. package/dist/components/input-component2.js +17 -6
  303. package/dist/components/input-component2.js.map +1 -1
  304. package/dist/components/input-dropdown2.js +1 -1
  305. package/dist/components/italic.js +1 -1
  306. package/dist/components/loading.js +1 -1
  307. package/dist/components/location-off.js +1 -1
  308. package/dist/components/location.js +1 -1
  309. package/dist/components/microsof-teams.js +37 -0
  310. package/dist/components/microsof-teams.js.map +1 -0
  311. package/dist/components/microsoft-logo.js +1 -1
  312. package/dist/components/microsoft-teams-icon.d.ts +11 -0
  313. package/dist/components/microsoft-teams-icon.js +8 -0
  314. package/dist/components/microsoft-teams-icon.js.map +1 -0
  315. package/dist/components/multi-select-dropdown2.js +5 -3
  316. package/dist/components/multi-select-dropdown2.js.map +1 -1
  317. package/dist/components/nylas-additional-participants2.js +26 -8
  318. package/dist/components/nylas-additional-participants2.js.map +1 -1
  319. package/dist/components/nylas-api-request.js +1 -0
  320. package/dist/components/nylas-api-request.js.map +1 -1
  321. package/dist/components/nylas-availability-picker2.js +2 -2
  322. package/dist/components/nylas-availability-picker2.js.map +1 -1
  323. package/dist/components/nylas-booked-event-card2.js +7 -4
  324. package/dist/components/nylas-booked-event-card2.js.map +1 -1
  325. package/dist/components/nylas-booking-calendar-picker2.js +5 -6
  326. package/dist/components/nylas-booking-calendar-picker2.js.map +1 -1
  327. package/dist/components/nylas-booking-form-config.d.ts +11 -0
  328. package/dist/components/nylas-booking-form-config.js +8 -0
  329. package/dist/components/nylas-booking-form-config.js.map +1 -0
  330. package/dist/components/nylas-booking-form-config2.js +3691 -0
  331. package/dist/components/nylas-booking-form-config2.js.map +1 -0
  332. package/dist/components/nylas-booking-form2.js +78 -32
  333. package/dist/components/nylas-booking-form2.js.map +1 -1
  334. package/dist/components/nylas-calendar-picker2.js +27 -23
  335. package/dist/components/nylas-calendar-picker2.js.map +1 -1
  336. package/dist/components/nylas-cancel-booking-form2.js +21 -2
  337. package/dist/components/nylas-cancel-booking-form2.js.map +1 -1
  338. package/dist/components/nylas-cancellation-policy2.js +1 -1
  339. package/dist/components/nylas-cancelled-event-card2.js +1 -1
  340. package/dist/components/nylas-composer2.js +1 -1
  341. package/dist/components/nylas-connected-calendars.d.ts +11 -0
  342. package/dist/components/nylas-connected-calendars.js +8 -0
  343. package/dist/components/nylas-connected-calendars.js.map +1 -0
  344. package/dist/components/nylas-connected-calendars2.js +232 -0
  345. package/dist/components/nylas-connected-calendars2.js.map +1 -0
  346. package/dist/components/nylas-custom-booking-flow.js +1 -1
  347. package/dist/components/nylas-customize-booking-settings2.js +4 -4
  348. package/dist/components/nylas-customize-booking-settings2.js.map +1 -1
  349. package/dist/components/nylas-editor-tabs2.js +251 -113
  350. package/dist/components/nylas-editor-tabs2.js.map +1 -1
  351. package/dist/components/nylas-event-info2.js +1 -1
  352. package/dist/components/nylas-event-limits2.js +1 -1
  353. package/dist/components/nylas-event-limits2.js.map +1 -1
  354. package/dist/components/nylas-event-location2.js +138 -25
  355. package/dist/components/nylas-event-location2.js.map +1 -1
  356. package/dist/components/nylas-event-title2.js +1 -1
  357. package/dist/components/nylas-event-title2.js.map +1 -1
  358. package/dist/components/nylas-form-card2.js +1 -1
  359. package/dist/components/nylas-if-state.js +1 -1
  360. package/dist/components/nylas-limit-future-bookings2.js +1 -1
  361. package/dist/components/nylas-limit-future-bookings2.js.map +1 -1
  362. package/dist/components/nylas-list-configurations2.js +142 -25
  363. package/dist/components/nylas-list-configurations2.js.map +1 -1
  364. package/dist/components/nylas-list-folders.js +1 -1
  365. package/dist/components/nylas-list-threads.js +1 -1
  366. package/dist/components/nylas-login.js +1 -1
  367. package/dist/components/nylas-logo2.js +1 -1
  368. package/dist/components/nylas-mailbox-toolbar-button.js +1 -1
  369. package/dist/components/nylas-mailbox.js +1 -1
  370. package/dist/components/nylas-min-booking-notice2.js +1 -1
  371. package/dist/components/nylas-min-booking-notice2.js.map +1 -1
  372. package/dist/components/nylas-min-cancellation-notice2.js +1 -1
  373. package/dist/components/nylas-min-cancellation-notice2.js.map +1 -1
  374. package/dist/components/nylas-notification2.js +1 -1
  375. package/dist/components/nylas-participant-booking-calendars.d.ts +11 -0
  376. package/dist/components/nylas-participant-booking-calendars.js +8 -0
  377. package/dist/components/nylas-participant-booking-calendars.js.map +1 -0
  378. package/dist/components/nylas-participant-booking-calendars2.js +237 -0
  379. package/dist/components/nylas-participant-booking-calendars2.js.map +1 -0
  380. package/dist/components/nylas-participants-custom-availability2.js +18 -5
  381. package/dist/components/nylas-participants-custom-availability2.js.map +1 -1
  382. package/dist/components/nylas-provider.js +1 -1
  383. package/dist/components/nylas-scheduler-editor.js +210 -101
  384. package/dist/components/nylas-scheduler-editor.js.map +1 -1
  385. package/dist/components/nylas-scheduling.js +70 -52
  386. package/dist/components/nylas-scheduling.js.map +1 -1
  387. package/dist/components/nylas-summarize-message-button2.js +2 -2
  388. package/dist/components/nylas-threads-refresh.js +2 -2
  389. package/dist/components/nylas-threads-search.js +1 -1
  390. package/dist/components/nylas-time-window-picker2.js +1 -1
  391. package/dist/components/nylas-timeslot-interval2.js +11 -11
  392. package/dist/components/nylas-timeslot-interval2.js.map +1 -1
  393. package/dist/components/nylas-timeslot-picker2.js +6 -5
  394. package/dist/components/nylas-timeslot-picker2.js.map +1 -1
  395. package/dist/components/nylas-view-email2.js +1 -1
  396. package/dist/components/nylas-view-thread.js +1 -1
  397. package/dist/components/people.js +1 -1
  398. package/dist/components/person.js +1 -1
  399. package/dist/components/play.js +1 -1
  400. package/dist/components/plus-icon.d.ts +11 -0
  401. package/dist/components/plus-icon.js +8 -0
  402. package/dist/components/plus-icon.js.map +1 -0
  403. package/dist/components/plus.js +37 -0
  404. package/dist/components/plus.js.map +1 -0
  405. package/dist/components/radio-button-group2.js +23 -6
  406. package/dist/components/radio-button-group2.js.map +1 -1
  407. package/dist/components/refresh.js +1 -1
  408. package/dist/components/reply-all.js +1 -1
  409. package/dist/components/reply.js +1 -1
  410. package/dist/components/scheduler-config-store.js +2 -0
  411. package/dist/components/scheduler-config-store.js.map +1 -1
  412. package/dist/components/scheduler-store.js +42 -6
  413. package/dist/components/scheduler-store.js.map +1 -1
  414. package/dist/components/search.js +1 -1
  415. package/dist/components/select-dropdown2.js +12 -2
  416. package/dist/components/select-dropdown2.js.map +1 -1
  417. package/dist/components/sent.js +1 -1
  418. package/dist/components/spam.js +1 -1
  419. package/dist/components/star.js +1 -1
  420. package/dist/components/stop.js +1 -1
  421. package/dist/components/textarea-component.js +1 -82
  422. package/dist/components/textarea-component.js.map +1 -1
  423. package/dist/components/textarea-component2.js +89 -0
  424. package/dist/components/textarea-component2.js.map +1 -0
  425. package/dist/components/time-period-selector2.js +1 -1
  426. package/dist/components/toggle-switch2.js +2 -2
  427. package/dist/components/toggle-switch2.js.map +1 -1
  428. package/dist/components/toolitp-component.js +1 -1
  429. package/dist/components/translate.js +1 -1
  430. package/dist/components/trash.js +1 -1
  431. package/dist/components/underline.js +1 -1
  432. package/dist/components/warning.js +1 -1
  433. package/dist/components/zoom-icon.d.ts +11 -0
  434. package/dist/components/zoom-icon.js +8 -0
  435. package/dist/components/zoom-icon.js.map +1 -0
  436. package/dist/components/zoom.js +37 -0
  437. package/dist/components/zoom.js.map +1 -0
  438. package/dist/esm/add-circle-icon_2.entry.js +1 -1
  439. package/dist/esm/archive-icon_7.entry.js +7 -7
  440. package/dist/esm/arrow-icon.entry.js +1 -1
  441. package/dist/esm/bold-icon_3.entry.js +3 -3
  442. package/dist/esm/button-component_4.entry.js +196 -0
  443. package/dist/esm/button-component_4.entry.js.map +1 -0
  444. package/dist/esm/calendar-agenda-fill-icon_35.entry.js +6905 -0
  445. package/dist/esm/calendar-agenda-fill-icon_35.entry.js.map +1 -0
  446. package/dist/esm/chevron-icon_3.entry.js +11 -3
  447. package/dist/esm/chevron-icon_3.entry.js.map +1 -1
  448. package/dist/esm/clock-icon_2.entry.js +1 -1
  449. package/dist/esm/{constants-f34b9c6e.js → constants-7ce66b44.js} +103 -2
  450. package/dist/esm/{constants-f34b9c6e.js.map → constants-7ce66b44.js.map} +1 -1
  451. package/dist/esm/copy-icon_4.entry.js +65 -0
  452. package/dist/esm/copy-icon_4.entry.js.map +1 -0
  453. package/dist/esm/document-refresh-icon.entry.js +1 -1
  454. package/dist/esm/forward-icon_6.entry.js +7 -7
  455. package/dist/esm/globe-icon.entry.js +1 -1
  456. package/dist/esm/google-logo-icon_4.entry.js +192 -51
  457. package/dist/esm/google-logo-icon_4.entry.js.map +1 -1
  458. package/dist/esm/index-7cb0dd3d.js +20 -16
  459. package/dist/esm/index.js +1 -1
  460. package/dist/esm/info-icon_2.entry.js +2 -2
  461. package/dist/esm/input-dropdown_2.entry.js +2 -2
  462. package/dist/esm/loader.js +1 -1
  463. package/dist/esm/loading-icon.entry.js +1 -1
  464. package/dist/esm/multi-select-dropdown.entry.js +140 -0
  465. package/dist/esm/multi-select-dropdown.entry.js.map +1 -0
  466. package/dist/esm/{nylas-api-request-a67d2997.js → nylas-api-request-4f8edff2.js} +2 -1
  467. package/dist/esm/nylas-api-request-4f8edff2.js.map +1 -0
  468. package/dist/esm/nylas-booked-event-card_10.entry.js +66 -35
  469. package/dist/esm/nylas-booked-event-card_10.entry.js.map +1 -1
  470. package/dist/esm/nylas-custom-booking-flow.entry.js +1 -1
  471. package/dist/esm/nylas-form-card.entry.js +1 -1
  472. package/dist/esm/nylas-if-state.entry.js +1 -1
  473. package/dist/esm/nylas-list-folders.entry.js +1 -1
  474. package/dist/esm/nylas-list-threads.entry.js +1 -1
  475. package/dist/esm/nylas-login.entry.js +1 -1
  476. package/dist/esm/nylas-mailbox-toolbar-button.entry.js +1 -1
  477. package/dist/esm/nylas-mailbox.entry.js +1 -1
  478. package/dist/esm/nylas-provider.entry.js +3 -3
  479. package/dist/esm/nylas-scheduler-editor.entry.js +26 -9
  480. package/dist/esm/nylas-scheduler-editor.entry.js.map +1 -1
  481. package/dist/esm/nylas-scheduling.entry.js +3 -3
  482. package/dist/esm/nylas-scheduling.entry.js.map +1 -1
  483. package/dist/esm/nylas-threads-refresh.entry.js +2 -2
  484. package/dist/esm/nylas-threads-search.entry.js +1 -1
  485. package/dist/esm/nylas-time-window-picker.entry.js +1 -1
  486. package/dist/esm/nylas-view-thread.entry.js +1 -1
  487. package/dist/esm/nylas-web-elements.js +1 -1
  488. package/dist/esm/play-icon_2.entry.js +2 -2
  489. package/dist/esm/refresh-icon.entry.js +1 -1
  490. package/dist/esm/{scheduler-config-store-4a50a03d.js → scheduler-config-store-9ccfba4d.js} +3 -1
  491. package/dist/esm/scheduler-config-store-9ccfba4d.js.map +1 -0
  492. package/dist/esm/{scheduler-store-f02ce045.js → scheduler-store-8a400448.js} +43 -7
  493. package/dist/esm/scheduler-store-8a400448.js.map +1 -0
  494. package/dist/esm/textarea-component.entry.js +3 -1
  495. package/dist/esm/textarea-component.entry.js.map +1 -1
  496. package/dist/esm/translate-icon.entry.js +1 -1
  497. package/dist/esm/warning-icon.entry.js +1 -1
  498. package/dist/nylas-web-elements/index.esm.js +1 -1
  499. package/dist/nylas-web-elements/nylas-web-elements.esm.js +1 -1
  500. package/dist/nylas-web-elements/nylas-web-elements.esm.js.map +1 -1
  501. package/dist/nylas-web-elements/p-0161429f.entry.js +2 -0
  502. package/dist/nylas-web-elements/{p-33a6a75b.entry.js.map → p-0161429f.entry.js.map} +1 -1
  503. package/dist/nylas-web-elements/p-064c2ae5.entry.js +2 -0
  504. package/dist/nylas-web-elements/{p-de7b0878.entry.js → p-0aa1e433.entry.js} +2 -2
  505. package/dist/nylas-web-elements/{p-3f122804.entry.js → p-0bf6f818.entry.js} +2 -2
  506. package/dist/nylas-web-elements/p-1102df14.entry.js +2 -0
  507. package/dist/nylas-web-elements/{p-f1a54acf.entry.js → p-155e5ce8.entry.js} +2 -2
  508. package/dist/nylas-web-elements/{p-a85408e0.entry.js → p-18d100c8.entry.js} +2 -2
  509. package/dist/nylas-web-elements/{p-5231fc13.entry.js → p-1a7edf86.entry.js} +3 -3
  510. package/dist/nylas-web-elements/p-1d8c468f.entry.js +2 -0
  511. package/dist/nylas-web-elements/p-1d8c468f.entry.js.map +1 -0
  512. package/dist/nylas-web-elements/{p-be38a8eb.entry.js → p-1e1ae8d0.entry.js} +2 -2
  513. package/dist/nylas-web-elements/p-1f290858.entry.js +2 -0
  514. package/dist/nylas-web-elements/p-1f290858.entry.js.map +1 -0
  515. package/dist/nylas-web-elements/{p-eb7e8455.entry.js → p-1fbe50b1.entry.js} +2 -2
  516. package/dist/nylas-web-elements/p-20bbc663.js +2 -0
  517. package/dist/nylas-web-elements/p-20bbc663.js.map +1 -0
  518. package/dist/nylas-web-elements/{p-49f716ed.js → p-2270e6cf.js} +4 -4
  519. package/dist/nylas-web-elements/p-2270e6cf.js.map +1 -0
  520. package/dist/nylas-web-elements/{p-70e5cfb0.entry.js → p-22e05c7d.entry.js} +2 -2
  521. package/dist/nylas-web-elements/{p-554891cd.entry.js → p-26302ad0.entry.js} +2 -2
  522. package/dist/nylas-web-elements/p-27df8f01.entry.js +2 -0
  523. package/dist/nylas-web-elements/p-27df8f01.entry.js.map +1 -0
  524. package/dist/nylas-web-elements/p-2b1d53fa.entry.js +8 -0
  525. package/dist/nylas-web-elements/p-2b1d53fa.entry.js.map +1 -0
  526. package/dist/nylas-web-elements/{p-6ce66add.entry.js → p-2f47205d.entry.js} +2 -2
  527. package/dist/nylas-web-elements/{p-28512ab6.entry.js → p-3277023d.entry.js} +2 -2
  528. package/dist/nylas-web-elements/{p-1a27960b.entry.js → p-3423de64.entry.js} +2 -2
  529. package/dist/nylas-web-elements/p-3423de64.entry.js.map +1 -0
  530. package/dist/nylas-web-elements/{p-b0c8021f.entry.js → p-34c747f9.entry.js} +2 -2
  531. package/dist/nylas-web-elements/{p-d9a91bc9.entry.js → p-359af1e3.entry.js} +2 -2
  532. package/dist/nylas-web-elements/p-359af1e3.entry.js.map +1 -0
  533. package/dist/nylas-web-elements/{p-613c070f.js → p-371b20b2.js} +2 -2
  534. package/dist/nylas-web-elements/p-371b20b2.js.map +1 -0
  535. package/dist/nylas-web-elements/{p-e9ba368f.entry.js → p-3ae38e51.entry.js} +2 -2
  536. package/dist/nylas-web-elements/{p-6ef1024f.entry.js → p-3bc1289e.entry.js} +2 -2
  537. package/dist/nylas-web-elements/{p-7fcecf3f.entry.js → p-3d1e8e4d.entry.js} +2 -2
  538. package/dist/nylas-web-elements/{p-45c37986.entry.js → p-3dae0c71.entry.js} +2 -2
  539. package/dist/nylas-web-elements/{p-acadfabf.entry.js → p-3db7ab8d.entry.js} +3 -3
  540. package/dist/nylas-web-elements/{p-66493463.entry.js → p-3e09b0fb.entry.js} +2 -2
  541. package/dist/nylas-web-elements/{p-5c3c1888.entry.js → p-3eac9f45.entry.js} +2 -2
  542. package/dist/nylas-web-elements/{p-dcc27b67.entry.js → p-4000107d.entry.js} +2 -2
  543. package/dist/nylas-web-elements/p-40cad9a8.entry.js +11 -0
  544. package/dist/nylas-web-elements/p-40cad9a8.entry.js.map +1 -0
  545. package/dist/nylas-web-elements/p-445d8bb4.entry.js +11 -0
  546. package/dist/nylas-web-elements/p-445d8bb4.entry.js.map +1 -0
  547. package/dist/nylas-web-elements/{p-08d75d35.entry.js → p-47392968.entry.js} +2 -2
  548. package/dist/nylas-web-elements/{p-16a3bfb2.entry.js → p-4a594ebe.entry.js} +2 -2
  549. package/dist/nylas-web-elements/{p-d633e735.entry.js → p-4b6995fe.entry.js} +2 -2
  550. package/dist/nylas-web-elements/p-4cdd4107.entry.js +2 -0
  551. package/dist/nylas-web-elements/{p-39fd9c90.entry.js → p-4e8c8939.entry.js} +2 -2
  552. package/dist/nylas-web-elements/{p-9b68568e.entry.js → p-4e9ba325.entry.js} +2 -2
  553. package/dist/nylas-web-elements/p-4f55d0e5.entry.js +2 -0
  554. package/dist/nylas-web-elements/{p-12b83ea9.entry.js.map → p-4f55d0e5.entry.js.map} +1 -1
  555. package/dist/nylas-web-elements/{p-9794f735.entry.js → p-524a6acc.entry.js} +2 -2
  556. package/dist/nylas-web-elements/{p-6bd9c9c3.entry.js → p-533d39ce.entry.js} +2 -2
  557. package/dist/nylas-web-elements/{p-e928898a.entry.js → p-5a379fb5.entry.js} +2 -2
  558. package/dist/nylas-web-elements/{p-c90755ba.entry.js → p-5a68368a.entry.js} +2 -2
  559. package/dist/nylas-web-elements/{p-37f41a90.entry.js → p-5b965d0d.entry.js} +2 -2
  560. package/dist/nylas-web-elements/p-5e1cd3c1.entry.js +2 -0
  561. package/dist/nylas-web-elements/p-5e1cd3c1.entry.js.map +1 -0
  562. package/dist/nylas-web-elements/{p-34f0d1fe.entry.js → p-5ff4e63b.entry.js} +2 -2
  563. package/dist/nylas-web-elements/p-62aeac5f.entry.js +2 -0
  564. package/dist/nylas-web-elements/p-62aeac5f.entry.js.map +1 -0
  565. package/dist/nylas-web-elements/p-64d43339.entry.js +2 -0
  566. package/dist/nylas-web-elements/p-64d43339.entry.js.map +1 -0
  567. package/dist/nylas-web-elements/p-656cf33f.entry.js +2 -0
  568. package/dist/nylas-web-elements/{p-cf589eab.entry.js → p-65b7a2a7.entry.js} +2 -2
  569. package/dist/nylas-web-elements/p-68471dbd.entry.js +8 -0
  570. package/dist/nylas-web-elements/p-68471dbd.entry.js.map +1 -0
  571. package/dist/nylas-web-elements/p-692852d2.entry.js +2 -0
  572. package/dist/nylas-web-elements/p-692852d2.entry.js.map +1 -0
  573. package/dist/nylas-web-elements/{p-60b03f86.entry.js → p-6c8af4fb.entry.js} +2 -2
  574. package/dist/nylas-web-elements/p-6d410f0a.entry.js +2 -0
  575. package/dist/nylas-web-elements/{p-daac96cb.entry.js → p-6e50d2fd.entry.js} +3 -3
  576. package/dist/nylas-web-elements/p-6e8b7ce8.entry.js +2 -0
  577. package/dist/nylas-web-elements/p-7042eb03.entry.js +2 -0
  578. package/dist/nylas-web-elements/{p-958746a1.entry.js.map → p-7042eb03.entry.js.map} +1 -1
  579. package/dist/nylas-web-elements/{p-b9fa6848.entry.js → p-7355937b.entry.js} +2 -2
  580. package/dist/nylas-web-elements/p-749238c6.entry.js +2 -0
  581. package/dist/nylas-web-elements/p-749238c6.entry.js.map +1 -0
  582. package/dist/nylas-web-elements/p-76156a82.entry.js +2 -0
  583. package/dist/nylas-web-elements/p-79c1475e.entry.js +11 -0
  584. package/dist/nylas-web-elements/p-79c1475e.entry.js.map +1 -0
  585. package/dist/nylas-web-elements/p-79c33cf9.entry.js +2 -0
  586. package/dist/nylas-web-elements/p-79c33cf9.entry.js.map +1 -0
  587. package/dist/nylas-web-elements/{p-052bc3b1.entry.js → p-7e08f131.entry.js} +2 -2
  588. package/dist/nylas-web-elements/{p-a12f3223.entry.js → p-7e10aa6d.entry.js} +2 -2
  589. package/dist/nylas-web-elements/{p-a7b19349.entry.js → p-7e53588e.entry.js} +2 -2
  590. package/dist/nylas-web-elements/p-83de54ae.entry.js +2 -0
  591. package/dist/nylas-web-elements/{p-b2d95965.entry.js → p-884b66bd.entry.js} +2 -2
  592. package/dist/nylas-web-elements/p-8aac762b.entry.js +2 -0
  593. package/dist/nylas-web-elements/p-8aac762b.entry.js.map +1 -0
  594. package/dist/nylas-web-elements/p-8d74c874.js +2 -0
  595. package/dist/nylas-web-elements/p-8d74c874.js.map +1 -0
  596. package/dist/nylas-web-elements/{p-a800e7af.entry.js → p-8ddf6518.entry.js} +2 -2
  597. package/dist/nylas-web-elements/p-8ddf6518.entry.js.map +1 -0
  598. package/dist/nylas-web-elements/{p-7a95bc3f.entry.js → p-90294a76.entry.js} +2 -2
  599. package/dist/nylas-web-elements/p-90817d1f.entry.js +2 -0
  600. package/dist/nylas-web-elements/{p-f1b0120b.entry.js → p-90d32fc3.entry.js} +2 -2
  601. package/dist/nylas-web-elements/p-94a93ca9.entry.js +2 -0
  602. package/dist/nylas-web-elements/p-94a93ca9.entry.js.map +1 -0
  603. package/dist/nylas-web-elements/p-95a9d2f1.entry.js +2 -0
  604. package/dist/nylas-web-elements/p-96746b87.entry.js +2 -0
  605. package/dist/nylas-web-elements/p-97026709.entry.js +2 -0
  606. package/dist/nylas-web-elements/{p-65097f45.entry.js → p-987042a1.entry.js} +2 -2
  607. package/dist/nylas-web-elements/{p-7ce048c0.entry.js → p-9f903292.entry.js} +2 -2
  608. package/dist/nylas-web-elements/{p-bd34f97d.entry.js → p-9fdbeba5.entry.js} +2 -2
  609. package/dist/nylas-web-elements/{p-2a92691a.entry.js → p-a22908ba.entry.js} +2 -2
  610. package/dist/nylas-web-elements/{p-091a8f00.entry.js → p-a3c76c06.entry.js} +2 -2
  611. package/dist/nylas-web-elements/{p-520ffe94.entry.js → p-a63d6241.entry.js} +2 -2
  612. package/dist/nylas-web-elements/{p-cf0d5ab9.entry.js → p-aa4e6e5e.entry.js} +2 -2
  613. package/dist/nylas-web-elements/{p-ba5a625c.entry.js → p-ab050d5b.entry.js} +2 -2
  614. package/dist/nylas-web-elements/p-b2b2d351.entry.js +2 -0
  615. package/dist/nylas-web-elements/p-b2b2d351.entry.js.map +1 -0
  616. package/dist/nylas-web-elements/{p-161c9325.entry.js → p-b348aad4.entry.js} +2 -2
  617. package/dist/nylas-web-elements/{p-bfe8e06b.entry.js → p-b547209f.entry.js} +2 -2
  618. package/dist/nylas-web-elements/{p-e8cde784.entry.js → p-b5b051e0.entry.js} +2 -2
  619. package/dist/nylas-web-elements/{p-aae7febd.entry.js → p-b7a53268.entry.js} +2 -2
  620. package/dist/nylas-web-elements/p-b8a9e8f4.entry.js +2 -0
  621. package/dist/nylas-web-elements/p-b8a9e8f4.entry.js.map +1 -0
  622. package/dist/nylas-web-elements/{p-385070ba.entry.js → p-bc6c9256.entry.js} +2 -2
  623. package/dist/nylas-web-elements/{p-cb03e4d4.entry.js → p-be26ce19.entry.js} +2 -2
  624. package/dist/nylas-web-elements/{p-8a4ac2a4.entry.js → p-bed6d217.entry.js} +2 -2
  625. package/dist/nylas-web-elements/p-bf4e0d2a.entry.js +2 -0
  626. package/dist/nylas-web-elements/p-bf4e0d2a.entry.js.map +1 -0
  627. package/dist/nylas-web-elements/{p-8e63b66c.entry.js → p-cb9fd100.entry.js} +2 -2
  628. package/dist/nylas-web-elements/p-ce14a1d5.entry.js +2 -0
  629. package/dist/nylas-web-elements/{p-1fa7b832.entry.js.map → p-ce14a1d5.entry.js.map} +1 -1
  630. package/dist/nylas-web-elements/{p-44507695.entry.js → p-cee0929a.entry.js} +2 -2
  631. package/dist/nylas-web-elements/{p-b334d63b.entry.js → p-cffb3636.entry.js} +2 -2
  632. package/dist/nylas-web-elements/{p-b2aca6c4.entry.js → p-d1ab9d75.entry.js} +2 -2
  633. package/dist/nylas-web-elements/p-d6a19e25.entry.js +2 -0
  634. package/dist/nylas-web-elements/p-d6a19e25.entry.js.map +1 -0
  635. package/dist/nylas-web-elements/{p-f96b12de.entry.js → p-d830e428.entry.js} +2 -2
  636. package/dist/nylas-web-elements/{p-8075a758.entry.js → p-d9b08dd2.entry.js} +2 -2
  637. package/dist/nylas-web-elements/{p-8f843faf.entry.js → p-db73506b.entry.js} +2 -2
  638. package/dist/nylas-web-elements/p-dcf99ddf.entry.js +2 -0
  639. package/dist/nylas-web-elements/p-dcf99ddf.entry.js.map +1 -0
  640. package/dist/nylas-web-elements/{p-d513d2ee.entry.js → p-de2f4643.entry.js} +2 -2
  641. package/dist/nylas-web-elements/{p-f2d1b1a6.entry.js.map → p-de2f4643.entry.js.map} +1 -1
  642. package/dist/nylas-web-elements/{p-25c97a60.entry.js → p-de84d999.entry.js} +2 -2
  643. package/dist/nylas-web-elements/p-debf614f.entry.js +8 -0
  644. package/dist/nylas-web-elements/p-debf614f.entry.js.map +1 -0
  645. package/dist/nylas-web-elements/{p-158fe1e9.entry.js → p-dfe9b5d0.entry.js} +2 -2
  646. package/dist/nylas-web-elements/{p-085950eb.entry.js → p-e5452799.entry.js} +2 -2
  647. package/dist/nylas-web-elements/{p-f8653b9b.entry.js → p-e6e79d76.entry.js} +2 -2
  648. package/dist/nylas-web-elements/{p-b813eb5d.entry.js → p-e944aa75.entry.js} +2 -2
  649. package/dist/nylas-web-elements/p-ec844414.entry.js +2 -0
  650. package/dist/nylas-web-elements/{p-34f0d1fe.entry.js.map → p-ec844414.entry.js.map} +1 -1
  651. package/dist/nylas-web-elements/p-ed64716c.entry.js +2 -0
  652. package/dist/nylas-web-elements/p-ed64716c.entry.js.map +1 -0
  653. package/dist/nylas-web-elements/{p-ecaf3ae1.entry.js → p-eff175d3.entry.js} +2 -2
  654. package/dist/nylas-web-elements/{p-246983ed.entry.js → p-eff774e6.entry.js} +2 -2
  655. package/dist/nylas-web-elements/p-f03b9d40.entry.js +2 -0
  656. package/dist/nylas-web-elements/p-f03b9d40.entry.js.map +1 -0
  657. package/dist/nylas-web-elements/{p-2f148064.entry.js → p-f13b8bd3.entry.js} +2 -2
  658. package/dist/nylas-web-elements/{p-8f3b02cd.entry.js → p-f7465959.entry.js} +2 -2
  659. package/dist/nylas-web-elements/p-f8e8270d.entry.js +2 -0
  660. package/dist/nylas-web-elements/p-f8e8270d.entry.js.map +1 -0
  661. package/dist/types/common/constants.d.ts +17 -0
  662. package/dist/types/common/icons/calendar-agenda-fill.d.ts +5 -0
  663. package/dist/types/common/icons/calendar-agenda.d.ts +5 -0
  664. package/dist/types/common/icons/copy.d.ts +5 -0
  665. package/dist/types/common/icons/delete.d.ts +5 -0
  666. package/dist/types/common/icons/dragable.d.ts +5 -0
  667. package/dist/types/common/icons/edit.d.ts +5 -0
  668. package/dist/types/common/icons/eye.d.ts +5 -0
  669. package/dist/types/common/icons/google-meet.d.ts +5 -0
  670. package/dist/types/common/icons/microsof-teams.d.ts +5 -0
  671. package/dist/types/common/icons/plus.d.ts +5 -0
  672. package/dist/types/common/icons/zoom.d.ts +5 -0
  673. package/dist/types/common/nylas-api-request.d.ts +1 -0
  674. package/dist/types/common/types.d.ts +1 -0
  675. package/dist/types/components/design-system/checkbox-component/checkbox-component.d.ts +3 -0
  676. package/dist/types/components/design-system/input-component/input-component.d.ts +2 -1
  677. package/dist/types/components/design-system/multi-select-dropdown/multi-select-dropdown.d.ts +1 -0
  678. package/dist/types/components/design-system/radio-button-group/radio-button-group.d.ts +6 -1
  679. package/dist/types/components/design-system/select-dropdown/select-dropdown.d.ts +3 -0
  680. package/dist/types/components/design-system/textarea-component/textarea-component.d.ts +2 -0
  681. package/dist/types/components/scheduler/nylas-booked-event-card/nylas-booked-event-card.d.ts +1 -0
  682. package/dist/types/components/scheduler/nylas-booking-form/nylas-booking-form.d.ts +8 -6
  683. package/dist/types/components/scheduler/nylas-cancel-booking-form/nylas-cancel-booking-form.d.ts +3 -2
  684. package/dist/types/components/scheduler-editor/nylas-additional-participants/nylas-additional-participants.d.ts +7 -4
  685. package/dist/types/components/scheduler-editor/nylas-booking-calendar-picker/nylas-booking-calendar-picker.d.ts +1 -0
  686. package/dist/types/components/scheduler-editor/nylas-booking-form-config/nylas-booking-form-config.d.ts +51 -0
  687. package/dist/types/components/scheduler-editor/nylas-calendar-picker/nylas-calendar-picker.d.ts +1 -0
  688. package/dist/types/components/scheduler-editor/nylas-connected-calendars/nylas-connected-calendars.d.ts +41 -0
  689. package/dist/types/components/scheduler-editor/nylas-customize-booking-settings/nylas-customize-booking-settings.d.ts +1 -1
  690. package/dist/types/components/scheduler-editor/nylas-editor-tabs/nylas-editor-tabs.d.ts +27 -4
  691. package/dist/types/components/scheduler-editor/nylas-editor-tabs/tab-contents.d.ts +2 -1
  692. package/dist/types/components/scheduler-editor/nylas-event-location/nylas-event-location.d.ts +7 -1
  693. package/dist/types/components/scheduler-editor/nylas-list-configurations/nylas-list-configurations.d.ts +13 -2
  694. package/dist/types/components/scheduler-editor/nylas-participant-booking-calendars/nylas-participant-booking-calendars.d.ts +43 -0
  695. package/dist/types/components/scheduler-editor/nylas-participants-custom-availability/nylas-participants-custom-availability.d.ts +4 -2
  696. package/dist/types/components/scheduler-editor/nylas-scheduler-editor/ExpressFlow.d.ts +11 -2
  697. package/dist/types/components/scheduler-editor/nylas-scheduler-editor/nylas-scheduler-editor.d.ts +4 -2
  698. package/dist/types/components/scheduler-editor/nylas-timeslot-interval/nylas-timeslot-interval.d.ts +2 -2
  699. package/dist/types/components.d.ts +723 -30
  700. package/dist/types/connector/shared/api/scheduler-config.d.ts +1 -1
  701. package/dist/types/stores/scheduler-config-store.d.ts +5 -2
  702. package/dist/types/stores/scheduler-store.d.ts +3 -1
  703. package/dist/types/types/index.d.ts +8 -0
  704. package/package.json +4 -3
  705. package/dist/cjs/button-component.cjs.entry.js +0 -31
  706. package/dist/cjs/button-component.cjs.entry.js.map +0 -1
  707. package/dist/cjs/calendar-info-icon_28.cjs.entry.js +0 -2935
  708. package/dist/cjs/calendar-info-icon_28.cjs.entry.js.map +0 -1
  709. package/dist/cjs/input-component.cjs.entry.js +0 -89
  710. package/dist/cjs/input-component.cjs.entry.js.map +0 -1
  711. package/dist/cjs/nylas-api-request-a1751a40.js.map +0 -1
  712. package/dist/cjs/scheduler-config-store-9f19c7a9.js.map +0 -1
  713. package/dist/cjs/scheduler-store-0f7328f1.js.map +0 -1
  714. package/dist/esm/button-component.entry.js +0 -27
  715. package/dist/esm/button-component.entry.js.map +0 -1
  716. package/dist/esm/calendar-info-icon_28.entry.js +0 -2904
  717. package/dist/esm/calendar-info-icon_28.entry.js.map +0 -1
  718. package/dist/esm/input-component.entry.js +0 -85
  719. package/dist/esm/input-component.entry.js.map +0 -1
  720. package/dist/esm/nylas-api-request-a67d2997.js.map +0 -1
  721. package/dist/esm/scheduler-config-store-4a50a03d.js.map +0 -1
  722. package/dist/esm/scheduler-store-f02ce045.js.map +0 -1
  723. package/dist/nylas-web-elements/p-019be093.entry.js +0 -11
  724. package/dist/nylas-web-elements/p-019be093.entry.js.map +0 -1
  725. package/dist/nylas-web-elements/p-05833164.entry.js +0 -2
  726. package/dist/nylas-web-elements/p-05833164.entry.js.map +0 -1
  727. package/dist/nylas-web-elements/p-061d0ae2.entry.js +0 -2
  728. package/dist/nylas-web-elements/p-061d0ae2.entry.js.map +0 -1
  729. package/dist/nylas-web-elements/p-0c31f7ca.entry.js +0 -2
  730. package/dist/nylas-web-elements/p-0d98c728.entry.js +0 -2
  731. package/dist/nylas-web-elements/p-0d98c728.entry.js.map +0 -1
  732. package/dist/nylas-web-elements/p-12b83ea9.entry.js +0 -2
  733. package/dist/nylas-web-elements/p-16fb6243.entry.js +0 -2
  734. package/dist/nylas-web-elements/p-1970b6ee.entry.js +0 -2
  735. package/dist/nylas-web-elements/p-1a27960b.entry.js.map +0 -1
  736. package/dist/nylas-web-elements/p-1fa7b832.entry.js +0 -2
  737. package/dist/nylas-web-elements/p-26976360.entry.js +0 -2
  738. package/dist/nylas-web-elements/p-26976360.entry.js.map +0 -1
  739. package/dist/nylas-web-elements/p-29938263.js +0 -2
  740. package/dist/nylas-web-elements/p-29938263.js.map +0 -1
  741. package/dist/nylas-web-elements/p-33a6a75b.entry.js +0 -2
  742. package/dist/nylas-web-elements/p-36f4b804.entry.js +0 -2
  743. package/dist/nylas-web-elements/p-36f4b804.entry.js.map +0 -1
  744. package/dist/nylas-web-elements/p-39160c0d.entry.js +0 -11
  745. package/dist/nylas-web-elements/p-39160c0d.entry.js.map +0 -1
  746. package/dist/nylas-web-elements/p-3b6bd448.entry.js +0 -2
  747. package/dist/nylas-web-elements/p-3eeab083.entry.js +0 -2
  748. package/dist/nylas-web-elements/p-49f716ed.js.map +0 -1
  749. package/dist/nylas-web-elements/p-53a1bb82.entry.js +0 -2
  750. package/dist/nylas-web-elements/p-53a1bb82.entry.js.map +0 -1
  751. package/dist/nylas-web-elements/p-5bed86c2.entry.js +0 -2
  752. package/dist/nylas-web-elements/p-5ddd0c37.entry.js +0 -2
  753. package/dist/nylas-web-elements/p-613c070f.js.map +0 -1
  754. package/dist/nylas-web-elements/p-644ff4ee.entry.js +0 -2
  755. package/dist/nylas-web-elements/p-644ff4ee.entry.js.map +0 -1
  756. package/dist/nylas-web-elements/p-64d73008.entry.js +0 -2
  757. package/dist/nylas-web-elements/p-6ddb4b95.entry.js +0 -2
  758. package/dist/nylas-web-elements/p-6ddb4b95.entry.js.map +0 -1
  759. package/dist/nylas-web-elements/p-823c8aa2.js +0 -2
  760. package/dist/nylas-web-elements/p-823c8aa2.js.map +0 -1
  761. package/dist/nylas-web-elements/p-83444c0a.entry.js +0 -2
  762. package/dist/nylas-web-elements/p-83444c0a.entry.js.map +0 -1
  763. package/dist/nylas-web-elements/p-8506a8d4.entry.js +0 -11
  764. package/dist/nylas-web-elements/p-8506a8d4.entry.js.map +0 -1
  765. package/dist/nylas-web-elements/p-926dd201.entry.js +0 -2
  766. package/dist/nylas-web-elements/p-9283504a.entry.js +0 -2
  767. package/dist/nylas-web-elements/p-9283504a.entry.js.map +0 -1
  768. package/dist/nylas-web-elements/p-958746a1.entry.js +0 -2
  769. package/dist/nylas-web-elements/p-9bb41364.entry.js +0 -2
  770. package/dist/nylas-web-elements/p-9bb41364.entry.js.map +0 -1
  771. package/dist/nylas-web-elements/p-a800e7af.entry.js.map +0 -1
  772. package/dist/nylas-web-elements/p-a8678862.entry.js +0 -2
  773. package/dist/nylas-web-elements/p-aac962c7.entry.js +0 -2
  774. package/dist/nylas-web-elements/p-aac962c7.entry.js.map +0 -1
  775. package/dist/nylas-web-elements/p-b4d09fcf.entry.js +0 -2
  776. package/dist/nylas-web-elements/p-b4d09fcf.entry.js.map +0 -1
  777. package/dist/nylas-web-elements/p-b9559f06.entry.js +0 -2
  778. package/dist/nylas-web-elements/p-b9559f06.entry.js.map +0 -1
  779. package/dist/nylas-web-elements/p-bab1d562.entry.js +0 -2
  780. package/dist/nylas-web-elements/p-bab1d562.entry.js.map +0 -1
  781. package/dist/nylas-web-elements/p-c18c15d0.entry.js +0 -2
  782. package/dist/nylas-web-elements/p-c1ff6499.entry.js +0 -2
  783. package/dist/nylas-web-elements/p-c1ff6499.entry.js.map +0 -1
  784. package/dist/nylas-web-elements/p-d5d67115.entry.js +0 -2
  785. package/dist/nylas-web-elements/p-d5d67115.entry.js.map +0 -1
  786. package/dist/nylas-web-elements/p-d9a91bc9.entry.js.map +0 -1
  787. package/dist/nylas-web-elements/p-ea12997b.entry.js +0 -2
  788. package/dist/nylas-web-elements/p-f2d1b1a6.entry.js +0 -2
  789. package/dist/nylas-web-elements/p-f6fafe86.entry.js +0 -2
  790. package/dist/nylas-web-elements/p-f6fafe86.entry.js.map +0 -1
  791. package/dist/nylas-web-elements/p-ffce3a49.entry.js +0 -2
  792. package/dist/nylas-web-elements/p-ffce3a49.entry.js.map +0 -1
  793. /package/dist/nylas-web-elements/{p-08d75d35.entry.js.map → p-064c2ae5.entry.js.map} +0 -0
  794. /package/dist/nylas-web-elements/{p-5bed86c2.entry.js.map → p-0aa1e433.entry.js.map} +0 -0
  795. /package/dist/nylas-web-elements/{p-3f122804.entry.js.map → p-0bf6f818.entry.js.map} +0 -0
  796. /package/dist/nylas-web-elements/{p-926dd201.entry.js.map → p-1102df14.entry.js.map} +0 -0
  797. /package/dist/nylas-web-elements/{p-a7b19349.entry.js.map → p-155e5ce8.entry.js.map} +0 -0
  798. /package/dist/nylas-web-elements/{p-a85408e0.entry.js.map → p-18d100c8.entry.js.map} +0 -0
  799. /package/dist/nylas-web-elements/{p-5231fc13.entry.js.map → p-1a7edf86.entry.js.map} +0 -0
  800. /package/dist/nylas-web-elements/{p-554891cd.entry.js.map → p-1e1ae8d0.entry.js.map} +0 -0
  801. /package/dist/nylas-web-elements/{p-65097f45.entry.js.map → p-1fbe50b1.entry.js.map} +0 -0
  802. /package/dist/nylas-web-elements/{p-70e5cfb0.entry.js.map → p-22e05c7d.entry.js.map} +0 -0
  803. /package/dist/nylas-web-elements/{p-be38a8eb.entry.js.map → p-26302ad0.entry.js.map} +0 -0
  804. /package/dist/nylas-web-elements/{p-2a92691a.entry.js.map → p-2f47205d.entry.js.map} +0 -0
  805. /package/dist/nylas-web-elements/{p-085950eb.entry.js.map → p-3277023d.entry.js.map} +0 -0
  806. /package/dist/nylas-web-elements/{p-64d73008.entry.js.map → p-34c747f9.entry.js.map} +0 -0
  807. /package/dist/nylas-web-elements/{p-45c37986.entry.js.map → p-3ae38e51.entry.js.map} +0 -0
  808. /package/dist/nylas-web-elements/{p-0c31f7ca.entry.js.map → p-3bc1289e.entry.js.map} +0 -0
  809. /package/dist/nylas-web-elements/{p-5ddd0c37.entry.js.map → p-3d1e8e4d.entry.js.map} +0 -0
  810. /package/dist/nylas-web-elements/{p-e9ba368f.entry.js.map → p-3dae0c71.entry.js.map} +0 -0
  811. /package/dist/nylas-web-elements/{p-acadfabf.entry.js.map → p-3db7ab8d.entry.js.map} +0 -0
  812. /package/dist/nylas-web-elements/{p-28512ab6.entry.js.map → p-3e09b0fb.entry.js.map} +0 -0
  813. /package/dist/nylas-web-elements/{p-158fe1e9.entry.js.map → p-3eac9f45.entry.js.map} +0 -0
  814. /package/dist/nylas-web-elements/{p-d513d2ee.entry.js.map → p-4000107d.entry.js.map} +0 -0
  815. /package/dist/nylas-web-elements/{p-3b6bd448.entry.js.map → p-47392968.entry.js.map} +0 -0
  816. /package/dist/nylas-web-elements/{p-16a3bfb2.entry.js.map → p-4a594ebe.entry.js.map} +0 -0
  817. /package/dist/nylas-web-elements/{p-c90755ba.entry.js.map → p-4b6995fe.entry.js.map} +0 -0
  818. /package/dist/nylas-web-elements/{p-b2d95965.entry.js.map → p-4cdd4107.entry.js.map} +0 -0
  819. /package/dist/nylas-web-elements/{p-25c97a60.entry.js.map → p-4e8c8939.entry.js.map} +0 -0
  820. /package/dist/nylas-web-elements/{p-6bd9c9c3.entry.js.map → p-4e9ba325.entry.js.map} +0 -0
  821. /package/dist/nylas-web-elements/{p-6ce66add.entry.js.map → p-524a6acc.entry.js.map} +0 -0
  822. /package/dist/nylas-web-elements/{p-9b68568e.entry.js.map → p-533d39ce.entry.js.map} +0 -0
  823. /package/dist/nylas-web-elements/{p-7a95bc3f.entry.js.map → p-5a379fb5.entry.js.map} +0 -0
  824. /package/dist/nylas-web-elements/{p-cb03e4d4.entry.js.map → p-5a68368a.entry.js.map} +0 -0
  825. /package/dist/nylas-web-elements/{p-1970b6ee.entry.js.map → p-5b965d0d.entry.js.map} +0 -0
  826. /package/dist/nylas-web-elements/{p-091a8f00.entry.js.map → p-5ff4e63b.entry.js.map} +0 -0
  827. /package/dist/nylas-web-elements/{p-37f41a90.entry.js.map → p-656cf33f.entry.js.map} +0 -0
  828. /package/dist/nylas-web-elements/{p-246983ed.entry.js.map → p-65b7a2a7.entry.js.map} +0 -0
  829. /package/dist/nylas-web-elements/{p-60b03f86.entry.js.map → p-6c8af4fb.entry.js.map} +0 -0
  830. /package/dist/nylas-web-elements/{p-8e63b66c.entry.js.map → p-6d410f0a.entry.js.map} +0 -0
  831. /package/dist/nylas-web-elements/{p-daac96cb.entry.js.map → p-6e50d2fd.entry.js.map} +0 -0
  832. /package/dist/nylas-web-elements/{p-c18c15d0.entry.js.map → p-6e8b7ce8.entry.js.map} +0 -0
  833. /package/dist/nylas-web-elements/{p-b9fa6848.entry.js.map → p-7355937b.entry.js.map} +0 -0
  834. /package/dist/nylas-web-elements/{p-a8678862.entry.js.map → p-76156a82.entry.js.map} +0 -0
  835. /package/dist/nylas-web-elements/{p-052bc3b1.entry.js.map → p-7e08f131.entry.js.map} +0 -0
  836. /package/dist/nylas-web-elements/{p-2f148064.entry.js.map → p-7e10aa6d.entry.js.map} +0 -0
  837. /package/dist/nylas-web-elements/{p-b2aca6c4.entry.js.map → p-7e53588e.entry.js.map} +0 -0
  838. /package/dist/nylas-web-elements/{p-aae7febd.entry.js.map → p-83de54ae.entry.js.map} +0 -0
  839. /package/dist/nylas-web-elements/{p-de7b0878.entry.js.map → p-884b66bd.entry.js.map} +0 -0
  840. /package/dist/nylas-web-elements/{p-e928898a.entry.js.map → p-90294a76.entry.js.map} +0 -0
  841. /package/dist/nylas-web-elements/{p-3eeab083.entry.js.map → p-90817d1f.entry.js.map} +0 -0
  842. /package/dist/nylas-web-elements/{p-f1b0120b.entry.js.map → p-90d32fc3.entry.js.map} +0 -0
  843. /package/dist/nylas-web-elements/{p-dcc27b67.entry.js.map → p-95a9d2f1.entry.js.map} +0 -0
  844. /package/dist/nylas-web-elements/{p-6ef1024f.entry.js.map → p-96746b87.entry.js.map} +0 -0
  845. /package/dist/nylas-web-elements/{p-7fcecf3f.entry.js.map → p-97026709.entry.js.map} +0 -0
  846. /package/dist/nylas-web-elements/{p-eb7e8455.entry.js.map → p-987042a1.entry.js.map} +0 -0
  847. /package/dist/nylas-web-elements/{p-44507695.entry.js.map → p-9f903292.entry.js.map} +0 -0
  848. /package/dist/nylas-web-elements/{p-7ce048c0.entry.js.map → p-9fdbeba5.entry.js.map} +0 -0
  849. /package/dist/nylas-web-elements/{p-9794f735.entry.js.map → p-a22908ba.entry.js.map} +0 -0
  850. /package/dist/nylas-web-elements/{p-16fb6243.entry.js.map → p-a3c76c06.entry.js.map} +0 -0
  851. /package/dist/nylas-web-elements/{p-520ffe94.entry.js.map → p-a63d6241.entry.js.map} +0 -0
  852. /package/dist/nylas-web-elements/{p-cf0d5ab9.entry.js.map → p-aa4e6e5e.entry.js.map} +0 -0
  853. /package/dist/nylas-web-elements/{p-ba5a625c.entry.js.map → p-ab050d5b.entry.js.map} +0 -0
  854. /package/dist/nylas-web-elements/{p-161c9325.entry.js.map → p-b348aad4.entry.js.map} +0 -0
  855. /package/dist/nylas-web-elements/{p-5c3c1888.entry.js.map → p-b547209f.entry.js.map} +0 -0
  856. /package/dist/nylas-web-elements/{p-e8cde784.entry.js.map → p-b5b051e0.entry.js.map} +0 -0
  857. /package/dist/nylas-web-elements/{p-b0c8021f.entry.js.map → p-b7a53268.entry.js.map} +0 -0
  858. /package/dist/nylas-web-elements/{p-385070ba.entry.js.map → p-bc6c9256.entry.js.map} +0 -0
  859. /package/dist/nylas-web-elements/{p-d633e735.entry.js.map → p-be26ce19.entry.js.map} +0 -0
  860. /package/dist/nylas-web-elements/{p-8a4ac2a4.entry.js.map → p-bed6d217.entry.js.map} +0 -0
  861. /package/dist/nylas-web-elements/{p-8f3b02cd.entry.js.map → p-cb9fd100.entry.js.map} +0 -0
  862. /package/dist/nylas-web-elements/{p-bd34f97d.entry.js.map → p-cee0929a.entry.js.map} +0 -0
  863. /package/dist/nylas-web-elements/{p-b334d63b.entry.js.map → p-cffb3636.entry.js.map} +0 -0
  864. /package/dist/nylas-web-elements/{p-f1a54acf.entry.js.map → p-d1ab9d75.entry.js.map} +0 -0
  865. /package/dist/nylas-web-elements/{p-f96b12de.entry.js.map → p-d830e428.entry.js.map} +0 -0
  866. /package/dist/nylas-web-elements/{p-8075a758.entry.js.map → p-d9b08dd2.entry.js.map} +0 -0
  867. /package/dist/nylas-web-elements/{p-39fd9c90.entry.js.map → p-db73506b.entry.js.map} +0 -0
  868. /package/dist/nylas-web-elements/{p-8f843faf.entry.js.map → p-de84d999.entry.js.map} +0 -0
  869. /package/dist/nylas-web-elements/{p-bfe8e06b.entry.js.map → p-dfe9b5d0.entry.js.map} +0 -0
  870. /package/dist/nylas-web-elements/{p-66493463.entry.js.map → p-e5452799.entry.js.map} +0 -0
  871. /package/dist/nylas-web-elements/{p-f8653b9b.entry.js.map → p-e6e79d76.entry.js.map} +0 -0
  872. /package/dist/nylas-web-elements/{p-b813eb5d.entry.js.map → p-e944aa75.entry.js.map} +0 -0
  873. /package/dist/nylas-web-elements/{p-a12f3223.entry.js.map → p-eff175d3.entry.js.map} +0 -0
  874. /package/dist/nylas-web-elements/{p-cf589eab.entry.js.map → p-eff774e6.entry.js.map} +0 -0
  875. /package/dist/nylas-web-elements/{p-ecaf3ae1.entry.js.map → p-f13b8bd3.entry.js.map} +0 -0
  876. /package/dist/nylas-web-elements/{p-ea12997b.entry.js.map → p-f7465959.entry.js.map} +0 -0
@@ -1,2904 +0,0 @@
1
- import { r as registerInstance, h, c as createEvent, H as Host, a as getElement } from './index-7cb0dd3d.js';
2
- import { a as debug, y as timeToMinutes, z as convertTo12HourFormat, A as convertTo24HourFormat, B as minutesToTime, C as checkForMissingSlots, D as getBrowser, E as isNonPrintableKey } from './utils-f79fc8b5.js';
3
- import { R as RegisterComponent } from './register-component-a5a9ca5d.js';
4
- import { T as TIMEZONE_MAP, E as EVENT_TITLE_TOKENS } from './constants-f34b9c6e.js';
5
- import { s as sanitizeHtml } from './index-6d9eeb53.js';
6
- import './buffer-es6-aad332f1.js';
7
- import './_commonjsHelpers-57e89916.js';
8
- import './index-53420959.js';
9
-
10
- const iconCss$5 = ".sc-calendar-info-icon-h{display:flex}";
11
- const CalendarInfoIconStyle0 = iconCss$5;
12
-
13
- const CalendarInfoIcon = class {
14
- constructor(hostRef) {
15
- registerInstance(this, hostRef);
16
- this.width = '20';
17
- this.height = '20';
18
- }
19
- render() {
20
- return (h("svg", { key: '9012ae7b873d35927c299ed62d247b77757bb679', width: this.width, height: this.height, fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { key: '0a3a11d84c99d05ad964d3b5606c072dd31872a7', d: "M12 0C13.3807 0 14.5 1.11929 14.5 2.5V6.59971C14.1832 6.43777 13.8486 6.30564 13.5 6.20703V4H1.5V11.5C1.5 12.3284 2.17157 13 3 13H6.70703C6.80564 13.3486 6.93777 13.6832 7.09971 14H3C1.61929 14 0.5 12.8807 0.5 11.5V2.5C0.5 1.11929 1.61929 0 3 0H12ZM12 1H3C2.17157 1 1.5 1.67157 1.5 2.5V3H13.5V2.5C13.5 1.67157 12.8284 1 12 1ZM11.375 9.5C11.375 9.15482 11.6548 8.875 12 8.875C12.3452 8.875 12.625 9.15482 12.625 9.5C12.625 9.84518 12.3452 10.125 12 10.125C11.6548 10.125 11.375 9.84518 11.375 9.5ZM12.5 13.5C12.5 13.7761 12.2761 14 12 14C11.7239 14 11.5 13.7761 11.5 13.5V11.5C11.5 11.2239 11.7239 11 12 11C12.2761 11 12.5 11.2239 12.5 11.5V13.5ZM7.5 11.5C7.5 9.01472 9.51472 7 12 7C14.4853 7 16.5 9.01472 16.5 11.5C16.5 13.9853 14.4853 16 12 16C9.51472 16 7.5 13.9853 7.5 11.5ZM8.5 11.5C8.5 13.433 10.067 15 12 15C13.933 15 15.5 13.433 15.5 11.5C15.5 9.567 13.933 8 12 8C10.067 8 8.5 9.567 8.5 11.5Z", fill: "currentColor" })));
21
- }
22
- };
23
- CalendarInfoIcon.style = CalendarInfoIconStyle0;
24
-
25
- const iconCss$4 = ".sc-calendar-patterns-icon-h{display:flex}";
26
- const CalendarPatternsIconStyle0 = iconCss$4;
27
-
28
- const CalendarPatternsIcon = class {
29
- constructor(hostRef) {
30
- registerInstance(this, hostRef);
31
- this.width = '20';
32
- this.height = '20';
33
- }
34
- render() {
35
- return (h("svg", { key: 'ca6df3db90bbbffc29dfdc6ee5a440266eaa153d', width: this.width, height: this.height, fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { key: 'ab45118ff407127ca1673159e1b78c93c7c97bed', d: "M3.25 0H11.75C13.2688 0 14.5 1.23122 14.5 2.75V11.25C14.5 12.7688 13.2688 14 11.75 14H3.25C1.73122 14 0.5 12.7688 0.5 11.25V2.75C0.5 1.23122 1.73122 0 3.25 0ZM2 2.75V4H13V2.75C13 2.05964 12.4404 1.5 11.75 1.5H3.25C2.55964 1.5 2 2.05964 2 2.75ZM12.2071 5L8.20711 9H10.7929L13 6.79289V5H12.2071ZM10.7929 5H8.20711L4.20711 9H6.79289L10.7929 5ZM2.79289 9L6.79289 5H4.20711L2 7.20711V9H2.79289ZM2 5.79289L2.79289 5H2V5.79289ZM12.2071 9H13V8.20711L12.2071 9Z", fill: "currentColor" })));
36
- }
37
- };
38
- CalendarPatternsIcon.style = CalendarPatternsIconStyle0;
39
-
40
- const checkboxComponentCss = "label{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;display:flex;align-items:center;font-family:var(--nylas-font-family);cursor:pointer;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}label input[type=checkbox]{position:absolute;opacity:0;cursor:pointer}label input[type=checkbox]:focus~.checkmark,label input[type=checkbox]:hover~.checkmark{border-color:var(--nylas-primary)}label input[type=checkbox]:checked~.checkmark{color:var(--nylas-base-0);background:var(--nylas-primary) url() 50% 40% no-repeat;border:2px solid var(--nylas-primary)}label .checkmark{border-radius:var(--nylas-border-radius);border:2px solid var(--nylas-base-800);position:absolute;left:0;top:2px;width:18px;height:18px;cursor:pointer;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}label .label{margin-left:32px;font-size:16px;font-weight:400;color:var(--nylas-base-800);line-height:24px}";
41
- const CheckboxComponentStyle0 = checkboxComponentCss;
42
-
43
- const CheckboxComponent = class {
44
- constructor(hostRef) {
45
- registerInstance(this, hostRef);
46
- this.nylasFormCheckboxToggled = createEvent(this, "nylasFormCheckboxToggled", 7);
47
- this.name = 'checkbox';
48
- this.checked = false;
49
- this.label = '';
50
- this.isChecked = this.checked;
51
- }
52
- componentWillLoad() {
53
- this.isChecked = this.checked;
54
- }
55
- toggleCheck() {
56
- this.isChecked = !this.isChecked;
57
- this.nylasFormCheckboxToggled.emit({
58
- checked: this.isChecked,
59
- name: this.name,
60
- label: this.label,
61
- });
62
- }
63
- render() {
64
- return (h("label", { key: 'ff418217723b6044270dc691f7d0e11aea5fb204' }, h("input", { key: 'c45008c89d147534ba6b4a70120b7c5159a25ce6', type: "checkbox", name: this.name, checked: this.isChecked, onChange: () => this.toggleCheck() }), h("span", { key: 'a785e711233dab04bb19bcf1f1c6f665d7460015', class: "checkmark" }), h("slot", { key: '05e7f91a9e038bf9a467d63c9c004f7b90454b6f', name: "label" }, h("span", { key: '35a5c8bef4f998f993fbdcf2b752b83432218422', class: "label" }, this.label))));
65
- }
66
- };
67
- CheckboxComponent.style = CheckboxComponentStyle0;
68
-
69
- const iconCss$3 = ".sc-flow-icon-h{display:flex}";
70
- const FlowIconStyle0 = iconCss$3;
71
-
72
- const FlowIcon = class {
73
- constructor(hostRef) {
74
- registerInstance(this, hostRef);
75
- this.width = '16';
76
- this.height = '12';
77
- }
78
- render() {
79
- return (h("svg", { key: '18bdb1e3a2d6d1f4b9f9e1983c1ad7156e83e489', width: this.width, height: this.height, fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { key: 'a291353c08dfca6bb961e83386a3bfe71a840299', d: "M13 1.66211C11.8954 1.66211 11 2.55754 11 3.66211C11 4.76668 11.8954 5.66211 13 5.66211C14.1046 5.66211 15 4.76668 15 3.66211C15 2.55754 14.1046 1.66211 13 1.66211ZM10.0407 3.16678C10.2768 1.74563 11.5119 0.662109 13 0.662109C14.6569 0.662109 16 2.00526 16 3.66211C16 5.31896 14.6569 6.66211 13 6.66211C11.5162 6.66211 10.2839 5.58482 10.0428 4.16971C9.37629 4.23688 8.82682 4.7426 8.71466 5.41551L8.27173 8.07311C8.07929 9.22776 7.11428 10.087 5.9593 10.1574C5.72319 11.5786 4.48813 12.6621 3 12.6621C1.34315 12.6621 0 11.319 0 9.66211C0 8.00526 1.34315 6.66211 3 6.66211C4.48384 6.66211 5.71607 7.73939 5.95724 9.15451C6.62371 9.08734 7.17318 8.58162 7.28534 7.90871L7.72827 5.25111C7.92071 4.09646 8.88571 3.23718 10.0407 3.16678ZM3 7.66211C1.89543 7.66211 1 8.55754 1 9.66211C1 10.7667 1.89543 11.6621 3 11.6621C4.10457 11.6621 5 10.7667 5 9.66211C5 8.55754 4.10457 7.66211 3 7.66211Z", fill: "currentColor" })));
80
- }
81
- };
82
- FlowIcon.style = FlowIconStyle0;
83
-
84
- const iconCss$2 = ".sc-location-icon-h{display:flex}";
85
- const LocationIconStyle0 = iconCss$2;
86
-
87
- const LocationIcon = class {
88
- constructor(hostRef) {
89
- registerInstance(this, hostRef);
90
- this.width = '16';
91
- this.height = '18';
92
- }
93
- render() {
94
- return (h("svg", { key: 'c4b6ed753f7c3c3e26ae2fe2e92b429abe4eceb4', width: this.width, height: this.height, fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { key: 'cff1afc5e511a814bfc16fc7c8fdaef6356a7952', d: "M10 7.66211C10 9.31896 8.65685 10.6621 7 10.6621C5.34315 10.6621 4 9.31896 4 7.66211C4 6.00526 5.34315 4.66211 7 4.66211C8.65685 4.66211 10 6.00526 10 7.66211ZM9 7.66211C9 6.55754 8.10457 5.66211 7 5.66211C5.89543 5.66211 5 6.55754 5 7.66211C5 8.76668 5.89543 9.66211 7 9.66211C8.10457 9.66211 9 8.76668 9 7.66211ZM11.9497 12.6171C14.6834 9.88221 14.6834 5.44812 11.9497 2.71326C9.21608 -0.0216067 4.78392 -0.0216067 2.05025 2.71326C-0.683418 5.44812 -0.683418 9.88221 2.05025 12.6171L3.57128 14.1159L5.61408 16.101L5.74691 16.2188C6.52168 16.8468 7.65623 16.8076 8.38611 16.1012L10.8223 13.7312L11.9497 12.6171ZM2.75499 3.4183C5.09944 1.07282 8.90055 1.07282 11.245 3.4183C13.5294 5.70364 13.5879 9.3725 11.4207 11.7288L11.245 11.912L9.92371 13.216L7.69315 15.3846L7.60016 15.4642C7.24594 15.732 6.7543 15.732 6.40012 15.4642L6.30713 15.3845L3.3263 12.4791L2.75499 11.912L2.57927 11.7288C0.412077 9.3725 0.47065 5.70364 2.75499 3.4183Z", fill: "currentColor" })));
95
- }
96
- };
97
- LocationIcon.style = LocationIconStyle0;
98
-
99
- const iconCss$1 = ".sc-location-off-icon-h{display:flex}";
100
- const LocationOffIconStyle0 = iconCss$1;
101
-
102
- const LocationOffIcon = class {
103
- constructor(hostRef) {
104
- registerInstance(this, hostRef);
105
- this.width = '16';
106
- this.height = '18';
107
- }
108
- render() {
109
- return (h("svg", { key: 'b7eb987c802beac155700ccbd2c51189708f3422', width: this.width, height: this.height, fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { key: '91e1d8458400d7d502def34ce86611fc17110cb4', d: "M0.146447 0.808556C0.341709 0.613294 0.658291 0.613294 0.853553 0.808556L15.8536 15.8086C16.0488 16.0038 16.0488 16.3204 15.8536 16.5157C15.6583 16.7109 15.3417 16.7109 15.1464 16.5157L12.0938 13.463L11.8223 13.7312L9.38611 16.1012C8.65623 16.8076 7.52168 16.8468 6.74691 16.2188L6.61408 16.101L4.57128 14.1159L3.05025 12.6171C0.607421 10.1732 0.347525 6.37239 2.27056 3.63976L0.146447 1.51566C-0.0488155 1.3204 -0.0488155 1.00382 0.146447 0.808556ZM9.07768 10.4469C8.74346 10.576 8.38024 10.6468 8.0005 10.6468C6.34839 10.6468 5.00909 9.30689 5.00909 7.65406C5.00909 7.27461 5.07967 6.91166 5.20843 6.57763L2.98793 4.35713C1.49206 6.62038 1.68917 9.67377 3.57927 11.7288L3.75499 11.912L4.3263 12.4791L7.30713 15.3845L7.40012 15.4642C7.7543 15.732 8.24594 15.732 8.60016 15.4642L8.69315 15.3846L10.9237 13.216L11.3883 12.7575L9.07768 10.4469ZM9.85409 8.39486L10.5983 9.13904C10.8487 8.70143 10.9919 8.19447 10.9919 7.65406C10.9919 6.00122 9.65261 4.66134 8.0005 4.66134C7.45986 4.66134 6.95271 4.80482 6.51504 5.05581L7.25921 5.79998C7.48839 5.70819 7.73855 5.6577 8.0005 5.6577C9.10258 5.6577 9.99599 6.5515 9.99599 7.65406C9.99599 7.91581 9.94564 8.16581 9.85409 8.39486ZM4.35291 2.89368C6.70671 1.08827 10.0908 1.26314 12.245 3.4183C14.3986 5.57283 14.5739 8.95702 12.771 11.3118L13.4812 12.022C15.6702 9.27273 15.493 5.25762 12.9497 2.71326C10.4058 0.168159 6.39081 -0.00843871 3.64269 2.18347L4.35291 2.89368Z", fill: "currentColor" })));
110
- }
111
- };
112
- LocationOffIcon.style = LocationOffIconStyle0;
113
-
114
- const multiSelectDropdownCss = ":host{display:block;width:inherit;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.dropdown{display:inline-block;width:100%;position:relative}.dropdown .dropdown-label{display:flex;align-items:center;gap:0.25rem;color:var(--nylas-base-800)}.dropbtn{width:inherit;height:48px;color:black;padding:0.5rem;font-size:1rem;cursor:pointer;display:flex;gap:0.5rem;justify-content:space-between;align-items:center;background:transparent;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x)}.dropbtn.focus{background:transparent}.dropbtn:hover,.dropbtn:active{border:1px solid var(--nylas-primary)}.dropbtn:active{outline:2px solid var(--nylas-primary)}.dropbtn span.open{transform:rotate(90deg)}.dropbtn span.closed{transform:rotate(270deg)}.dropdown-content{display:block;margin-top:0.5rem;background-color:var(--nylas-base-0);width:100%;max-height:336px;overflow:auto;border:1px solid #ddd;z-index:1;border-radius:4px;position:absolute;box-shadow:0px 4px 6px -2px rgba(0, 0, 0, 0.0509803922);box-shadow:0px 10px 15px -3px rgba(0, 0, 0, 0.1019607843)}.dropdown-content ul{padding:0;list-style-type:none;color:var(--nylas-base-900);max-height:336px}.dropdown-content ul li{padding:16px, 12px, 16px, 12px;color:black;padding:12px 16px;text-decoration:none;display:block;font-family:inherit;font-size:14px;font-weight:400;line-height:20px;letter-spacing:0px;text-align:left;cursor:pointer}.dropdown-content ul li:hover,.dropdown-content ul li:focus{background-color:var(--nylas-base-100)}.dropdown-content ul li label{display:flex;align-items:center;gap:0.5rem}.dropdown-content ul li label input{margin:0}.selected-options{display:flex;flex-wrap:wrap;gap:0.5rem;padding:0.5rem 0;margin-top:0.25rem;background:var(--nylas-base-0)}.selected-options .selected-option{display:flex;align-items:center;gap:0.5rem;padding:4px 8px;border-radius:var(--nylas-border-radius-2x);background:var(--nylas-base-100);color:var(--nylas-base-800);font-size:16px;font-weight:500;line-height:1.5rem;letter-spacing:0.5px}.selected-options .selected-option button{background:transparent;border:none;cursor:pointer;padding:0}.selected-options .selected-option button:hover{color:var(--nylas-primary)}";
115
- const MultiSelectDropdownStyle0 = multiSelectDropdownCss;
116
-
117
- const MultiSelectDropdown = class {
118
- constructor(hostRef) {
119
- registerInstance(this, hostRef);
120
- this.selectedOptionsChanged = createEvent(this, "selectedOptionsChanged", 7);
121
- this.name = undefined;
122
- this.label = undefined;
123
- this.options = [];
124
- this.availableOptions = this.options;
125
- this.isOpen = false;
126
- this.ariaActivedescendant = '';
127
- this.shouldFocusFirstOption = false;
128
- }
129
- componentDidRender() {
130
- debug('multi-select-dropdown', 'componentDidRender');
131
- if (this.isOpen && this.shouldFocusFirstOption) {
132
- this.ariaActivedescendant = this.availableOptions[0].value;
133
- this.focusOption(0);
134
- this.shouldFocusFirstOption = false;
135
- }
136
- }
137
- handleOutsideClick(event) {
138
- const path = event.composedPath();
139
- const isClickInside = path.includes(this.el);
140
- if (!isClickInside && this.isOpen) {
141
- this.isOpen = false;
142
- }
143
- }
144
- selectOption(option) {
145
- this.availableOptions = this.availableOptions.map(o => {
146
- if (o.value === option.value) {
147
- o.selected = option.selected ? false : true;
148
- }
149
- return o;
150
- });
151
- const selectedOptions = this.availableOptions.filter(o => o.selected).map(o => o.value);
152
- this.selectedOptionsChanged.emit({
153
- value: selectedOptions,
154
- name: this.name,
155
- });
156
- }
157
- toggleDropdown() {
158
- this.isOpen = !this.isOpen;
159
- if (this.isOpen) {
160
- this.shouldFocusFirstOption = true;
161
- }
162
- else {
163
- this.ariaActivedescendant = '';
164
- }
165
- }
166
- handleSelectButtonKeyDown(event) {
167
- switch (event.key) {
168
- case 'ArrowDown':
169
- case 'Enter':
170
- event.preventDefault();
171
- if (!this.isOpen) {
172
- this.toggleDropdown();
173
- }
174
- break;
175
- case 'Escape':
176
- this.isOpen = false;
177
- break;
178
- }
179
- }
180
- handleListboxKeydown(e) {
181
- const items = this.availableOptions;
182
- const currentIndex = items.findIndex(item => item.value === this.ariaActivedescendant);
183
- switch (e.key) {
184
- case 'ArrowDown':
185
- case 'Tab':
186
- if (!e.shiftKey) {
187
- e.preventDefault();
188
- const nextIndex = currentIndex + 1 < items.length ? currentIndex + 1 : 0;
189
- this.ariaActivedescendant = items[nextIndex].value;
190
- this.focusOption(nextIndex);
191
- }
192
- else {
193
- e.preventDefault();
194
- const prevIndex = currentIndex - 1 >= 0 ? currentIndex - 1 : items.length - 1;
195
- this.ariaActivedescendant = items[prevIndex].value;
196
- this.focusOption(prevIndex);
197
- }
198
- break;
199
- case 'ArrowUp':
200
- e.preventDefault();
201
- const prevIndex = currentIndex - 1 >= 0 ? currentIndex - 1 : items.length - 1;
202
- this.ariaActivedescendant = items[prevIndex].value;
203
- this.focusOption(prevIndex);
204
- break;
205
- case 'Enter':
206
- e.preventDefault();
207
- if (this.ariaActivedescendant) {
208
- this.selectOption(items[currentIndex]);
209
- }
210
- break;
211
- case 'Escape':
212
- this.isOpen = false;
213
- break;
214
- }
215
- }
216
- focusOption(index) {
217
- const option = this.availableOptions[index];
218
- if (!option)
219
- return;
220
- const elementId = option.value;
221
- const element = this.el.shadowRoot?.getElementById(elementId);
222
- if (element) {
223
- element.focus();
224
- element.scrollIntoView({ behavior: 'smooth', block: 'nearest' });
225
- }
226
- }
227
- getSelectedOptions() {
228
- return this.availableOptions.filter(option => option.selected);
229
- }
230
- renderOption(option) {
231
- return (h("li", { key: option.value, id: option.value, role: "option", tabindex: "0", "aria-selected": option.selected ? 'true' : 'false', onClick: e => {
232
- e.stopImmediatePropagation();
233
- this.selectOption(option);
234
- }, class: { selected: !!option.selected } }, h("label", { htmlFor: option.value }, h("input", { "aria-hidden": "true", id: option.value, type: "checkbox", checked: option.selected }), h("span", null, option.label))));
235
- }
236
- render() {
237
- return (h(Host, { key: 'af0befb6c6c059e41a99ebe56c9632e6445e897b' }, h("div", { key: 'e93abae0184670a75caa02b4f687a374fce9a055', class: "dropdown", part: "msd_dropdown" }, h("label", { key: 'cb7ab81e0c7e23934dfc814a4c5281470e2ad510', class: "dropdown-label" }, this.label, h("slot", { key: '88fdcec62b47bf2b7da977c06b36300722789373', name: "label-icon", "aria-hidden": "true" })), h("button", { key: '17e03081353c32b5f571e7655fbe7b0c2ea87a35', part: "msd_dropdown-button", class: { dropbtn: true, open: this.isOpen }, onClick: () => this.toggleDropdown(), "aria-haspopup": "listbox", "aria-expanded": this.isOpen ? 'true' : 'false', "aria-label": this.name, onKeyDown: e => this.handleSelectButtonKeyDown(e) }, h("slot", { key: 'f1925d4d315c6be091a07f18261e574792883fd7', name: "select-icon", "aria-hidden": "true" }), h("span", { key: '02c03946856eed3b6207ec84abbba0d16554af9f', class: "selected-option", part: "msd_dropdown-button-selected-label" }, this.getSelectedOptions().length > 1
238
- ? `Multiple ${this.name}s selected`
239
- : this.availableOptions.filter(o => o.selected)[0]?.label ?? this.availableOptions[0]?.label), h("span", { key: 'bbd36a37a7ee28e299da6b22612206e4bbbcf8db', class: this.isOpen ? 'open' : 'closed', "aria-hidden": "true" }, h("chevron-icon", { key: '4e6f9c3dfd33c8d87b9584648487783e417961c6', width: "16", height: "16" }))), this.isOpen ? null : (h("div", { class: 'selected-options' }, this.getSelectedOptions().map(option => (h("span", { class: "selected-option" }, option.label, h("button", { key: option.label, onClick: () => this.selectOption(option) }, h("close-icon", null))))))), this.isOpen ? (h("div", { class: "dropdown-content", part: "msd_dropdown-content" }, h("ul", { tabindex: "-1", role: "listbox", "aria-label": this.name, "aria-multiselectable": true, "aria-activedescendant": this.ariaActivedescendant, onKeyDown: e => this.handleListboxKeydown(e) }, this.availableOptions.map(option => this.renderOption(option))))) : null)));
240
- }
241
- get el() { return getElement(this); }
242
- };
243
- MultiSelectDropdown.style = MultiSelectDropdownStyle0;
244
-
245
- const nylasAdditionalParticipantsCss = ":host{display:block;margin:1rem;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-additional-participants__title{color:var(--nylas-base-nylas-base-900-aaa, #101323);font-size:16px;font-style:normal;font-weight:600;line-height:20px;margin:0;text-align:left}.nylas-additional-participants__subtitle{color:var(--nylas-base-600);font-size:14px;font-style:normal;font-weight:400;line-height:20px;margin:0.25rem 0px 0px;text-align:left}.nylas-additional-participants__content{padding:1rem;display:flex;flex-direction:column;gap:1rem}.nylas-additional-participants__input_group{padding-top:8px;display:flex;flex-direction:column;gap:4px}.nylas-additional-participants__input_group label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:14px;font-style:normal;font-weight:400;line-height:150%}.nylas-additional-participants__input_wrapper{display:flex;border-width:1;border-radius:8px;border:1px solid var(--nylas-base-300)}.nylas-additional-participants__input_wrapper button{padding:12px;border:none;border-left:1px solid var(--nylas-base-300);background:none;cursor:pointer}.nylas-additional-participants__input_wrapper button:hover,.nylas-additional-participants__input_wrapper button:active{color:var(--nylas-primary)}.nylas-additional-participants__input_wrapper_organizer{background:var(--nylas-base-50)}.nylas-additional-participants__input{flex:1;display:flex;justify-content:space-between}.nylas-additional-participants__input.organizer{padding:12px 16px}.nylas-additional-participants__input input{border:none;outline:none;background:none;width:100%}.nylas-additional-participants__input input-dropdown{width:100%}.nylas-additional-participants__input input-dropdown::part(id_dropdown){width:100%;height:100%}.nylas-additional-participants__input input-dropdown::part(id_dropdown-input){height:100%;border-radius:var(--nylas-border-radius-2x);border:none;border-top-right-radius:initial;border-bottom-right-radius:initial;padding-left:16px}.nylas-additional-participants__add{padding:12px;display:flex;align-items:center;border:none;background:none;cursor:pointer}.nylas-additional-participants__add span{padding:0 8px;font-size:16px;font-style:normal;font-weight:500}.nylas-additional-participants__add:hover,.nylas-additional-participants__add:active{color:var(--nylas-primary)}";
246
- const NylasAdditionalParticipantsStyle0 = nylasAdditionalParticipantsCss;
247
-
248
- var __decorate$h = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
249
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
250
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
251
- r = Reflect.decorate(decorators, target, key, desc);
252
- else
253
- for (var i = decorators.length - 1; i >= 0; i--)
254
- if (d = decorators[i])
255
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
256
- return c > 3 && r && Object.defineProperty(target, key, r), r;
257
- };
258
- var __metadata$h = (undefined && undefined.__metadata) || function (k, v) {
259
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
260
- return Reflect.metadata(k, v);
261
- };
262
- const NylasAdditionalParticipants = class {
263
- constructor(hostRef) {
264
- registerInstance(this, hostRef);
265
- this.valueChanged = createEvent(this, "valueChanged", 7);
266
- if (hostRef.$hostElement$["s-ei"]) {
267
- this.internals = hostRef.$hostElement$["s-ei"];
268
- }
269
- else {
270
- this.internals = hostRef.$hostElement$.attachInternals();
271
- hostRef.$hostElement$["s-ei"] = this.internals;
272
- }
273
- this.name = 'participants';
274
- this.eventParticipants = undefined;
275
- this.participantOptions = undefined;
276
- this.participants = this.eventParticipants ?? [];
277
- this.participantsValid = true;
278
- }
279
- elementNameChangedHandler(newValue) {
280
- debug('nylas-additional-participants', 'elementNameChangedHandler', newValue);
281
- this.host.setAttribute('name', newValue);
282
- }
283
- connectedCallback() {
284
- debug('nylas-additional-participants', 'connectedCallback');
285
- }
286
- componentWillLoad() {
287
- debug('nylas-additional-participants', 'componentWillLoad');
288
- this.host.setAttribute('name', this.name);
289
- }
290
- componentDidLoad() {
291
- debug('nylas-additional-participants', 'componentDidLoad');
292
- this.updateFormValue();
293
- }
294
- disconnectedCallback() {
295
- debug('nylas-additional-participants', 'disconnectedCallback');
296
- }
297
- onInputOptionChanged(event) {
298
- debug('nylas-additional-participants', 'onInputOptionChanged');
299
- const index = event.detail.name;
300
- this.participants[index].email = event.detail.value;
301
- const participant = this.participantOptions?.find(participant => participant.email === event.detail.value);
302
- this.participants[index].availability = participant ? { calendar_ids: ['primary'] } : undefined;
303
- this.participants[index].name = participant?.name || event.detail.value;
304
- this.participants = [...this.participants];
305
- this.updateFormValue();
306
- }
307
- onParticipantChange(event, index) {
308
- debug('nylas-additional-participants', 'onParticipantChange');
309
- this.participants[index].email = event.target.value;
310
- this.updateFormValue();
311
- }
312
- addParticipant() {
313
- debug('nylas-additional-participants', 'addParticipant');
314
- this.participants = [...this.participants, { name: '', email: '', is_organizer: false }];
315
- this.updateFormValue();
316
- }
317
- removeParticipant(index) {
318
- debug('nylas-additional-participants', 'removeParticipant');
319
- this.participants = this.participants.filter((_, i) => i !== index);
320
- this.updateFormValue();
321
- }
322
- validate(email, index) {
323
- debug('nylas-additional-participants', 'validate');
324
- const regex = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
325
- const valid = regex.test(String(email).toLowerCase());
326
- this.participants[index].is_valid = valid;
327
- this.updateFormValue();
328
- }
329
- updateFormValue() {
330
- debug('nylas-additional-participants', 'updateFormValue');
331
- this.internals.setFormValue(JSON.stringify(this.participants), this.name);
332
- this.valueChanged.emit({ value: JSON.stringify(this.participants), name: this.name });
333
- }
334
- getArrayDifference(array1, array2) {
335
- const filtered = array1.filter(participant1 => !array2.some(participant2 => participant1.email === participant2.email));
336
- return filtered.map(participant => {
337
- return { value: participant.email, label: participant.email };
338
- });
339
- }
340
- render() {
341
- return (h(Host, { key: '30915e4727e68b0652fc265ced20a3fce93f94d7' }, h("nylas-form-card", { key: 'e652c77a0e382aeaab234593ad1cd8fa6cc1b858' }, h("h3", { key: 'ee6d3ac07461ef43976e32069cd978a2dc32ba96', slot: "header-title", class: "nylas-additional-participants__title", part: "nap__title" }, "Additional participants"), h("p", { key: '72d712c00b839ad8220ea23cce11cfc233cf14b5', slot: "header-subtitle", class: "nylas-additional-participants__subtitle", part: "nap__subtitle" }, "Add anyone else who would be joining for this event."), h("div", { key: '87b08e14dc5a16b2381728263e079c46545284f4', slot: "content", class: "nylas-additional-participants__content" }, h("div", { key: 'da67ac11f9c977007ce885531bcdcbf9c59aca0c' }, this.participants.map((participant, index) => {
342
- return (h("div", { class: 'nylas-additional-participants__input_group', part: "nap__input_group" }, h("label", null, participant.is_organizer ? 'Organizer' : `Participant ${index}`), h("div", { part: "nap__input_wrapper", class: `nylas-additional-participants__input_wrapper ${participant.is_organizer && 'nylas-additional-participants__input_wrapper_organizer'} ${participant.is_valid === false && 'nylas-additional-participants__input_wrapper_invalid'}` }, h("div", { class: { 'nylas-additional-participants__input': true, 'organizer': participant.is_organizer }, part: "nap__input" }, participant.is_organizer ? (h("input", { type: "text", value: participant.email, onInput: e => {
343
- this.onParticipantChange(e, index);
344
- }, readOnly: participant.is_organizer, onBlur: () => this.validate(participant.email, index) })) : (h("input-dropdown", { name: `${index}`, filterable: true, inputValue: participant.email, options: this.getArrayDifference(this.participantOptions || [], this.participants) })), !participant.is_organizer && (h("button", { onClick: () => this.removeParticipant(index), part: "nap__remove-participant" }, h("close-icon", null)))))));
345
- })), h("button", { key: 'dd0f412f9affa5cf2b3ab5a331365d5b217e1ade', class: "nylas-additional-participants__add", part: "nap__add-participant", onClick: () => this.addParticipant() }, h("add-circle-icon", { key: '089167b221913ef3e0393efa23db2698a93b3e73' }), " ", h("span", { key: '70860b8258a871e714f2f33890d35ec46835f349' }, "Add ", this.participants.length > 1 ? 'another' : 'a', " participant"))))));
346
- }
347
- static get formAssociated() { return true; }
348
- get host() { return getElement(this); }
349
- static get watchers() { return {
350
- "name": ["elementNameChangedHandler"]
351
- }; }
352
- };
353
- __decorate$h([
354
- RegisterComponent({
355
- name: 'nylas-additional-participants',
356
- stateToProps: new Map([['schedulerConfig.additionalParticipants', 'participantOptions']]),
357
- eventToProps: {},
358
- fireRegisterEvent: true,
359
- }),
360
- __metadata$h("design:type", Function),
361
- __metadata$h("design:paramtypes", []),
362
- __metadata$h("design:returntype", void 0)
363
- ], NylasAdditionalParticipants.prototype, "render", null);
364
- NylasAdditionalParticipants.style = NylasAdditionalParticipantsStyle0;
365
-
366
- const nylasAvailabilityPickerCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;width:inherit}.nylas-availability-picker{width:inherit;display:flex;flex-direction:column;margin:1rem;border-radius:var(--nylas-border-radius-2x);border:1px solid var(--nylas-base-200)}.nylas-availability-picker .header{padding:1rem}.nylas-availability-picker .header h3{margin:0;font-size:16px;font-weight:600;line-height:20px;color:var(--nylas-base-900);text-align:left}.nylas-availability-picker .header p{margin:0.25rem 0 0 0;font-size:0.875rem;font-weight:400;line-height:20px;color:var(--nylas-base-600);text-align:left}.nylas-availability-picker .content{padding:1rem;color:var(--nylas-base-900);font-size:16px;font-family:var(--nylas-font-family);border-top:1px solid var(--nylas-base-200)}@media screen and (max-width: 504px){.nylas-availability-picker .content{font-size:15px}}.nylas-availability-picker .content .select-timezone{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--nylas-base-200);padding-bottom:1rem;gap:1rem}.nylas-availability-picker .content .select-timezone h4{display:flex;gap:0.5rem;align-items:center;margin:0;font-size:16px;font-weight:500;line-height:20px}@media screen and (max-width: 504px){.nylas-availability-picker .content .select-timezone h4{font-size:15px}}.nylas-availability-picker .content .availability{display:flex;flex-direction:column;gap:1rem;padding:0 0.5rem;margin:1rem 0}@media screen and (max-width: 504px){.nylas-availability-picker .content .availability{gap:0.5rem;padding:0}}.nylas-availability-picker .content .availability .availability-day{display:grid;grid-template-columns:minmax(auto, 65px) 1fr minmax(auto, 40px);gap:1rem;align-items:baseline}@media screen and (max-width: 768px){.nylas-availability-picker .content .availability .availability-day{grid-template-columns:78px 1fr auto}}@media screen and (max-width: 504px){.nylas-availability-picker .content .availability .availability-day{display:inline-grid;gap:8px;grid-template-columns:60px 1fr auto}}.nylas-availability-picker .content .availability .availability-day .day{display:flex;gap:0.5rem;align-items:center}@media screen and (max-width: 504px){.nylas-availability-picker .content .availability .availability-day .day{gap:0.25rem}}.nylas-availability-picker .content .availability .availability-day .day input[type=checkbox]{transform:scale(1.3)}.nylas-availability-picker .content .availability .availability-day .time-ranges span.unavailable{height:48px;display:flex;align-items:center;justify-content:center}.nylas-availability-picker .content .availability .availability-day .time-ranges .time-range{display:flex;gap:1.5rem;justify-content:space-between;align-items:baseline}@media screen and (max-width: 504px){.nylas-availability-picker .content .availability .availability-day .time-ranges .time-range{justify-content:unset;gap:0.5rem}}.nylas-availability-picker .content .availability .availability-day .time-ranges .time-range .pickers{display:flex;gap:1rem}@media screen and (max-width: 504px){.nylas-availability-picker .content .availability .availability-day .time-ranges .time-range .pickers{gap:0.5rem}}.nylas-availability-picker .content .availability .availability-day .time-ranges .time-range .pickers span{margin-top:0.75rem}.nylas-availability-picker .content .availability .availability-day .time-ranges .time-range:not(:last-of-type){margin-bottom:1rem}.nylas-availability-picker .content .availability .availability-day .time-ranges p.error{color:var(--nylas-error)}.nylas-availability-picker .content .availability .availability-day button{border:none;background:transparent;height:40px;cursor:pointer;color:var(--nylas-base-800)}.nylas-availability-picker .content .availability .availability-day button:hover,.nylas-availability-picker .content .availability .availability-day button:active{color:var(--nylas-primary)}select-dropdown{width:auto}select-dropdown::part(sd_dropdown-button){justify-content:initial}";
367
- const NylasAvailabilityPickerStyle0 = nylasAvailabilityPickerCss;
368
-
369
- var __decorate$g = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
370
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
371
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
372
- r = Reflect.decorate(decorators, target, key, desc);
373
- else
374
- for (var i = decorators.length - 1; i >= 0; i--)
375
- if (d = decorators[i])
376
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
377
- return c > 3 && r && Object.defineProperty(target, key, r), r;
378
- };
379
- var __metadata$g = (undefined && undefined.__metadata) || function (k, v) {
380
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
381
- return Reflect.metadata(k, v);
382
- };
383
- const NylasAvailabilityPicker = class {
384
- constructor(hostRef) {
385
- registerInstance(this, hostRef);
386
- this.valueChanged = createEvent(this, "valueChanged", 7);
387
- if (hostRef.$hostElement$["s-ei"]) {
388
- this.internals = hostRef.$hostElement$["s-ei"];
389
- }
390
- else {
391
- this.internals = hostRef.$hostElement$.attachInternals();
392
- hostRef.$hostElement$["s-ei"] = this.internals;
393
- }
394
- this.selectedConfiguration = undefined;
395
- this.openHours = undefined;
396
- this.name = 'availability';
397
- this.defaultTimezone = Intl.DateTimeFormat().resolvedOptions().timeZone;
398
- this.hideHeader = false;
399
- this.schedule = {
400
- SUN: [],
401
- MON: [{ start: '09:00am', end: '05:00pm' }],
402
- TUE: [{ start: '09:00am', end: '05:00pm' }],
403
- WED: [{ start: '09:00am', end: '05:00pm' }],
404
- THU: [{ start: '09:00am', end: '05:00pm' }],
405
- FRI: [{ start: '09:00am', end: '05:00pm' }],
406
- SAT: [],
407
- };
408
- this.timezone = Intl.DateTimeFormat().resolvedOptions().timeZone;
409
- this.overlapDays = {};
410
- }
411
- elementNameChangedHandler(newValue) {
412
- debug('nylas-calendar-picker', 'elementNameChangedHandler', newValue);
413
- this.host.setAttribute('name', newValue);
414
- }
415
- configChangedHandler(newConfig) {
416
- const defaultOpenHours = newConfig?.availability?.availability_rules?.default_open_hours;
417
- if (defaultOpenHours) {
418
- this.openHoursToSchedule(defaultOpenHours);
419
- }
420
- }
421
- scheduleChanged(newValue, oldValue) {
422
- if (newValue !== oldValue) {
423
- let overlapDays = {};
424
- Object.keys(newValue).forEach(key => {
425
- const dayTimeRanges = newValue[key];
426
- if (dayTimeRanges.length > 0) {
427
- const overlaps = this.getOverlaps(dayTimeRanges);
428
- if (overlaps.length > 0) {
429
- overlapDays[key] = overlaps;
430
- }
431
- }
432
- });
433
- this.overlapDays = overlapDays;
434
- if (typeof this.internals.setFormValue !== 'function') {
435
- return;
436
- }
437
- if (Object.keys(overlapDays).length > 0) {
438
- const element = this.host.shadowRoot?.getElementById(Object.keys(overlapDays)[0]);
439
- if (element) {
440
- debug('nylas-availability-picker', 'The time ranges are overlapping. Overlap: ', overlapDays);
441
- this.internals.setValidity({ customError: true }, 'Overlapping time ranges found', element);
442
- }
443
- }
444
- else {
445
- this.internals.setValidity({ customError: false });
446
- this.internals.setFormValue(JSON.stringify({
447
- openHours: this.scheduleToOpenHours(this.schedule),
448
- timezone: this.timezone,
449
- }));
450
- }
451
- this.valueChanged.emit({
452
- value: JSON.stringify({
453
- openHours: this.scheduleToOpenHours(newValue),
454
- timezone: this.timezone,
455
- }),
456
- name: this.name,
457
- });
458
- }
459
- }
460
- nylasFormDropdownChangedHandler(event) {
461
- const { name, value } = event.detail;
462
- if (name === 'timezone') {
463
- this.timezone = value;
464
- if (typeof this.internals.setFormValue !== 'function') {
465
- return;
466
- }
467
- const updateValue = {
468
- openHours: this.scheduleToOpenHours(this.schedule),
469
- timezone: this.timezone,
470
- };
471
- this.internals.setFormValue(JSON.stringify(updateValue));
472
- this.valueChanged.emit({
473
- value: JSON.stringify(updateValue),
474
- name: this.name,
475
- });
476
- }
477
- }
478
- connectedCallback() {
479
- debug('nylas-availability-picker', 'connectedCallback');
480
- }
481
- disconnectedCallback() {
482
- debug('nylas-availability-picker', 'disconnectedCallback');
483
- }
484
- componentWillLoad() {
485
- debug('nylas-availability-picker', 'componentWillLoad');
486
- this.host.setAttribute('name', this.name);
487
- }
488
- componentDidLoad() {
489
- debug('nylas-availability-picker', 'componentDidLoad');
490
- if (this.openHours && this.openHours.length > 0) {
491
- this.openHoursToSchedule(this.openHours);
492
- }
493
- if (typeof this.internals.setFormValue !== 'function') {
494
- return;
495
- }
496
- const updateValue = {
497
- openHours: this.scheduleToOpenHours(this.schedule),
498
- timezone: this.timezone,
499
- };
500
- this.internals.setFormValue(JSON.stringify(updateValue));
501
- this.valueChanged.emit({
502
- value: JSON.stringify(updateValue),
503
- name: this.name,
504
- });
505
- }
506
- getOverlaps(timeRanges) {
507
- let timeRangesInMinutes = timeRanges.map((range, index) => ({
508
- start: timeToMinutes(range.start),
509
- end: timeToMinutes(range.end),
510
- originalIndex: index,
511
- }));
512
- timeRangesInMinutes.sort((a, b) => a.start - b.start);
513
- let overlaps = [];
514
- for (let i = 1; i < timeRangesInMinutes.length; i++) {
515
- if (timeRangesInMinutes[i].start < timeRangesInMinutes[i - 1].end) {
516
- if (!overlaps.includes(timeRangesInMinutes[i].originalIndex)) {
517
- overlaps.push(timeRangesInMinutes[i].originalIndex);
518
- }
519
- if (!overlaps.includes(timeRangesInMinutes[i - 1].originalIndex)) {
520
- overlaps.push(timeRangesInMinutes[i - 1].originalIndex);
521
- }
522
- }
523
- }
524
- return overlaps.sort((a, b) => a - b);
525
- }
526
- addTimeRange(day) {
527
- const currentTimeRanges = this.schedule[day];
528
- const dayStart = 0;
529
- const dayEnd = 1425;
530
- if (currentTimeRanges.length === 0) {
531
- this.schedule[day] = [{ start: '09:00am', end: '05:00pm' }];
532
- }
533
- else {
534
- const timeRangesInMinutes = currentTimeRanges
535
- .map(range => ({
536
- start: timeToMinutes(range.start),
537
- end: timeToMinutes(range.end),
538
- }))
539
- .sort((a, b) => a.start - b.start);
540
- const lastRangeEnd = timeRangesInMinutes[timeRangesInMinutes.length - 1].end;
541
- if (lastRangeEnd + 60 <= dayEnd) {
542
- this.schedule[day].push({
543
- start: convertTo12HourFormat(minutesToTime(lastRangeEnd)),
544
- end: convertTo12HourFormat(minutesToTime(lastRangeEnd + 60)),
545
- });
546
- }
547
- else {
548
- let gapFound = false;
549
- if (timeRangesInMinutes[0].start > dayStart + 60) {
550
- this.schedule[day].push({
551
- start: convertTo12HourFormat(minutesToTime(dayStart)),
552
- end: convertTo12HourFormat(minutesToTime(dayStart + 60)),
553
- });
554
- gapFound = true;
555
- }
556
- if (!gapFound) {
557
- for (let i = 0; i < timeRangesInMinutes.length - 1; i++) {
558
- const currentEnd = timeRangesInMinutes[i].end;
559
- const nextStart = timeRangesInMinutes[i + 1].start;
560
- if (nextStart - currentEnd >= 60) {
561
- this.schedule[day].push({
562
- start: convertTo12HourFormat(minutesToTime(currentEnd)),
563
- end: convertTo12HourFormat(minutesToTime(currentEnd + 60)),
564
- });
565
- break;
566
- }
567
- }
568
- }
569
- }
570
- }
571
- this.schedule[day].sort((a, b) => timeToMinutes(a.start) - timeToMinutes(b.start));
572
- this.schedule = { ...this.schedule };
573
- }
574
- removeTimeRange(day, index) {
575
- this.schedule[day].splice(index, 1);
576
- this.schedule = { ...this.schedule };
577
- }
578
- setTime(event) {
579
- const { key, value } = event.detail;
580
- const [dayIndex, timeType] = key.split('_');
581
- const [day, index] = dayIndex.split(':');
582
- if (timeType === 'start') {
583
- this.schedule[day][index].start = value;
584
- }
585
- else if (timeType === 'end') {
586
- this.schedule[day][index].end = value;
587
- }
588
- this.internals.setValidity({ customError: false });
589
- this.schedule = { ...this.schedule };
590
- }
591
- setFormError(event) {
592
- const { key } = event.detail;
593
- const [_, timeType] = key.split('_');
594
- const element = this.host.shadowRoot?.getElementById(key);
595
- if (element) {
596
- this.internals.setValidity({ customError: true }, `Invalid ${timeType} time`, element);
597
- }
598
- }
599
- openHoursToSchedule(openHours) {
600
- const newSchedule = {
601
- SUN: [],
602
- MON: [],
603
- TUE: [],
604
- WED: [],
605
- THU: [],
606
- FRI: [],
607
- SAT: [],
608
- };
609
- openHours.forEach(openHour => {
610
- openHour.days.forEach(day => {
611
- const dayKey = this.getDayKey(day);
612
- const start12hr = convertTo12HourFormat(openHour.start);
613
- const end12hr = convertTo12HourFormat(openHour.end);
614
- const timeRange = { start: start12hr, end: end12hr };
615
- let timeRangeExists = false;
616
- if (newSchedule[dayKey]) {
617
- timeRangeExists = newSchedule[dayKey].some(range => range.start === timeRange.start && range.end === timeRange.end);
618
- }
619
- if (!timeRangeExists) {
620
- if (newSchedule[dayKey]) {
621
- newSchedule[dayKey].push(timeRange);
622
- }
623
- else {
624
- newSchedule[dayKey] = [timeRange];
625
- }
626
- }
627
- });
628
- });
629
- this.timezone = this.defaultTimezone;
630
- this.schedule = newSchedule;
631
- }
632
- getDayKey(dayIndex) {
633
- const days = ['SUN', 'MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT'];
634
- return days[dayIndex];
635
- }
636
- scheduleToOpenHours(schedule) {
637
- const dayKeys = ['SUN', 'MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT'];
638
- let openHoursMap = new Map();
639
- dayKeys.forEach((dayKey, index) => {
640
- if (schedule[dayKey]) {
641
- schedule[dayKey].forEach(timeRange => {
642
- const start24hr = convertTo24HourFormat(timeRange.start);
643
- const end24hr = convertTo24HourFormat(timeRange.end);
644
- const key = `${start24hr}-${end24hr}`;
645
- if (!openHoursMap.has(key)) {
646
- openHoursMap.set(key, { days: [index], start: start24hr, end: end24hr });
647
- }
648
- else {
649
- let entry = openHoursMap.get(key);
650
- if (entry) {
651
- entry.days.push(index);
652
- openHoursMap.set(key, entry);
653
- }
654
- }
655
- });
656
- }
657
- });
658
- let selectedOpenHours = [];
659
- openHoursMap.forEach((value, _key) => {
660
- selectedOpenHours.push({
661
- days: value.days,
662
- start: value.start,
663
- end: value.end,
664
- timezone: this.timezone,
665
- });
666
- });
667
- return selectedOpenHours;
668
- }
669
- render() {
670
- const timezoneOptions = Object.keys(TIMEZONE_MAP).map(key => ({
671
- label: TIMEZONE_MAP[key],
672
- value: key,
673
- }));
674
- return (h(Host, { key: 'bb0a4148b2d9728d7a2a9fdab8359382dd1ae5d5' }, h("div", { key: '27c5e85931d318e6ec66a155faa78e021b570f70', class: "nylas-availability-picker", part: "nap" }, !this.hideHeader && (h("div", { class: "header", part: "nap__header" }, h("h3", null, "General availability"), h("p", null, "Set your availability for scheduling meetings."))), h("div", { key: 'f2b3434dc127fc19fe6fe915cdc5f4a9d12ba6e7', class: "content" }, h("div", { key: 'bd75cb0749168b32c6366aea6f4df5920d098ec7', class: "select-timezone", part: "nap__select-timezone" }, h("h4", { key: '0c74924a291afaa07ff5b06781720a8cbadeea4d', class: "sub-header" }, "Select timezone", h("span", { key: '64933b3f6623f2d0b13559406db3d14afa99e0b6', class: "icon" }, h("tooltip-component", { key: '09c42633826e0ad358b4877f7d48bb70ce7ca518' }, h("info-icon", { key: '9ea9340b193710d759e71081e59ad6ccf762e4a8', slot: "tooltip-icon" }), h("span", { key: '83e596171dc8fb74543b21e957855f9cd32423b1', slot: "tooltip-content" }, "Select your timezone for displaying availability.")))), h("select-dropdown", { key: 'd65b32234b1669a5e7bef4b88024f50548011b98', name: "timezone", exportparts: "sd_dropdown: nap__timezone-container, sd_dropdown-button: nap__timezone-button, sd_dropdown-content: nap__timezone-dropdown-content", options: timezoneOptions, defaultSelectedOption: timezoneOptions.find(i => i.value === this.defaultTimezone) }, h("span", { key: '3387e2d39b7a052557d7668d5a7822fda1440da7', slot: "select-icon" }, h("globe-icon", { key: 'e92459b2ce063e199d8685f5a422a88e7a50fbd6', width: "20", height: "20" })))), h("div", { key: 'd510d9538189898f52e56388d661158e243fc8dd', class: "availability", part: "nap__availability" }, Object.keys(this.schedule).map(key => {
675
- const day = key;
676
- const timeRanges = this.schedule[key];
677
- return (h("div", { class: "availability-day" }, h("div", { class: "day", part: "nap__day" }, h("input", { type: "checkbox", name: day, id: day, checked: timeRanges.length > 0, onClick: () => {
678
- if (timeRanges.length > 0) {
679
- this.schedule[day] = [];
680
- }
681
- else {
682
- this.schedule[day] = [{ start: '09:00am', end: '05:00pm' }];
683
- }
684
- this.schedule = { ...this.schedule };
685
- } }), h("label", { htmlFor: day, "aria-label": "Select day" }, day)), h("div", { class: "time-ranges", part: "nap__time-ranges" }, timeRanges.length ? null : h("span", { class: "unavailable" }, "Unavailable"), timeRanges.length > 0 &&
686
- timeRanges.map((timeRange, timeRangeIndex) => {
687
- const startKey = `${key}:${timeRangeIndex}_start`;
688
- const endKey = `${key}:${timeRangeIndex}_end`;
689
- return (h("div", { class: "time-range", part: "nap__time-range" }, h("div", { class: "pickers" }, h("nylas-time-window-picker", { id: startKey, hasError: this.overlapDays[day]?.includes(timeRangeIndex), time: timeRange.start, name: startKey, key: startKey, exportparts: "time-picker: nap__time-picker-container, time-input: nap__time-picker-input, times: nap__time-picker-times" }), h("span", null, " - "), h("nylas-time-window-picker", { id: endKey, hasError: this.overlapDays[day]?.includes(timeRangeIndex), time: timeRange.end, name: endKey, key: endKey, minimumStartTime: timeRange.start, exportparts: "time-picker: nap__time-picker-container, time-input: nap__time-picker-input, times: nap__time-picker-times" })), h("button", { onClick: () => this.removeTimeRange(day, timeRangeIndex) }, h("close-icon", null))));
690
- }), h("p", { class: "error" }, this.overlapDays[day] ? 'Overlapping time ranges' : '')), h("div", null, timeRanges.length > 0 ? (h("button", { onClick: () => this.addTimeRange(day), part: "nap__add-time-range" }, h("add-circle-icon", null))) : null)));
691
- }))))));
692
- }
693
- static get formAssociated() { return true; }
694
- get host() { return getElement(this); }
695
- static get watchers() { return {
696
- "name": ["elementNameChangedHandler"],
697
- "selectedConfiguration": ["configChangedHandler"],
698
- "schedule": ["scheduleChanged"]
699
- }; }
700
- };
701
- __decorate$g([
702
- RegisterComponent({
703
- name: 'nylas-availability-picker',
704
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
705
- fireRegisterEvent: true,
706
- }),
707
- __metadata$g("design:type", Function),
708
- __metadata$g("design:paramtypes", []),
709
- __metadata$g("design:returntype", void 0)
710
- ], NylasAvailabilityPicker.prototype, "render", null);
711
- NylasAvailabilityPicker.style = NylasAvailabilityPickerStyle0;
712
-
713
- const nylasBookingCalendarPickerCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;width:inherit}.nylas-booking-calendar-picker{width:inherit;display:flex;flex-direction:column;margin:1rem;border-radius:var(--nylas-border-radius-2x);border:1px solid var(--nylas-base-200)}.nylas-booking-calendar-picker .header{padding:1rem;border-bottom:1px solid var(--nylas-base-200)}.nylas-booking-calendar-picker .header h3{margin:0;font-size:1rem;font-weight:600;line-height:20px;color:var(--nylas-base-900);text-align:left}.nylas-booking-calendar-picker .header p{margin:0.25rem 0 0 0;font-size:0.875rem;font-weight:400;line-height:20px;color:var(--nylas-base-600);text-align:left}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__loading{padding-bottom:1rem;display:flex;flex-direction:column;gap:4px}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__loading .label{display:flex;align-items:center;gap:0.5rem;margin:1rem 1rem 0;color:var(--nylas-base-800)}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__loading .loading-button{margin:0 1rem;padding:0;width:inherit;height:48px;color:black;font-size:1rem;cursor:not-allowed;display:flex;gap:0.5rem;justify-content:space-between;align-items:center;background:transparent;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x)}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__loading .loading-button span{padding:0 1rem}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__dropdown{padding:1rem;display:flex;flex-direction:column;gap:4px}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__dropdown span.label{display:flex;align-items:center;gap:4px;color:var(--nylas-base-800)}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__dropdown span.label tooltip-component{display:flex}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__dropdown select-dropdown::part(sd_dropdown){width:100%}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__dropdown select-dropdown::part(sd_dropdown-content){width:100%;max-width:unset}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__dropdown select-dropdown::part(sd_dropdown-button){width:100%;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x)}.nylas-booking-calendar-picker .nylas-booking-calendar-picker__dropdown select-dropdown::part(sd_dropdown-button-selected-label){max-width:calc(100% - 2rem);font-family:var(--nylas-font-family);font-size:16px;line-height:24px}";
714
- const NylasBookingCalendarPickerStyle0 = nylasBookingCalendarPickerCss;
715
-
716
- var __decorate$f = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
717
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
718
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
719
- r = Reflect.decorate(decorators, target, key, desc);
720
- else
721
- for (var i = decorators.length - 1; i >= 0; i--)
722
- if (d = decorators[i])
723
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
724
- return c > 3 && r && Object.defineProperty(target, key, r), r;
725
- };
726
- var __metadata$f = (undefined && undefined.__metadata) || function (k, v) {
727
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
728
- return Reflect.metadata(k, v);
729
- };
730
- const NylasBookingCalendarPicker = class {
731
- constructor(hostRef) {
732
- registerInstance(this, hostRef);
733
- this.valueChanged = createEvent(this, "valueChanged", 7);
734
- if (hostRef.$hostElement$["s-ei"]) {
735
- this.internals = hostRef.$hostElement$["s-ei"];
736
- }
737
- else {
738
- this.internals = hostRef.$hostElement$.attachInternals();
739
- hostRef.$hostElement$["s-ei"] = this.internals;
740
- }
741
- this.calendars = undefined;
742
- this.currentUser = undefined;
743
- this.name = 'booking-calendar';
744
- this.defaultBookingCalendar = '';
745
- this.selectedCalendar = '';
746
- }
747
- connectedCallback() {
748
- debug('nylas-booking-calendar-picker', 'connectedCallback');
749
- }
750
- disconnectedCallback() {
751
- debug('nylas-booking-calendar-picker', 'disconnectedCallback');
752
- }
753
- componentWillLoad() {
754
- debug('nylas-booking-calendar-picker', 'componentWillLoad');
755
- this.host.setAttribute('name', this.name);
756
- }
757
- componentDidLoad() {
758
- debug('nylas-booking-calendar-picker', 'componentDidLoad');
759
- this.defaultBookingCalendar = this.defaultBookingCalendar || this.currentUser?.email || '';
760
- if (typeof this.internals.setFormValue === 'function') {
761
- this.internals.setFormValue(this.defaultBookingCalendar.toString(), 'booking-calendar');
762
- }
763
- this.selectedCalendar = this.defaultBookingCalendar || this.currentUser?.email || '';
764
- }
765
- componentWillUpdate() {
766
- debug('nylas-booking-calendar-picker', 'componentWillUpdate');
767
- }
768
- componentDidUpdate() {
769
- debug('nylas-booking-calendar-picker', 'componentDidUpdate');
770
- }
771
- componentWillRender() {
772
- debug('nylas-booking-calendar-picker', 'componentWillRender');
773
- }
774
- componentDidRender() {
775
- debug('nylas-booking-calendar-picker', 'componentDidRender');
776
- }
777
- elementNameChangedHandler(newValue) {
778
- debug('nylas-booking-calendar-picker', 'elementNameChangedHandler', newValue);
779
- this.host.setAttribute('name', newValue);
780
- }
781
- nylasFormDropdownChangedHandler(event) {
782
- debug('nylas-booking-calendar-picker', 'nylasFormDropdownChangedHandler', event.detail);
783
- const valueChanged = (event) => {
784
- const { value } = event.detail;
785
- this.selectedCalendar = value;
786
- this.internals.setFormValue(value.toString(), this.name);
787
- };
788
- this.valueChanged.emit({ value: event.detail.value, name: this.name, valueChanged });
789
- }
790
- render() {
791
- const calendarOptions = this.calendars?.map(calendar => {
792
- return {
793
- value: calendar.id,
794
- label: calendar.name,
795
- };
796
- }) ?? [];
797
- return (h(Host, null, h("div", { class: "nylas-booking-calendar-picker", part: "nbcp" }, h("div", { class: "header", part: "nbcp__header" }, h("h3", null, "Calendar booking"), h("p", null, "Choose calendar where you\u2019d like the event bookings to show up.")), calendarOptions.length > 0 ? (h("div", { class: "nylas-booking-calendar-picker__dropdown" }, h("span", { class: "label", part: "nbcp__input-label" }, "Select a calendar to book meetings on", h("tooltip-component", null, h("info-icon", { slot: "tooltip-icon" }), h("span", { slot: "tooltip-content" }, "Check availability across one or multiple calendars. If multiple calendars are selected, you must be available across all of them to be considered available."))), h("select-dropdown", { name: "booking-calendar", options: calendarOptions, withSearch: false, exportparts: "sd_dropdown: nbcp__dropdown, sd_dropdown-button: nbcp__dropdown-button, sd_dropdown-content: nbcp__dropdown-content", defaultSelectedOption: calendarOptions.find(cal => cal.value == this.defaultBookingCalendar) ?? calendarOptions[0] }))) : (h("div", { class: "nylas-booking-calendar-picker__loading" }, h("span", { class: "label" }, "Select a calendar to book meetings on ", h("info-icon", null)), h("div", { class: "loading-button" }, h("span", null, "Loading...")))))));
798
- }
799
- static get formAssociated() { return true; }
800
- get host() { return getElement(this); }
801
- static get watchers() { return {
802
- "name": ["elementNameChangedHandler"]
803
- }; }
804
- };
805
- __decorate$f([
806
- RegisterComponent({
807
- name: 'nylas-booking-calendar-picker',
808
- stateToProps: new Map([
809
- ['schedulerConfig.calendars', 'calendars'],
810
- ['schedulerConfig.currentUser', 'currentUser'],
811
- ]),
812
- eventToProps: {
813
- valueChanged: async (event, _nylasSchedulerConfigConnector) => {
814
- const { valueChanged } = event.detail;
815
- if (valueChanged) {
816
- valueChanged(event);
817
- }
818
- },
819
- },
820
- fireRegisterEvent: true,
821
- }),
822
- __metadata$f("design:type", Function),
823
- __metadata$f("design:paramtypes", []),
824
- __metadata$f("design:returntype", void 0)
825
- ], NylasBookingCalendarPicker.prototype, "render", null);
826
- NylasBookingCalendarPicker.style = NylasBookingCalendarPickerStyle0;
827
-
828
- const nylasBufferTimeCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;width:inherit}.nylas-buffer-time{width:inherit;display:flex;flex-direction:column;margin:1rem;border-radius:var(--nylas-border-radius-2x);border:1px solid var(--nylas-base-200);text-align:left}.nylas-buffer-time .header{padding:1rem;border-bottom:1px solid var(--nylas-base-200)}.nylas-buffer-time .header h3{margin:0;font-size:1rem;font-weight:600;line-height:20px;color:var(--nylas-base-900);text-align:left}.nylas-buffer-time .header p{margin:0.25rem 0 0 0;font-size:0.875rem;font-weight:400;line-height:20px;color:var(--nylas-base-600);text-align:left}.nylas-buffer-time .nylas-buffer-time__body{display:grid;grid-template-columns:1fr auto}@media screen and (max-width: 768px){.nylas-buffer-time .nylas-buffer-time__body{grid-template-columns:1fr}}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__dropdown{padding:1rem;display:flex;flex-direction:column;gap:1rem;border-right:1px solid var(--nylas-base-200);color:var(--nylas-base-800)}@media screen and (max-width: 768px){.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__dropdown{border:none}}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__dropdown .nylas-buffer-time__row{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:1rem}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__dropdown .nylas-buffer-time__row label{width:200px}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__dropdown .nylas-buffer-time__row .dropdown-container{display:flex;gap:1rem;align-items:center;justify-content:flex-end}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview{width:208px;background:var(--nylas-base-25);border-bottom-right-radius:var(--nylas-border-radius-2x)}@media screen and (max-width: 768px){.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview{width:inherit;border-bottom-left-radius:var(--nylas-border-radius-2x)}}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview h4{font-size:14px;line-height:24px;color:var(--nylas-base-600);font-family:var(--nylas-font-family);font-weight:500;text-align:center;margin:0.75rem 0}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview .preview-container{padding:0 2rem 1rem}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview .preview-container .slot{background-color:transparent;border-top:1px solid var(--nylas-base-300)}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview .preview-container .slot.active{background-color:var(--nylas-base-100)}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview .preview-container .slot:last-of-type{border-bottom:1px solid var(--nylas-base-300)}.nylas-buffer-time .nylas-buffer-time__body .nylas-buffer-time__preview .preview-container .event-slot{background-color:var(--nylas-base-600);border-top:1px solid var(--nylas-base-300)}.nylas-buffer-time .nylas-buffer-time__dropdown select-dropdown::part(sd_dropdown-button){width:104px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x);padding:1rem}.nylas-buffer-time .nylas-buffer-time__dropdown select-dropdown::part(sd_dropdown-content){width:100%}.nylas-buffer-time .nylas-buffer-time__dropdown select-dropdown::part(sd_dropdown-button-selected-label){max-width:calc(100% - 2rem);font-family:var(--nylas-font-family);font-size:16px;line-height:24px}";
829
- const NylasBufferTimeStyle0 = nylasBufferTimeCss;
830
-
831
- var __decorate$e = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
832
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
833
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
834
- r = Reflect.decorate(decorators, target, key, desc);
835
- else
836
- for (var i = decorators.length - 1; i >= 0; i--)
837
- if (d = decorators[i])
838
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
839
- return c > 3 && r && Object.defineProperty(target, key, r), r;
840
- };
841
- var __metadata$e = (undefined && undefined.__metadata) || function (k, v) {
842
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
843
- return Reflect.metadata(k, v);
844
- };
845
- const NylasBufferTime = class {
846
- constructor(hostRef) {
847
- registerInstance(this, hostRef);
848
- this.valueChanged = createEvent(this, "valueChanged", 7);
849
- if (hostRef.$hostElement$["s-ei"]) {
850
- this.internals = hostRef.$hostElement$["s-ei"];
851
- }
852
- else {
853
- this.internals = hostRef.$hostElement$.attachInternals();
854
- hostRef.$hostElement$["s-ei"] = this.internals;
855
- }
856
- this.name = 'buffer-time';
857
- this.buffer = { before: 0, after: 0 };
858
- this.selectedBeforeBufferTime = this.buffer.before;
859
- this.selectedAfterBufferTime = this.buffer.after;
860
- }
861
- connectedCallback() {
862
- debug('nylas-buffer-time', 'connectedCallback');
863
- }
864
- disconnectedCallback() {
865
- debug('nylas-buffer-time', 'disconnectedCallback');
866
- }
867
- componentWillLoad() {
868
- debug('nylas-buffer-time', 'componentWillLoad');
869
- this.host.setAttribute('name', this.name);
870
- }
871
- componentDidLoad() {
872
- debug('nylas-buffer-time', 'componentDidLoad');
873
- if (typeof this.internals.setFormValue === 'function') {
874
- const bufferTime = {
875
- before: this.selectedBeforeBufferTime,
876
- after: this.selectedAfterBufferTime,
877
- };
878
- this.internals.setFormValue(JSON.stringify(bufferTime), this.name);
879
- }
880
- this.selectedAfterBufferTime = this.buffer.after;
881
- this.selectedBeforeBufferTime = this.buffer.before;
882
- }
883
- componentWillUpdate() {
884
- debug('nylas-buffer-time', 'componentWillUpdate');
885
- }
886
- componentDidUpdate() {
887
- debug('nylas-buffer-time', 'componentDidUpdate');
888
- }
889
- componentWillRender() {
890
- debug('nylas-buffer-time', 'componentWillRender');
891
- }
892
- componentDidRender() {
893
- debug('nylas-buffer-time', 'componentDidRender');
894
- }
895
- elementNameChangedHandler(newValue) {
896
- debug('nylas-buffer-time', 'elementNameChangedHandler', newValue);
897
- this.host.setAttribute('name', newValue);
898
- }
899
- nylasFormDropdownChangedHandler(event) {
900
- debug('nylas-buffer-time', 'nylasFormDropdownChangedHandler', event.detail);
901
- const valueChanged = (event) => {
902
- const { value, name } = event.detail;
903
- if (name === 'before-buffer-time') {
904
- this.selectedBeforeBufferTime = parseInt(value);
905
- }
906
- else if (name === 'after-buffer-time') {
907
- this.selectedAfterBufferTime = parseInt(value);
908
- }
909
- const bufferTime = {
910
- before: this.selectedBeforeBufferTime,
911
- after: this.selectedAfterBufferTime,
912
- };
913
- this.internals.setFormValue(JSON.stringify(bufferTime), 'booking-calendar');
914
- };
915
- this.valueChanged.emit({ ...event.detail, valueChanged });
916
- }
917
- renderPreview() {
918
- const totalSlots = 4;
919
- const slotHeight = 10;
920
- const eventSlotHeight = slotHeight * 2;
921
- const slotFill = minutes => {
922
- const fullSlots = Math.floor(minutes / 30);
923
- const partialFillHeight = ((minutes % 30) / 30) * slotHeight;
924
- return {
925
- fullSlots,
926
- partialFillHeight,
927
- };
928
- };
929
- const createBeforeSlots = () => {
930
- const { fullSlots, partialFillHeight } = slotFill(this.selectedBeforeBufferTime);
931
- return Array.from({ length: totalSlots }, (_, index) => {
932
- const isActive = this.selectedBeforeBufferTime > 0 && index > totalSlots - fullSlots - 1;
933
- const isPartial = this.selectedBeforeBufferTime > 0 && index === totalSlots - fullSlots - 1 && partialFillHeight > 0;
934
- let slotStyle = {};
935
- if (isActive && !isPartial) {
936
- slotStyle.backgroundColor = 'var(--nylas-base-100)';
937
- }
938
- else if (isPartial) {
939
- slotStyle.background = `linear-gradient(to top, var(--nylas-base-100) ${partialFillHeight}px, transparent 0)`;
940
- }
941
- return (h("div", { key: index, class: `slot ${isActive ? 'active' : ''}`, style: {
942
- height: `${slotHeight}px`,
943
- ...slotStyle,
944
- } }));
945
- });
946
- };
947
- const createAfterSlots = () => {
948
- const { fullSlots, partialFillHeight } = slotFill(this.selectedAfterBufferTime);
949
- return Array.from({ length: totalSlots }, (_, index) => {
950
- const isActive = this.selectedAfterBufferTime > 0 && index < fullSlots;
951
- const isPartial = index === fullSlots && partialFillHeight > 0;
952
- let slotStyle = {};
953
- if (isActive && !isPartial) {
954
- slotStyle.backgroundColor = 'var(--nylas-base-100)';
955
- }
956
- else if (isPartial) {
957
- slotStyle.background = `linear-gradient(to bottom, var(--nylas-base-100) ${partialFillHeight}px, transparent 0)`;
958
- }
959
- return (h("div", { key: index, class: `slot ${isActive ? 'active' : ''}`, style: {
960
- height: `${slotHeight}px`,
961
- ...slotStyle,
962
- } }));
963
- });
964
- };
965
- return (h("div", { class: "preview-container" }, createBeforeSlots(), h("div", { class: "event-slot", style: { height: `${eventSlotHeight}px` } }), createAfterSlots()));
966
- }
967
- render() {
968
- const minuteOptions = Array.from({ length: 25 }, (_, i) => {
969
- const value = i * 5;
970
- return {
971
- label: value.toString(),
972
- value: value,
973
- };
974
- });
975
- return (h(Host, null, h("div", { class: "nylas-buffer-time", part: "nbt" }, h("div", { class: "header", part: "nbt__header" }, h("h3", null, "Buffer time"), h("p", null, "Add buffer time before and after the event.")), h("div", { class: "nylas-buffer-time__body", part: "nbt__body" }, h("div", { class: "nylas-buffer-time__dropdown" }, h("div", { class: "nylas-buffer-time__row" }, h("label", null, "Before the event"), h("div", { class: "dropdown-container" }, h("select-dropdown", { id: "before-buffer-time", withSearch: false, name: "before-buffer-time", exportparts: "sd_dropdown: nbt__dropdown-before, sd_dropdown-button: nbt__dropdown-button-before, sd_dropdown-content: nbt__dropdown-content-before", options: minuteOptions, defaultSelectedOption: minuteOptions.find(min => min.value == this.selectedBeforeBufferTime) ?? minuteOptions[0] }), h("span", null, "mins"))), h("div", { class: "nylas-buffer-time__row" }, h("label", null, "After the event"), h("div", { class: "dropdown-container" }, h("select-dropdown", { id: "after-buffer-time", withSearch: false, name: "after-buffer-time", exportparts: "sd_dropdown: nbt__dropdown-after, sd_dropdown-button: nbt__dropdown-button-after, sd_dropdown-content: nbt__dropdown-content-after", options: minuteOptions, defaultSelectedOption: minuteOptions.find(min => min.value == this.selectedAfterBufferTime) ?? minuteOptions[0] }), h("span", null, "mins")))), h("div", { class: "nylas-buffer-time__preview", part: "nbt__preview" }, h("h4", null, "PREVIEW"), this.renderPreview())))));
976
- }
977
- static get formAssociated() { return true; }
978
- get host() { return getElement(this); }
979
- static get watchers() { return {
980
- "name": ["elementNameChangedHandler"]
981
- }; }
982
- };
983
- __decorate$e([
984
- RegisterComponent({
985
- name: 'nylas-buffer-time',
986
- eventToProps: {
987
- valueChanged: async (event, _nylasSchedulerConfigConnector) => {
988
- const { valueChanged } = event.detail;
989
- if (valueChanged) {
990
- valueChanged(event);
991
- }
992
- },
993
- },
994
- fireRegisterEvent: true,
995
- }),
996
- __metadata$e("design:type", Function),
997
- __metadata$e("design:paramtypes", []),
998
- __metadata$e("design:returntype", void 0)
999
- ], NylasBufferTime.prototype, "render", null);
1000
- NylasBufferTime.style = NylasBufferTimeStyle0;
1001
-
1002
- const nylasCalendarPickerCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;width:inherit}.nylas-calendar-picker{width:inherit;display:flex;flex-direction:column;margin:1rem;border-radius:var(--nylas-border-radius-2x);border:1px solid var(--nylas-base-200)}.nylas-calendar-picker .header{padding:1rem;border-bottom:1px solid var(--nylas-base-200)}.nylas-calendar-picker .header h3{margin:0;font-size:1rem;font-weight:600;line-height:20px;color:var(--nylas-base-900);text-align:left}.nylas-calendar-picker .header p{margin:0.25rem 0 0 0;font-size:0.875rem;font-weight:400;line-height:20px;color:var(--nylas-base-600);text-align:left}.nylas-calendar-picker .nylas-calendar-picker__loading{padding-bottom:1rem;display:flex;flex-direction:column;gap:4px}.nylas-calendar-picker .nylas-calendar-picker__loading .label{display:flex;align-items:center;gap:0.5rem;margin:1rem 1rem 0;color:var(--nylas-base-800)}.nylas-calendar-picker .nylas-calendar-picker__loading .label tooltip-component{display:flex}.nylas-calendar-picker .nylas-calendar-picker__loading .loading-button{margin:0 1rem;padding:0;width:inherit;height:48px;color:black;font-size:1rem;cursor:not-allowed;display:flex;gap:0.5rem;justify-content:space-between;align-items:center;background:transparent;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x)}.nylas-calendar-picker .nylas-calendar-picker__loading .loading-button span{padding:0 1rem}.nylas-calendar-picker .nylas-calendar-picker__dropdown{padding:1rem}.nylas-calendar-picker .nylas-calendar-picker__dropdown multi-select-dropdown::part(msd_dropdown){width:100%;display:flex;flex-direction:column;gap:4px}.nylas-calendar-picker .nylas-calendar-picker__dropdown multi-select-dropdown::part(msd_dropdown-button){width:100%;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x);padding:1rem}.nylas-calendar-picker .nylas-calendar-picker__dropdown multi-select-dropdown::part(msd_dropdown-content){width:100%;max-width:unset}.nylas-calendar-picker .nylas-calendar-picker__dropdown multi-select-dropdown::part(msd_dropdown-button-selected-label){max-width:calc(100% - 2rem);font-family:var(--nylas-font-family);font-size:16px;line-height:24px}";
1003
- const NylasCalendarPickerStyle0 = nylasCalendarPickerCss;
1004
-
1005
- var __decorate$d = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1006
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1007
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1008
- r = Reflect.decorate(decorators, target, key, desc);
1009
- else
1010
- for (var i = decorators.length - 1; i >= 0; i--)
1011
- if (d = decorators[i])
1012
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1013
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1014
- };
1015
- var __metadata$d = (undefined && undefined.__metadata) || function (k, v) {
1016
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1017
- return Reflect.metadata(k, v);
1018
- };
1019
- const NylasCalendarPicker = class {
1020
- constructor(hostRef) {
1021
- registerInstance(this, hostRef);
1022
- this.valueChanged = createEvent(this, "valueChanged", 7);
1023
- if (hostRef.$hostElement$["s-ei"]) {
1024
- this.internals = hostRef.$hostElement$["s-ei"];
1025
- }
1026
- else {
1027
- this.internals = hostRef.$hostElement$.attachInternals();
1028
- hostRef.$hostElement$["s-ei"] = this.internals;
1029
- }
1030
- this.calendars = undefined;
1031
- this.currentUser = undefined;
1032
- this.name = 'calendar';
1033
- this.defaultSelectedCalendars = [];
1034
- this.selectedCalendars = [];
1035
- }
1036
- elementNameChangedHandler(newValue) {
1037
- debug('nylas-calendar-picker', 'elementNameChangedHandler', newValue);
1038
- this.host.setAttribute('name', newValue);
1039
- }
1040
- connectedCallback() {
1041
- debug('nylas-calendar-picker', 'connectedCallback');
1042
- }
1043
- disconnectedCallback() {
1044
- debug('nylas-calendar-picker', 'disconnectedCallback');
1045
- }
1046
- componentWillLoad() {
1047
- debug('nylas-calendar-picker', 'componentWillLoad');
1048
- this.host.setAttribute('name', this.name);
1049
- }
1050
- componentDidLoad() {
1051
- debug('nylas-calendar-picker', 'componentDidLoad');
1052
- if (typeof this.internals.setFormValue === 'function') {
1053
- this.internals.setFormValue(this.defaultSelectedCalendars.toString(), 'calendar');
1054
- }
1055
- }
1056
- componentWillUpdate() {
1057
- debug('nylas-calendar-picker', 'componentWillUpdate');
1058
- }
1059
- componentDidUpdate() {
1060
- debug('nylas-calendar-picker', 'componentDidUpdate');
1061
- }
1062
- componentWillRender() {
1063
- debug('nylas-calendar-picker', 'componentWillRender');
1064
- }
1065
- componentDidRender() {
1066
- debug('nylas-calendar-picker', 'componentDidRender');
1067
- }
1068
- selectedOptionsChangedHandler(event) {
1069
- debug('nylas-calendar-picker', 'nylasFormDropdownChangedHandler', event.detail);
1070
- const valueChangedHandler = (event) => {
1071
- const { value } = event.detail;
1072
- this.selectedCalendars = [...value];
1073
- this.internals.setFormValue(value.toString(), 'calendar');
1074
- };
1075
- this.valueChanged.emit({ ...event.detail, name: this.name, valueChangedHandler });
1076
- }
1077
- render() {
1078
- const calendarOptions = this.calendars?.map(calendar => {
1079
- return {
1080
- value: calendar.id,
1081
- label: calendar.name,
1082
- selected: this.defaultSelectedCalendars?.includes(calendar.id) ||
1083
- (this.defaultSelectedCalendars?.includes('primary') || this.defaultSelectedCalendars?.length === 0 ? calendar.id === this.currentUser?.email : false),
1084
- };
1085
- }) ?? [];
1086
- return (h(Host, null, h("div", { class: "nylas-calendar-picker", part: "ncp" }, h("div", { class: "header", part: "ncp__header" }, h("h3", null, "Calendar availability"), h("p", null, "Select calendars that you\u2019d like to use for checking your availability.")), calendarOptions.length > 0 ? (h("div", { class: "nylas-calendar-picker__dropdown" }, h("multi-select-dropdown", { name: 'calendar', label: "Select calendars that will be checked for availability", options: calendarOptions, exportparts: "msd_dropdown: ncp__dropdown, msd_dropdown-button: ncp__dropdown-button, msd_dropdown-content: ncp__dropdown-content" }, h("span", { slot: "label-icon" }, h("tooltip-component", null, h("info-icon", { slot: "tooltip-icon" }), h("span", { slot: "tooltip-content" }, "Check availability across one or multiple calendars. If multiple calendars are selected, you must be available across all of them to be considered available. The default is your primary calendar if none are selected.")))))) : (h("div", { class: "nylas-calendar-picker__loading" }, h("span", { class: "label" }, "Select calendars that will be checked for availability ", h("info-icon", null)), h("div", { class: "loading-button" }, h("span", null, "Loading...")))))));
1087
- }
1088
- static get formAssociated() { return true; }
1089
- get host() { return getElement(this); }
1090
- static get watchers() { return {
1091
- "name": ["elementNameChangedHandler"]
1092
- }; }
1093
- };
1094
- __decorate$d([
1095
- RegisterComponent({
1096
- name: 'nylas-calendar-picker',
1097
- stateToProps: new Map([
1098
- ['schedulerConfig.calendars', 'calendars'],
1099
- ['schedulerConfig.currentUser', 'currentUser'],
1100
- ]),
1101
- eventToProps: {
1102
- valueChanged: async (event, _nylasSchedulerConfigConnector) => {
1103
- const { valueChangedHandler } = event.detail;
1104
- if (valueChangedHandler) {
1105
- valueChangedHandler(event);
1106
- }
1107
- },
1108
- },
1109
- fireRegisterEvent: true,
1110
- }),
1111
- __metadata$d("design:type", Function),
1112
- __metadata$d("design:paramtypes", []),
1113
- __metadata$d("design:returntype", void 0)
1114
- ], NylasCalendarPicker.prototype, "render", null);
1115
- NylasCalendarPicker.style = NylasCalendarPickerStyle0;
1116
-
1117
- const nylasCancellationPolicyCss = ":host{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-cancellation-policy{display:flex;flex-direction:column;gap:4px}.nylas-cancellation-policy label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-cancellation-policy label span.label-icon{margin-left:4px}.nylas-cancellation-policy label span.label-icon tooltip-component{display:flex}.nylas-cancellation-policy textarea{padding:12px 16px;border-width:1;resize:vertical;border-radius:8px;font-family:var(--nylas-font-family);font-size:16px;line-height:24px;border:1px solid var(--nylas-base-200)}.nylas-cancellation-policy textarea::-webkit-resizer{display:none}";
1118
- const NylasCancellationPolicyStyle0 = nylasCancellationPolicyCss;
1119
-
1120
- var __decorate$c = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1121
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1122
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1123
- r = Reflect.decorate(decorators, target, key, desc);
1124
- else
1125
- for (var i = decorators.length - 1; i >= 0; i--)
1126
- if (d = decorators[i])
1127
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1128
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1129
- };
1130
- var __metadata$c = (undefined && undefined.__metadata) || function (k, v) {
1131
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1132
- return Reflect.metadata(k, v);
1133
- };
1134
- const NylasCancellationPolicy = class {
1135
- constructor(hostRef) {
1136
- registerInstance(this, hostRef);
1137
- this.valueChanged = createEvent(this, "valueChanged", 7);
1138
- if (hostRef.$hostElement$["s-ei"]) {
1139
- this.internals = hostRef.$hostElement$["s-ei"];
1140
- }
1141
- else {
1142
- this.internals = hostRef.$hostElement$.attachInternals();
1143
- hostRef.$hostElement$["s-ei"] = this.internals;
1144
- }
1145
- this.selectedConfiguration = undefined;
1146
- this.cancellationPolicy = undefined;
1147
- this.name = 'cancelation-policy';
1148
- this.message = this.cancellationPolicy || this.selectedConfiguration?.scheduler?.cancellation_policy || '';
1149
- }
1150
- elementNameChangedHandler(newValue) {
1151
- debug('nylas-cancellation-policy', 'elementNameChangedHandler', newValue);
1152
- this.host.setAttribute('name', newValue);
1153
- }
1154
- selectedConfigurationChangedHandler(newValue, oldValue) {
1155
- debug('nylas-custom-booking-flow', 'selectedConfigurationChangedHandler', newValue, oldValue);
1156
- if (newValue?.scheduler?.cancellation_policy) {
1157
- this.message = newValue?.scheduler?.cancellation_policy;
1158
- }
1159
- }
1160
- connectedCallback() {
1161
- debug('nylas-cancellation-policy', 'connectedCallback');
1162
- }
1163
- componentWillLoad() {
1164
- debug('nylas-cancellation-policy', 'componentWillLoad');
1165
- this.host.setAttribute('name', this.name);
1166
- }
1167
- componentDidLoad() {
1168
- debug('nylas-cancellation-policy', 'componentDidLoad');
1169
- }
1170
- disconnectedCallback() {
1171
- debug('nylas-cancellation-policy', 'disconnectedCallback');
1172
- }
1173
- handleChange(event) {
1174
- const value = sanitizeHtml(event.target.value);
1175
- this.message = value;
1176
- this.internals.setFormValue(value, this.name);
1177
- this.valueChanged.emit({ value: value, name: this.name });
1178
- }
1179
- render() {
1180
- return (h(Host, { key: '7a57476ea21860b39103ab43f8b86a5804ddc055' }, h("div", { key: '67d7d2c00b2b658778dabe316a4512472bddf435', class: "nylas-cancellation-policy", part: "ncpolicy" }, h("label", { key: '2f0abff08c2485c93efaf6202a5c9720107f11d1', htmlFor: this.name }, "Cancellation policy message", h("span", { key: '2c16d52ce3b6fea15f23e57d50afe55872f920d6', class: "label-icon" }, h("tooltip-component", { key: '8bde2b6a884e8d180ef7296bbf29322df14128ef' }, h("info-icon", { key: 'cffadcf00bc6c3b07dffeb633bf87b423d6f4c59', slot: "tooltip-icon" }), h("span", { key: '5c37fbce026bb6f5a37f7867236fc27284323c42', slot: "tooltip-content" }, "Attendees receive this message if trying to cancel the event. Attendees are asked to provide a reason for cancellation.")))), h("textarea", { key: '0f492885372a90650104bbb4679cde1374296504', id: this.name, part: "ncpolicy__textarea", name: this.name, value: this.message, maxlength: "250", onInput: e => this.handleChange(e) }))));
1181
- }
1182
- static get formAssociated() { return true; }
1183
- get host() { return getElement(this); }
1184
- static get watchers() { return {
1185
- "name": ["elementNameChangedHandler"],
1186
- "selectedConfiguration": ["selectedConfigurationChangedHandler"]
1187
- }; }
1188
- };
1189
- __decorate$c([
1190
- RegisterComponent({
1191
- name: 'nylas-cancellation-policy',
1192
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
1193
- eventToProps: {},
1194
- fireRegisterEvent: true,
1195
- }),
1196
- __metadata$c("design:type", Function),
1197
- __metadata$c("design:paramtypes", []),
1198
- __metadata$c("design:returntype", void 0)
1199
- ], NylasCancellationPolicy.prototype, "render", null);
1200
- NylasCancellationPolicy.style = NylasCancellationPolicyStyle0;
1201
-
1202
- const nylasCustomizeBookingSettingsCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;width:inherit}.nylas-customize-booking-settings{width:inherit;display:flex;flex-direction:column;margin:1rem;border-radius:var(--nylas-border-radius-2x);border:1px solid var(--nylas-base-200)}.nylas-customize-booking-settings .header{padding:1rem;border-bottom:1px solid var(--nylas-base-200)}.nylas-customize-booking-settings .header h3{margin:0;font-size:1rem;font-weight:600;line-height:20px;color:var(--nylas-base-900);text-align:left}.nylas-customize-booking-settings .header p{margin:0.25rem 0 0 0;font-size:0.875rem;font-weight:400;line-height:20px;color:var(--nylas-base-600);text-align:left}.nylas-customize-booking-settings .nylas-customize-booking-settings__settings{display:flex;flex-direction:column;gap:1.5rem;padding:1rem;margin:1rem 0}.nylas-customize-booking-settings .nylas-customize-booking-settings__settings .nylas-customize-booking-settings__settings-div{display:flex;align-items:center;gap:4px}.label{margin-left:32px;font-size:16px;font-weight:400;color:var(--nylas-base-800);line-height:24px}.label .label-contents{margin:0;display:inline-block}@media screen and (max-width: 768px){.label .label-contents{display:block}}.label tooltip-component{display:inline-block}@media screen and (max-width: 768px){tooltip-component#guests::part(tc__content){left:58px}}tooltip-component#reschedule::part(tc__content){left:58px}@media screen and (max-width: 768px){tooltip-component#reschedule::part(tc__content){left:58px}}tooltip-component#cancel::part(tc__content){left:-58px}@media screen and (max-width: 768px){tooltip-component#cancel::part(tc__content){left:58px}}";
1203
- const NylasCustomizeBookingSettingsStyle0 = nylasCustomizeBookingSettingsCss;
1204
-
1205
- var __decorate$b = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1206
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1207
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1208
- r = Reflect.decorate(decorators, target, key, desc);
1209
- else
1210
- for (var i = decorators.length - 1; i >= 0; i--)
1211
- if (d = decorators[i])
1212
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1213
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1214
- };
1215
- var __metadata$b = (undefined && undefined.__metadata) || function (k, v) {
1216
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1217
- return Reflect.metadata(k, v);
1218
- };
1219
- const NylasCustomizeBookingSettings = class {
1220
- constructor(hostRef) {
1221
- registerInstance(this, hostRef);
1222
- this.valueChanged = createEvent(this, "valueChanged", 7);
1223
- if (hostRef.$hostElement$["s-ei"]) {
1224
- this.internals = hostRef.$hostElement$["s-ei"];
1225
- }
1226
- else {
1227
- this.internals = hostRef.$hostElement$.attachInternals();
1228
- hostRef.$hostElement$["s-ei"] = this.internals;
1229
- }
1230
- this.selectedConfiguration = undefined;
1231
- this.defaultAdditionalGuestsHidden = this.selectedConfiguration?.scheduler?.hide_additional_guests ?? false;
1232
- this.defaultHideCancellationOptions = this.selectedConfiguration?.scheduler?.hide_cancellation_options ?? false;
1233
- this.defaultHideReschedulingOptions = this.selectedConfiguration?.scheduler?.hide_rescheduling_options ?? false;
1234
- this.name = 'customize-booking-settings';
1235
- this.allowGuestsToInvite = this.defaultAdditionalGuestsHidden;
1236
- this.hideCancellationOptions = this.defaultHideCancellationOptions;
1237
- this.hideReschedulingOptions = this.defaultHideReschedulingOptions;
1238
- }
1239
- elementNameChangedHandler(newValue) {
1240
- debug('nylas-customize-booking-settings', 'elementNameChangedHandler', newValue);
1241
- this.host.setAttribute('name', newValue);
1242
- }
1243
- selectedConfigurationChangedHandler(newValue) {
1244
- debug('nylas-customize-booking-settings', 'selectedConfigurationChangedHandler', newValue);
1245
- this.allowGuestsToInvite = !newValue?.scheduler?.hide_additional_guests;
1246
- this.hideCancellationOptions = newValue?.scheduler?.hide_cancellation_options ?? false;
1247
- this.hideReschedulingOptions = newValue?.scheduler?.hide_rescheduling_options ?? false;
1248
- }
1249
- connectedCallback() {
1250
- debug('nylas-customize-booking-settings', 'connectedCallback');
1251
- }
1252
- disconnectedCallback() {
1253
- debug('nylas-customize-booking-settings', 'disconnectedCallback');
1254
- }
1255
- componentWillLoad() {
1256
- debug('nylas-customize-booking-settings', 'componentWillLoad');
1257
- this.host.setAttribute('name', this.name);
1258
- }
1259
- componentDidLoad() {
1260
- debug('nylas-customize-booking-settings', 'componentDidLoad');
1261
- }
1262
- componentWillUpdate() {
1263
- debug('nylas-customize-booking-settings', 'componentWillUpdate');
1264
- }
1265
- componentDidUpdate() {
1266
- debug('nylas-customize-booking-settings', 'componentDidUpdate');
1267
- }
1268
- componentWillRender() {
1269
- debug('nylas-customize-booking-settings', 'componentWillRender');
1270
- }
1271
- componentDidRender() {
1272
- debug('nylas-customize-booking-settings', 'componentDidRender');
1273
- }
1274
- checkboxToggledHandler(event) {
1275
- const { name, checked } = event.detail;
1276
- switch (name) {
1277
- case 'hide_additional_guests':
1278
- this.allowGuestsToInvite = checked;
1279
- break;
1280
- case 'hide_cancellation_options':
1281
- this.hideCancellationOptions = checked;
1282
- break;
1283
- case 'hide_rescheduling_options':
1284
- this.hideReschedulingOptions = checked;
1285
- break;
1286
- }
1287
- this.valueChanged.emit({
1288
- value: JSON.stringify({
1289
- additionalGuestsHidden: !this.allowGuestsToInvite,
1290
- hideCancellationOptions: this.hideCancellationOptions,
1291
- hideReschedulingOptions: this.hideReschedulingOptions,
1292
- }),
1293
- name: this.name,
1294
- });
1295
- this.internals.setFormValue(JSON.stringify({
1296
- additionalGuestsHidden: !this.allowGuestsToInvite,
1297
- hideCancellationOptions: this.hideCancellationOptions,
1298
- hideReschedulingOptions: this.hideReschedulingOptions,
1299
- }), this.name);
1300
- }
1301
- render() {
1302
- return (h(Host, { key: '543f4fc64d9dab03c528c5738cd4c1b1bb9cfd2a' }, h("div", { key: 'e3f153847ad5256327952d4be0aace03543b1d40', class: "nylas-customize-booking-settings", part: "ncbs" }, h("div", { key: '5b35f27785f6f6bc8e8848d94857869b73108df0', class: "header", part: "ncbs__header" }, h("h3", { key: 'd50a9614e3b0b5227a196356a43f12aab4acb158' }, "Additional settings"), h("p", { key: 'f29bbb165479e276cf87087582e9c60eb21c37d1' }, "Booking settings for the event.")), h("div", { key: 'd091485f983d0cc3ff86e7ca89df8d75526d3cef', class: "nylas-customize-booking-settings__settings", part: "ncbs__settings" }, h("div", { key: '7f7888a718a70a681795e599075c92cfbc16853a', class: "nylas-customize-booking-settings__settings-div", part: "ncbs__settings-div , ncbs__additional_guests" }, h("checkbox-component", { key: 'e37474d77812d96fe264d26c329078502c074dbe', name: "hide_additional_guests", label: "Allow guests to invite additional guests.", checked: this.allowGuestsToInvite }, h("span", { key: '00b45833c0223e373edf0b42669e4a154938b1eb', slot: "label", class: "label" }, h("p", { key: 'e66de8b9f53230347417a8ec0a7ae7a19af9db31', class: "label-contents" }, "Allow guests to invite additional guests to the booking."), h("tooltip-component", { key: '1ba5558e1991235c21f57ca1968220ea7bf43fcb', id: "guests" }, h("info-icon", { key: '3e62cc64cc55eb3dd4d0a73cef80a64c8dc9c38f', slot: "tooltip-icon" }), h("span", { key: '3853d0d575be29420ea012c90b0a2c07913a86a7', slot: "tooltip-content" }, "Allow guests to invite additional guests to the event. If enabled, the guest will be able to add additional guests' email addresses."))))), h("div", { key: '92e209a924673d8b1dee03475ffabfea5d9bf09b', class: "nylas-customize-booking-settings__settings-div", part: "ncbs__settings-div , ncbs__rescheduling_options" }, h("checkbox-component", { key: 'f7b522c07700938d25b17e14d236edb2aae12b21', name: "hide_rescheduling_options", label: "Hide 'Reschedule' option on booking page and emails.", checked: this.hideReschedulingOptions }, h("span", { key: '590cb5d983ff6eef95ebb370b845e1cc8e3080e4', slot: "label", class: "label" }, h("p", { key: '8f2d2742976e21a81268c793ae1c6c9dafdcecc3', class: "label-contents" }, "Hide the\u00A0", h("strong", { key: '4b01f75e4067d7c8d26ca785d5c6ad841633130c' }, "Reschedule"), "\u00A0button on the Scheduling Page and in the email notifications."), h("tooltip-component", { key: '8a157115569a4413143779c9e09c8389394973f9', id: "reschedule" }, h("info-icon", { key: 'b3a2c734d2d7a303d1d4d2622b51113aa7d3dfaf', slot: "tooltip-icon" }), h("span", { key: '2d08ceb49e744787da6863d72cf2c6df50f1a7cc', slot: "tooltip-content" }, "Hide the 'Reschedule' button on the Scheduling page and in the email notifications. If enabled, the guest will not be able to reschedule the booking."))))), h("div", { key: '6bc7f1a30a750ba85453d852f6f7e05c0513673d', class: "nylas-customize-booking-settings__settings-div", part: "ncbs__settings-div , ncbs__cancellation_options" }, h("checkbox-component", { key: '089ca174d8aabb26d87f5bb8cb871b9e82b7c04f', name: "hide_cancellation_options", label: "Hide 'Cancel' option on booking page and emails.", checked: this.hideCancellationOptions }, h("span", { key: '9ec50185d728baddbe0805eaeff057686b153bea', slot: "label", class: "label" }, h("p", { key: '118c1c3cc06dba90f451711aba0dde3efeeec9f0', class: "label-contents" }, "Hide the\u00A0", h("strong", { key: 'c1a26aa5c832fba488d60fc3af5a3c000ada144d' }, "Cancel"), "\u00A0button on the Scheduling Page and in the email notifications."), h("tooltip-component", { key: 'b70473d1e93c11d9b05a9dcec67d77795638bbeb', id: "cancel" }, h("info-icon", { key: '2f0d812ac9fb7a52260b601c590b7a629036ea7c', slot: "tooltip-icon" }), h("span", { key: '4c5b3b51b57761a377ccfa7f66d6d69486d8cb11', slot: "tooltip-content" }, "Hide the 'Cancel' button on the Scheduling page and in the email notifications. If enabled, the guest will not be able to cancel the booking.")))))))));
1303
- }
1304
- static get formAssociated() { return true; }
1305
- get host() { return getElement(this); }
1306
- static get watchers() { return {
1307
- "name": ["elementNameChangedHandler"],
1308
- "selectedConfiguration": ["selectedConfigurationChangedHandler"]
1309
- }; }
1310
- };
1311
- __decorate$b([
1312
- RegisterComponent({
1313
- name: 'nylas-customize-booking-settings',
1314
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
1315
- fireRegisterEvent: true,
1316
- }),
1317
- __metadata$b("design:type", Function),
1318
- __metadata$b("design:paramtypes", []),
1319
- __metadata$b("design:returntype", void 0)
1320
- ], NylasCustomizeBookingSettings.prototype, "render", null);
1321
- NylasCustomizeBookingSettings.style = NylasCustomizeBookingSettingsStyle0;
1322
-
1323
- const nylasEventDescriptionCss = ":host{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-event-description{display:flex;flex-direction:column;gap:4px}.nylas-event-description label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-event-description label span.label-icon{margin-left:4px}.nylas-event-description label span.label-icon tooltip-component{display:flex}.nylas-event-description textarea{padding:12px 16px;border-width:1;resize:vertical;border-radius:8px;font-family:var(--nylas-font-family);font-size:16px;line-height:24px;border:1px solid var(--nylas-base-200)}.nylas-event-description textarea::-webkit-resizer{display:none}";
1324
- const NylasEventDescriptionStyle0 = nylasEventDescriptionCss;
1325
-
1326
- var __decorate$a = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1327
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1328
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1329
- r = Reflect.decorate(decorators, target, key, desc);
1330
- else
1331
- for (var i = decorators.length - 1; i >= 0; i--)
1332
- if (d = decorators[i])
1333
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1334
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1335
- };
1336
- var __metadata$a = (undefined && undefined.__metadata) || function (k, v) {
1337
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1338
- return Reflect.metadata(k, v);
1339
- };
1340
- const NylasEventDescription = class {
1341
- constructor(hostRef) {
1342
- registerInstance(this, hostRef);
1343
- this.valueChanged = createEvent(this, "valueChanged", 7);
1344
- if (hostRef.$hostElement$["s-ei"]) {
1345
- this.internals = hostRef.$hostElement$["s-ei"];
1346
- }
1347
- else {
1348
- this.internals = hostRef.$hostElement$.attachInternals();
1349
- hostRef.$hostElement$["s-ei"] = this.internals;
1350
- }
1351
- this.selectedConfiguration = undefined;
1352
- this.eventDescription = undefined;
1353
- this.name = 'description';
1354
- this.description = this.eventDescription || this.selectedConfiguration?.event_booking?.description || '';
1355
- }
1356
- elementNameChangedHandler(newValue) {
1357
- debug('nylas-event-description', 'elementNameChangedHandler', newValue);
1358
- this.host.setAttribute('name', newValue);
1359
- }
1360
- selectedConfigurationChangedHandler(newValue, oldValue) {
1361
- debug('nylas-custom-booking-flow', 'selectedConfigurationChangedHandler', newValue, oldValue);
1362
- if (newValue?.event_booking?.description) {
1363
- this.description = newValue?.event_booking?.description;
1364
- }
1365
- }
1366
- connectedCallback() {
1367
- debug('nylas-event-description', 'connectedCallback');
1368
- }
1369
- componentWillLoad() {
1370
- debug('nylas-event-description', 'componentWillLoad');
1371
- this.host.setAttribute('name', this.name);
1372
- }
1373
- componentDidLoad() {
1374
- debug('nylas-event-description', 'componentDidLoad');
1375
- }
1376
- disconnectedCallback() {
1377
- debug('nylas-event-description', 'disconnectedCallback');
1378
- }
1379
- handleChange(event) {
1380
- const value = sanitizeHtml(event.target.value);
1381
- this.description = value;
1382
- this.internals.setFormValue(value, 'description');
1383
- this.valueChanged.emit({ value: value, name: this.name });
1384
- }
1385
- render() {
1386
- return (h(Host, { key: 'ac483c56982373fb625c6d1af54eed749ce820e2' }, h("div", { key: '3924853ea2c94d72bf2a04a319bee5fc61eb7642', class: "nylas-event-description", part: "nedesc" }, h("label", { key: 'e8f9990a4f0766de9691080ef02b823c4cd6beb4', htmlFor: "description" }, "Event description", h("span", { key: 'dc7fa731cc60ed6e59032cdb35d0b410de300750', class: "label-icon" }, h("tooltip-component", { key: '1c0b1a5a547227bf7d4f499cc7c319349ec26e2d' }, h("info-icon", { key: 'e74034f5a5d8ab86c0d497b15c9cb8016d22f38e', slot: "tooltip-icon" }), h("span", { key: 'c5efa1fc3adc9290e39d40f1f7998e0c6bdd3bf4', slot: "tooltip-content" }, "Provide any additional details for your event.")))), h("textarea", { key: '45d8cc241ab90a24ec437499234b02cc401fa720', id: "description", part: "nedesc__textarea", name: "description", value: this.description, maxlength: "8192", onInput: e => this.handleChange(e) }))));
1387
- }
1388
- static get formAssociated() { return true; }
1389
- get host() { return getElement(this); }
1390
- static get watchers() { return {
1391
- "name": ["elementNameChangedHandler"],
1392
- "selectedConfiguration": ["selectedConfigurationChangedHandler"]
1393
- }; }
1394
- };
1395
- __decorate$a([
1396
- RegisterComponent({
1397
- name: 'nylas-event-description',
1398
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
1399
- eventToProps: {},
1400
- fireRegisterEvent: true,
1401
- }),
1402
- __metadata$a("design:type", Function),
1403
- __metadata$a("design:paramtypes", []),
1404
- __metadata$a("design:returntype", void 0)
1405
- ], NylasEventDescription.prototype, "render", null);
1406
- NylasEventDescription.style = NylasEventDescriptionStyle0;
1407
-
1408
- const nylasEventDurationCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-event-duration{display:flex;flex-direction:column;gap:4px}.nylas-event-duration label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-event-duration label span.required{color:var(--nylas-error, #cc4841)}.nylas-event-duration label span.label-icon{margin-left:4px}.nylas-event-duration label span.label-icon tooltip-component{display:flex}.nylas-event-duration__wrapper{display:flex;align-items:center;gap:0.5rem}.nylas-event-duration__wrapper input{padding:12px 16px;border-width:1;border-radius:8px;border:1px solid var(--nylas-base-200);font-family:var(--nylas-font-family);font-size:16px;line-height:24px;width:48px}.nylas-event-duration__wrapper input-dropdown::part(id_dropdown-input){border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x);padding:14px 16px;width:50px}.nylas-event-duration__wrapper input-dropdown::part(id_dropdown-content){width:100%;min-width:unset;height:200px}.nylas-event-duration__wrapper select-dropdown{width:120px}@media screen and (max-width: 768px){.nylas-event-duration__wrapper select-dropdown{width:100%}}.nylas-event-duration__wrapper select-dropdown::part(sd_dropdown-button){border:1px solid var(--nylas-base-200)}";
1409
- const NylasEventDurationStyle0 = nylasEventDurationCss;
1410
-
1411
- var __decorate$9 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1412
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1413
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1414
- r = Reflect.decorate(decorators, target, key, desc);
1415
- else
1416
- for (var i = decorators.length - 1; i >= 0; i--)
1417
- if (d = decorators[i])
1418
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1419
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1420
- };
1421
- var __metadata$9 = (undefined && undefined.__metadata) || function (k, v) {
1422
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1423
- return Reflect.metadata(k, v);
1424
- };
1425
- const NylasEventDuration = class {
1426
- constructor(hostRef) {
1427
- registerInstance(this, hostRef);
1428
- this.valueChanged = createEvent(this, "valueChanged", 7);
1429
- if (hostRef.$hostElement$["s-ei"]) {
1430
- this.internals = hostRef.$hostElement$["s-ei"];
1431
- }
1432
- else {
1433
- this.internals = hostRef.$hostElement$.attachInternals();
1434
- hostRef.$hostElement$["s-ei"] = this.internals;
1435
- }
1436
- this.selectedConfiguration = undefined;
1437
- this.name = 'duration';
1438
- this.eventDurationMinutes = undefined;
1439
- this.duration = this.eventDurationMinutes ? (this.eventDurationMinutes >= 60 ? this.eventDurationMinutes / 60 : this.eventDurationMinutes) : 30;
1440
- this.durationMinutes = this.eventDurationMinutes ?? 30;
1441
- this.durationIncrement = this.eventDurationMinutes ? (this.eventDurationMinutes >= 60 ? 60 : 1) : 1;
1442
- this.durationMinutesOptions = [
1443
- { value: 15, label: '15' },
1444
- { value: 30, label: '30' },
1445
- { value: 45, label: '45' },
1446
- { value: 60, label: '60' },
1447
- ];
1448
- }
1449
- elementNameChangedHandler(newValue) {
1450
- debug('nylas-event-duration', 'elementNameChangedHandler', newValue);
1451
- this.host.setAttribute('name', newValue);
1452
- }
1453
- selectedConfigurationChangedHandler(newVal) {
1454
- const configDuration = newVal?.availability?.duration_minutes;
1455
- if (configDuration) {
1456
- this.duration = configDuration >= 60 ? configDuration / 60 : configDuration;
1457
- this.durationMinutes = configDuration ?? 30;
1458
- this.durationIncrement = configDuration >= 60 ? 60 : 1;
1459
- }
1460
- }
1461
- durationMinutesChangedHandler(newValue, oldValue) {
1462
- debug('nylas-event-duration', 'durationMinutesChangedHandler', newValue);
1463
- if (newValue === oldValue) {
1464
- return;
1465
- }
1466
- this.valueChanged.emit({ value: newValue.toString(), name: this.name });
1467
- }
1468
- connectedCallback() {
1469
- debug('nylas-event-duration', 'connectedCallback');
1470
- }
1471
- componentWillLoad() {
1472
- debug('nylas-event-duration', 'componentWillLoad');
1473
- this.host.setAttribute('name', this.name);
1474
- this.setDurationMintueOptions();
1475
- }
1476
- componentDidLoad() {
1477
- debug('nylas-event-duration', 'componentDidLoad');
1478
- this.internals.setFormValue(this.durationMinutes.toString(), 'duration');
1479
- }
1480
- disconnectedCallback() {
1481
- debug('nylas-event-duration', 'disconnectedCallback');
1482
- }
1483
- setDurationMintueOptions() {
1484
- if (this.durationIncrement === 1) {
1485
- this.durationMinutesOptions = [
1486
- { value: 15, label: '15' },
1487
- { value: 30, label: '30' },
1488
- { value: 45, label: '45' },
1489
- { value: 60, label: '60' },
1490
- ];
1491
- }
1492
- else {
1493
- this.durationMinutesOptions = Array.from({ length: 23 }, (_, i) => ({ value: i + 1, label: (i + 1).toString() }));
1494
- }
1495
- return this.durationMinutesOptions;
1496
- }
1497
- handleChange(event) {
1498
- this.duration = event.target.value;
1499
- this.durationMinutes = this.duration * this.durationIncrement;
1500
- this.internals.setFormValue(this.durationMinutes.toString(), this.name);
1501
- }
1502
- nylasFormDropdownChangedHandler(event) {
1503
- debug('nylas-calendar-picker', 'nylasFormDropdownChangedHandler', event.detail);
1504
- const { value } = event.detail;
1505
- this.durationIncrement = parseInt(value);
1506
- if (this.durationIncrement === 1) {
1507
- this.duration = 60;
1508
- }
1509
- else {
1510
- this.duration = 1;
1511
- }
1512
- this.setDurationMintueOptions();
1513
- this.durationMinutes = this.duration * this.durationIncrement;
1514
- this.internals.setFormValue(this.durationMinutes.toString(), 'duration');
1515
- }
1516
- inputOptionChangedHandler(event) {
1517
- debug('nylas-calendar-picker', 'inputOptionChangedHandler', event.detail);
1518
- const { value } = event.detail;
1519
- this.duration = value;
1520
- this.durationMinutes = this.duration * this.durationIncrement;
1521
- this.internals.setFormValue(this.durationMinutes.toString(), this.name);
1522
- }
1523
- render() {
1524
- const durationOptions = [
1525
- { value: 1, label: 'minute' },
1526
- { value: 60, label: 'hour' },
1527
- ];
1528
- return (h(Host, { key: 'c8ab90c7a45ce6a5379552af0a9059b9d829e82c' }, h("div", { key: 'd957e610bd31a55430235b0ca903905c8bf3706b', class: "nylas-event-duration", part: "ned" }, h("label", { key: '39324d77ad9da4bc0c1f36d15c28384f423c1976', htmlFor: "duration" }, "Event duration", h("span", { key: '8f222a8a5d03899ff06790133434028dd1a62cd4', class: "required" }, "*"), h("span", { key: '6b83c675faa33db229ded711eac8c1f565bc9a61', class: "label-icon" }, h("tooltip-component", { key: '01b7ba340e2883e5a22d4559f67feda4bc745109' }, h("info-icon", { key: 'acbfa3dcbc994dec0e502ea9ded00612bf24b315', slot: "tooltip-icon" }), h("span", { key: 'e691c2a8ce4953e448cb6850ab2648645ae688c0', slot: "tooltip-content" }, "Set the duration of your event.")))), h("div", { key: '294766a022ba73042705050bc2fbc294cd1433b4', class: "nylas-event-duration__wrapper" }, h("input-dropdown", { key: '9a61a9527ae4c9991dc1f1596fbed85a5dd57966', name: 'event-duration', options: this.durationMinutesOptions, inputValue: this.duration.toString(), exportparts: "id_dropdown: ned__input_dropdown, id_dropdown-input: ned__input_dropdown-input, id_dropdown-content: ned__input_dropdown-content", defaultInputOption: this.durationMinutesOptions.find(i => i.value == this.duration) ?? durationOptions[0] }), h("select-dropdown", { key: 'edcda0700a80961b9a8b9f325288d70a1aa4e6f0', name: 'event-duration', options: durationOptions, pluralizedLabel: this.duration > 1 ? 's' : '', exportparts: "sd_dropdown: ned__dropdown, sd_dropdown-button: ned__dropdown-button, sd_dropdown-content: ned__dropdown-content", defaultSelectedOption: durationOptions.find(i => i.value == this.durationIncrement) ?? durationOptions[0], withSearch: false })))));
1529
- }
1530
- static get formAssociated() { return true; }
1531
- get host() { return getElement(this); }
1532
- static get watchers() { return {
1533
- "name": ["elementNameChangedHandler"],
1534
- "selectedConfiguration": ["selectedConfigurationChangedHandler"],
1535
- "durationMinutes": ["durationMinutesChangedHandler"]
1536
- }; }
1537
- };
1538
- __decorate$9([
1539
- RegisterComponent({
1540
- name: 'nylas-event-duration',
1541
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
1542
- eventToProps: {},
1543
- fireRegisterEvent: true,
1544
- }),
1545
- __metadata$9("design:type", Function),
1546
- __metadata$9("design:paramtypes", []),
1547
- __metadata$9("design:returntype", void 0)
1548
- ], NylasEventDuration.prototype, "render", null);
1549
- NylasEventDuration.style = NylasEventDurationStyle0;
1550
-
1551
- const nylasEventInfoCss = ":host{display:block;margin:1rem;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-event-info__title{color:var(--nylas-base-900);font-size:16px;font-style:normal;font-weight:600;line-height:20px;margin:0;text-align:left}.nylas-event-info__subtitle{color:var(--nylas-base-600);font-size:14px;font-style:normal;font-weight:400;line-height:20px;margin:0.25rem 0px 0px;text-align:left}.nylas-event-info__content{padding:1rem;display:flex;flex-direction:column;gap:1rem}.nylas-event-info__block{display:flex;justify-content:space-between;gap:0.5rem}";
1552
- const NylasEventInfoStyle0 = nylasEventInfoCss;
1553
-
1554
- var __decorate$8 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1555
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1556
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1557
- r = Reflect.decorate(decorators, target, key, desc);
1558
- else
1559
- for (var i = decorators.length - 1; i >= 0; i--)
1560
- if (d = decorators[i])
1561
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1562
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1563
- };
1564
- var __metadata$8 = (undefined && undefined.__metadata) || function (k, v) {
1565
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1566
- return Reflect.metadata(k, v);
1567
- };
1568
- const NylasEventInfo = class {
1569
- constructor(hostRef) {
1570
- registerInstance(this, hostRef);
1571
- if (hostRef.$hostElement$["s-ei"]) {
1572
- this.internals = hostRef.$hostElement$["s-ei"];
1573
- }
1574
- else {
1575
- this.internals = hostRef.$hostElement$.attachInternals();
1576
- hostRef.$hostElement$["s-ei"] = this.internals;
1577
- }
1578
- }
1579
- connectedCallback() {
1580
- debug('nylas-event-info', 'connectedCallback');
1581
- }
1582
- componentWillLoad() {
1583
- debug('nylas-event-info', 'componentWillLoad');
1584
- }
1585
- componentDidLoad() {
1586
- debug('nylas-event-info', 'componentDidLoad');
1587
- checkForMissingSlots(['inputs'], this.el);
1588
- }
1589
- disconnectedCallback() {
1590
- debug('nylas-event-info', 'disconnectedCallback');
1591
- }
1592
- render() {
1593
- return (h(Host, { key: 'adf72357920be8fadb32c683735719e5dbf76883' }, h("nylas-form-card", { key: '33823a1bbd57716f9b056f5addba8a5fb316ac93' }, h("h1", { key: 'eb14a7f95322992e24dad4e9ff612ffcb7c7634a', slot: "header-title", class: "nylas-event-info__title" }, "Event information"), h("h3", { key: '366d9ed654b03ea7bfe9d902240fcd4ad3c2b177', slot: "header-subtitle", class: "nylas-event-info__subtitle" }, "Enter all event information."), h("div", { key: 'a6abc2c53dbce1d8d0ad444033d1361171bc5720', slot: "content", class: "nylas-event-info__content" }, h("slot", { key: 'c814d4c24582dc76ee96f8e87c9b610a06205273', name: "inputs" })))));
1594
- }
1595
- static get formAssociated() { return true; }
1596
- get el() { return getElement(this); }
1597
- };
1598
- __decorate$8([
1599
- RegisterComponent({
1600
- name: 'nylas-event-info',
1601
- eventToProps: {},
1602
- fireRegisterEvent: true,
1603
- }),
1604
- __metadata$8("design:type", Function),
1605
- __metadata$8("design:paramtypes", []),
1606
- __metadata$8("design:returntype", void 0)
1607
- ], NylasEventInfo.prototype, "render", null);
1608
- NylasEventInfo.style = NylasEventInfoStyle0;
1609
-
1610
- const nylasEventLimitsCss = ":host{display:block;margin:1rem;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-event-limits__title{color:var(--nylas-base-900);font-size:16px;font-style:normal;font-weight:600;line-height:20px;margin:0;text-align:left}.nylas-event-limits__subtitle{color:var(--nylas-base-600);font-size:14px;font-style:normal;font-weight:400;line-height:20px;margin:0.25rem 0px 0px;text-align:left}.nylas-event-limits__content{padding:1rem;display:flex;flex-direction:column;gap:1rem}.nylas-event-limits__block{display:flex;justify-content:space-between;gap:0.5rem}";
1611
- const NylasEventLimitsStyle0 = nylasEventLimitsCss;
1612
-
1613
- var __decorate$7 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1614
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1615
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1616
- r = Reflect.decorate(decorators, target, key, desc);
1617
- else
1618
- for (var i = decorators.length - 1; i >= 0; i--)
1619
- if (d = decorators[i])
1620
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1621
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1622
- };
1623
- var __metadata$7 = (undefined && undefined.__metadata) || function (k, v) {
1624
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1625
- return Reflect.metadata(k, v);
1626
- };
1627
- const NylasEventLimits = class {
1628
- constructor(hostRef) {
1629
- registerInstance(this, hostRef);
1630
- if (hostRef.$hostElement$["s-ei"]) {
1631
- this.internals = hostRef.$hostElement$["s-ei"];
1632
- }
1633
- else {
1634
- this.internals = hostRef.$hostElement$.attachInternals();
1635
- hostRef.$hostElement$["s-ei"] = this.internals;
1636
- }
1637
- }
1638
- connectedCallback() {
1639
- debug('nylas-event-limits', 'connectedCallback');
1640
- }
1641
- componentWillLoad() {
1642
- debug('nylas-event-limits', 'componentWillLoad');
1643
- }
1644
- componentDidLoad() {
1645
- debug('nylas-event-limits', 'componentDidLoad');
1646
- checkForMissingSlots(['inputs'], this.el);
1647
- }
1648
- disconnectedCallback() {
1649
- debug('nylas-event-limits', 'disconnectedCallback');
1650
- }
1651
- render() {
1652
- return (h(Host, { key: '4afbe82f9887a84579e5a16fa628a8785927e19f' }, h("nylas-form-card", { key: 'b092de56ed7f3902ed5de970963697e19f47b5ea' }, h("h1", { key: 'c1a940f48d1e8daeaa719cfcefc7b5948960ea5c', slot: "header-title", class: "nylas-event-limits__title" }, "Set event limits"), h("h3", { key: '68c6426b83df6c15a85f6bae5bc0fd47aa17e8b4', slot: "header-subtitle", class: "nylas-event-limits__subtitle" }, "Customize event limits for the event."), h("div", { key: 'e70ed6be6d75a69b9405c38c0ab68accbc799670', slot: "content", class: "nylas-event-limits__content" }, h("slot", { key: '7220956029fa2ae7f8ab7f05342ab2ee8d15c15f', name: "inputs" })))));
1653
- }
1654
- static get formAssociated() { return true; }
1655
- get el() { return getElement(this); }
1656
- };
1657
- __decorate$7([
1658
- RegisterComponent({
1659
- name: 'nylas-event-limits',
1660
- eventToProps: {},
1661
- fireRegisterEvent: true,
1662
- }),
1663
- __metadata$7("design:type", Function),
1664
- __metadata$7("design:paramtypes", []),
1665
- __metadata$7("design:returntype", void 0)
1666
- ], NylasEventLimits.prototype, "render", null);
1667
- NylasEventLimits.style = NylasEventLimitsStyle0;
1668
-
1669
- const nylasEventLocationCss = ":host{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-event-location{display:flex;flex-direction:column;gap:4px;font-family:var(--nylas-font-family)}.nylas-event-location label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-event-location label span.label-icon{margin-left:4px}.nylas-event-location label span.label-icon tooltip-component{display:flex}.nylas-event-location span[slot=select-icon]{border-right:1px solid var(--nylas-base-200);padding:16px 0.75rem 16px 0.5rem;border-radius:var(--nylas-border-radius-2x);border-bottom-right-radius:0;border-top-right-radius:0;height:20px}.nylas-event-location div.location-input{display:grid;grid-template-columns:auto 1fr;width:100%;gap:0.5rem}@media screen and (max-width: 768px){.nylas-event-location div.location-input{grid-template-columns:1fr}}.nylas-event-location div.location-input input{border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x);padding:12px 16px;font-family:var(--nylas-font-family);font-size:16px;line-height:24px}.nylas-event-location select-dropdown{width:208px}@media screen and (max-width: 768px){.nylas-event-location select-dropdown{width:100%}}.nylas-event-location select-dropdown::part(sd_dropdown){width:100%}.nylas-event-location select-dropdown::part(sd_dropdown-content){left:calc(35px + 0.5rem)}.nylas-event-location select-dropdown::part(sd_dropdown-button){display:flex;justify-content:space-between;width:100%;border:1px solid var(--nylas-base-200);padding:0 0.5rem}.nylas-event-location select-dropdown::part(sd_dropdown-button-selected-label){display:inline-flex;align-self:center;padding:14px 0;font-family:var(--nylas-font-family);font-size:16px;line-height:24px}";
1670
- const NylasEventLocationStyle0 = nylasEventLocationCss;
1671
-
1672
- var __decorate$6 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1673
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1674
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1675
- r = Reflect.decorate(decorators, target, key, desc);
1676
- else
1677
- for (var i = decorators.length - 1; i >= 0; i--)
1678
- if (d = decorators[i])
1679
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1680
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1681
- };
1682
- var __metadata$6 = (undefined && undefined.__metadata) || function (k, v) {
1683
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1684
- return Reflect.metadata(k, v);
1685
- };
1686
- const NylasEventLocation = class {
1687
- constructor(hostRef) {
1688
- registerInstance(this, hostRef);
1689
- this.valueChanged = createEvent(this, "valueChanged", 7);
1690
- if (hostRef.$hostElement$["s-ei"]) {
1691
- this.internals = hostRef.$hostElement$["s-ei"];
1692
- }
1693
- else {
1694
- this.internals = hostRef.$hostElement$.attachInternals();
1695
- hostRef.$hostElement$["s-ei"] = this.internals;
1696
- }
1697
- this.name = 'location';
1698
- this.selectedConfiguration = undefined;
1699
- this.eventLocation = undefined;
1700
- this.location = this.eventLocation ?? '';
1701
- this.selectedLocationOption = this.eventLocation ? 'custom' : 'none';
1702
- }
1703
- elementNameChangedHandler(newValue) {
1704
- debug('nylas-event-location', 'elementNameChangedHandler', newValue);
1705
- this.host.setAttribute('name', newValue);
1706
- }
1707
- selectedConfigurationChangedHandler(newValue, oldValue) {
1708
- debug('nylas-custom-booking-flow', 'selectedConfigurationChangedHandler', newValue, oldValue);
1709
- const configLocation = newValue?.event_booking?.location;
1710
- if (configLocation) {
1711
- this.selectedLocationOption = configLocation ? 'custom' : 'none';
1712
- this.location = configLocation;
1713
- }
1714
- }
1715
- eventLocationChangedHandler(newValue, oldValue) {
1716
- debug('nylas-event-location', 'eventLocationChangedHandler', newValue);
1717
- if (newValue === oldValue) {
1718
- return;
1719
- }
1720
- this.selectedLocationOption = newValue ? 'custom' : 'none';
1721
- }
1722
- connectedCallback() {
1723
- debug('nylas-event-location', 'connectedCallback');
1724
- }
1725
- componentWillLoad() {
1726
- debug('nylas-event-location', 'componentWillLoad');
1727
- this.host.setAttribute('name', this.name);
1728
- }
1729
- componentDidLoad() {
1730
- debug('nylas-event-location', 'componentDidLoad');
1731
- }
1732
- disconnectedCallback() {
1733
- debug('nylas-event-location', 'disconnectedCallback');
1734
- }
1735
- nylasFormDropdownChangedHandler(event) {
1736
- this.selectedLocationOption = event.detail.value;
1737
- if (this.selectedLocationOption === 'none') {
1738
- this.location = '';
1739
- this.setFormValue('', 'location');
1740
- this.valueChanged.emit({ value: '', name: this.name });
1741
- }
1742
- }
1743
- setFormValue(value, name) {
1744
- if (typeof this.internals.setFormValue === 'function') {
1745
- this.internals.setFormValue(value, name);
1746
- }
1747
- }
1748
- handleChange(event) {
1749
- const value = sanitizeHtml(event.target.value);
1750
- this.location = value;
1751
- this.setFormValue(value, 'location');
1752
- this.valueChanged.emit({ value: value, name: this.name });
1753
- }
1754
- render() {
1755
- const locationOptions = [
1756
- { value: 'none', label: 'None' },
1757
- { value: 'custom', label: 'Custom location' },
1758
- ];
1759
- const icons = {
1760
- none: h("location-off-icon", { key: 'b83e4c1ee5292f3261fca8489ec10a6ded3378dc' }),
1761
- custom: h("location-icon", { key: '6ba8c483b7e242b0accf8a55ccb11efc8b4e19a5' }),
1762
- };
1763
- return (h(Host, { key: 'f65e817196207fa0397fb599bc89a8cb72b7e8e1' }, h("div", { key: '7410dde44d2b93d0aa655feb0c9dede3b14f3f1e', class: "nylas-event-location", part: "nel" }, h("label", { key: '4d158faf262e76e325e1dc35792bc36800a3df6f', htmlFor: "location" }, "Location type", h("span", { key: '28b4287f14b80b9a1db726470bf27dd017b3ba37', class: "label-icon" }, h("tooltip-component", { key: '65a2db2bdf57377beb1b5b4801a89f5a74320205' }, h("info-icon", { key: '350b0f6f2c7f442cc4fb3fdee838c600d271d667', slot: "tooltip-icon" }), h("span", { key: '31027673d5cd518b6cbc847c0010f482b0540de6', slot: "tooltip-content" }, "Choose how you\u2019ll meet with the participants at the scheduled time. Pick from available conferencing options or add a custom location.")))), h("div", { key: 'a902e62a97f181dcb6b0e0e4daea1ec4c817fe58', class: "location-input" }, h("select-dropdown", { key: '5f271d86549b8fa286b630f169e191d4c1d73e3d', withSearch: false, name: "location", options: locationOptions, defaultSelectedOption: locationOptions.find(i => i.value == this.selectedLocationOption), exportparts: "sd_dropdown: nel__dropdown, sd_dropdown-button: nel__dropdown-button, sd_dropdown-content: nel__dropdown-content" }, h("span", { key: 'cdc3f3fcdf971ffe3495f085b39cac2a1e77df11', slot: "select-icon" }, icons[this.selectedLocationOption])), this.selectedLocationOption === 'custom' && (h("input", { type: "text", part: "nel__location", id: "location", name: "location", maxlength: "1024", value: this.location, onInput: e => this.handleChange(e) }))))));
1764
- }
1765
- static get formAssociated() { return true; }
1766
- get host() { return getElement(this); }
1767
- static get watchers() { return {
1768
- "name": ["elementNameChangedHandler"],
1769
- "selectedConfiguration": ["selectedConfigurationChangedHandler"],
1770
- "eventLocation": ["eventLocationChangedHandler"]
1771
- }; }
1772
- };
1773
- __decorate$6([
1774
- RegisterComponent({
1775
- name: 'nylas-event-location',
1776
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
1777
- eventToProps: {},
1778
- fireRegisterEvent: true,
1779
- }),
1780
- __metadata$6("design:type", Function),
1781
- __metadata$6("design:paramtypes", []),
1782
- __metadata$6("design:returntype", void 0)
1783
- ], NylasEventLocation.prototype, "render", null);
1784
- NylasEventLocation.style = NylasEventLocationStyle0;
1785
-
1786
- const nylasEventTitleCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-event-title{display:flex;flex-direction:column;gap:4px;position:relative;text-align:left}.nylas-event-title div.title{padding:12px 16px;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x);overflow:scroll;white-space:nowrap;scrollbar-width:thin}.nylas-event-title div.title::-webkit-scrollbar{width:6px;height:6px}.nylas-event-title div.title.error{border-color:var(--nylas-error);outline:none}.nylas-event-title input{padding:12px 16px;border-width:1;border-radius:8px;border:1px solid var(--nylas-base-200)}.nylas-event-title span.help-text{color:var(--nylas-base-800);font-size:14px;font-style:normal;font-weight:400;line-height:21px}.nylas-event-title span.error-message{color:var(--nylas-error)}.nylas-event-title label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-event-title label span.required{color:var(--nylas-error, #cc4841)}.nylas-event-title label span.label-icon{margin-left:4px}.nylas-event-title label span.label-icon tooltip-component{display:flex}.highlighted-tag{background-color:var(--nylas-base-200);border-radius:var(--nylas-border-radius);padding:5px;margin-left:4px}.token-options{display:block;background-color:var(--nylas-base-0);width:100%;max-height:336px;overflow:auto;z-index:1;border-radius:4px;position:absolute;top:80px;box-shadow:0px 4px 6px -2px rgba(0, 0, 0, 0.0509803922);box-shadow:0px 10px 15px -3px rgba(0, 0, 0, 0.1019607843)}@media screen and (max-width: 768px){.token-options{right:0;width:325px;max-width:unset}}.token-options ul{padding:0;list-style-type:none;color:var(--nylas-base-900);max-height:336px;margin:0}.token-options ul li{padding:16px, 12px, 16px, 12px;color:black;padding:12px 16px;text-decoration:none;display:block;font-family:inherit;font-size:14px;font-weight:400;line-height:20px;letter-spacing:0px;text-align:left;cursor:pointer}.token-options ul li .token-label{display:flex;flex-direction:column;font-weight:400}.token-options ul li .token-label .token{color:var(--nylas-abse-900);font-size:16px;line-height:24px}.token-options ul li .token-label .description{color:var(--nylas-base-600);font-size:14px;line-height:21px}.token-options ul li:hover,.token-options ul li:focus,.token-options ul li:active,.token-options ul li.active{background-color:var(--nylas-base-100)}.token-options ul li:hover .token-label .token,.token-options ul li:focus .token-label .token,.token-options ul li:active .token-label .token,.token-options ul li.active .token-label .token{color:var(--nylas-primary)}.token-options .selected{background-color:var(--nylas-base-100)}";
1787
- const NylasEventTitleStyle0 = nylasEventTitleCss;
1788
-
1789
- var __decorate$5 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
1790
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1791
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
1792
- r = Reflect.decorate(decorators, target, key, desc);
1793
- else
1794
- for (var i = decorators.length - 1; i >= 0; i--)
1795
- if (d = decorators[i])
1796
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1797
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1798
- };
1799
- var __metadata$5 = (undefined && undefined.__metadata) || function (k, v) {
1800
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
1801
- return Reflect.metadata(k, v);
1802
- };
1803
- const NylasEventTitle = class {
1804
- constructor(hostRef) {
1805
- registerInstance(this, hostRef);
1806
- this.valueChanged = createEvent(this, "valueChanged", 7);
1807
- if (hostRef.$hostElement$["s-ei"]) {
1808
- this.internals = hostRef.$hostElement$["s-ei"];
1809
- }
1810
- else {
1811
- this.internals = hostRef.$hostElement$.attachInternals();
1812
- hostRef.$hostElement$["s-ei"] = this.internals;
1813
- }
1814
- this.selectedConfiguration = undefined;
1815
- this.eventTitle = this.selectedConfiguration?.event_booking?.title;
1816
- this.name = 'title';
1817
- this.showTokens = false;
1818
- this.availableTokens = EVENT_TITLE_TOKENS.map(token => ({
1819
- label: token.token,
1820
- value: token.value,
1821
- labelHTML: token,
1822
- }));
1823
- this.filteredTokens = this.availableTokens;
1824
- this.ariaActivedescendant = '';
1825
- this.currentWord = { $value: '', fullText: '', index: -1, focusOffset: -1 };
1826
- this.validationError = '';
1827
- }
1828
- elementNameChangedHandler(newValue) {
1829
- debug('nylas-event-title', 'elementNameChangedHandler', newValue);
1830
- this.host.setAttribute('name', newValue);
1831
- }
1832
- ariaActivedescendantChangedHandler(newValue) {
1833
- debug('nylas-event-title', 'ariaActivedescendantChangedHandler', newValue);
1834
- if (newValue !== '') {
1835
- const activeOption = this.host.shadowRoot?.getElementById(newValue);
1836
- activeOption?.classList.add('active');
1837
- }
1838
- else {
1839
- const options = this.host.shadowRoot?.querySelectorAll('.token-options li.active');
1840
- options?.forEach(option => option.classList.remove('active'));
1841
- }
1842
- }
1843
- configChangedHandler(newVal) {
1844
- const title = newVal?.event_booking?.title;
1845
- if (title) {
1846
- this.updateEventTitleFromProp(title);
1847
- }
1848
- }
1849
- connectedCallback() {
1850
- debug('nylas-event-title', 'connectedCallback');
1851
- }
1852
- componentWillLoad() {
1853
- debug('nylas-event-title', 'componentWillLoad');
1854
- this.host.setAttribute('name', this.name);
1855
- }
1856
- componentDidLoad() {
1857
- debug('nylas-event-title', 'componentDidLoad');
1858
- this.updateEventTitleFromProp(this.eventTitle || '');
1859
- }
1860
- disconnectedCallback() {
1861
- debug('nylas-event-title', 'disconnectedCallback');
1862
- }
1863
- formSubmittedHandler(event) {
1864
- debug('nylas-event-title', 'formSubmittedHandler', event);
1865
- if (!this.internals?.validity?.valid) {
1866
- this.validationError = 'Event title is required';
1867
- }
1868
- else {
1869
- this.validationError = '';
1870
- }
1871
- }
1872
- updateEventTitleFromProp(newValue) {
1873
- debug('nylas-event-title', 'eventTitleChangedHandler', newValue);
1874
- if (this.titleRef) {
1875
- this.titleRef.innerHTML = this.highlightTokens(newValue);
1876
- this.titleRef.focus();
1877
- if (typeof this.internals.setValidity === 'function') {
1878
- if (newValue === '') {
1879
- this.internals?.setValidity({ customError: true }, `Event title is required`, this.titleRef);
1880
- }
1881
- else {
1882
- this.internals?.setValidity({ customError: false });
1883
- }
1884
- }
1885
- }
1886
- }
1887
- highlightTokens(title) {
1888
- let outputHtml = title;
1889
- EVENT_TITLE_TOKENS.forEach(tokenObj => {
1890
- const token = tokenObj.value;
1891
- const regex = new RegExp(`(\\${token})(?!\\w)`, 'g');
1892
- outputHtml = outputHtml.replace(regex, '<span class="highlighted-tag">$1</span>');
1893
- });
1894
- return outputHtml;
1895
- }
1896
- getCurrentSelectionForBrowser() {
1897
- const getSelectionTextData = (nodeValue, offset, node, allSelected) => {
1898
- const text = nodeValue.replace(/[\u200B-\u200D\uFEFF]/g, '');
1899
- const dollarIndex = text.lastIndexOf('$');
1900
- const lastWord = text.substring(dollarIndex).split(' ')[0];
1901
- return {
1902
- focusOffset: offset,
1903
- dollarIndex,
1904
- lastWord,
1905
- currentText: text,
1906
- node,
1907
- allSelected,
1908
- };
1909
- };
1910
- const isAllSelected = (selection) => selection.anchorOffset === 0 && selection.focusOffset === selection.focusNode?.nodeValue?.length;
1911
- const currentBrowser = getBrowser();
1912
- switch (currentBrowser) {
1913
- case 'Chrome':
1914
- const shadowRootSelection = this.host.shadowRoot?.getSelection();
1915
- const focusNode = shadowRootSelection?.focusNode;
1916
- const focusNodeValue = focusNode?.nodeValue || '';
1917
- const allSelected = shadowRootSelection && isAllSelected(shadowRootSelection);
1918
- return getSelectionTextData(focusNodeValue, shadowRootSelection?.focusOffset || -1, focusNode, allSelected);
1919
- case 'Firefox':
1920
- const selection = document.getSelection();
1921
- const anchorNodeValue = selection?.anchorNode?.nodeValue || '';
1922
- const allSelectedFirefox = selection && isAllSelected(selection);
1923
- return getSelectionTextData(anchorNodeValue, selection?.focusOffset || -1, selection?.anchorNode, allSelectedFirefox);
1924
- case 'Safari':
1925
- const windowSelection = window.getSelection();
1926
- const anchorNode = windowSelection?.getComposedRanges(this.host.shadowRoot)[0];
1927
- const currentText = anchorNode?.startContainer?.nodeValue || '';
1928
- const allSelectedSafari = windowSelection && isAllSelected(windowSelection);
1929
- return getSelectionTextData(currentText, anchorNode?.endOffset || -1, anchorNode?.startContainer, allSelectedSafari);
1930
- default:
1931
- console.warn('Browser not supported');
1932
- return null;
1933
- }
1934
- }
1935
- handleChange(event) {
1936
- let textContent = event.target.textContent || '';
1937
- textContent = sanitizeHtml(textContent);
1938
- const currentSelection = this.getCurrentSelectionForBrowser();
1939
- if (!currentSelection) {
1940
- this.updateEventTitle(textContent);
1941
- this.resetDropdown();
1942
- return;
1943
- }
1944
- const { focusOffset, dollarIndex, lastWord, currentText } = currentSelection;
1945
- if (dollarIndex === -1 || focusOffset < dollarIndex) {
1946
- this.updateEventTitle(textContent);
1947
- this.resetDropdown();
1948
- return;
1949
- }
1950
- if (lastWord.startsWith('$')) {
1951
- this.showTokens = true;
1952
- this.currentWord = {
1953
- $value: lastWord,
1954
- fullText: currentText,
1955
- index: dollarIndex,
1956
- focusOffset,
1957
- };
1958
- this.populateSuggestionsDropdown(lastWord);
1959
- }
1960
- else {
1961
- this.resetDropdown();
1962
- }
1963
- this.updateEventTitle(textContent);
1964
- }
1965
- handleInputKeyDown(event) {
1966
- const selection = this.getCurrentSelectionForBrowser();
1967
- if (selection?.allSelected && !isNonPrintableKey(event)) {
1968
- this.titleRef.innerHTML = '';
1969
- }
1970
- if (event.key === 'Enter') {
1971
- event.preventDefault();
1972
- const activeOption = this.host.shadowRoot?.getElementById(this.ariaActivedescendant);
1973
- if (activeOption) {
1974
- activeOption.click();
1975
- this.ariaActivedescendant = '';
1976
- }
1977
- }
1978
- else if (event.key === 'ArrowDown') {
1979
- event.preventDefault();
1980
- const activeOption = this.host.shadowRoot?.getElementById(this.ariaActivedescendant);
1981
- if (activeOption) {
1982
- const nextOption = activeOption.nextElementSibling;
1983
- if (nextOption) {
1984
- this.ariaActivedescendant = nextOption.id;
1985
- }
1986
- else {
1987
- this.ariaActivedescendant = this.filteredTokens[0].label;
1988
- }
1989
- }
1990
- else {
1991
- this.ariaActivedescendant = this.filteredTokens[0].label;
1992
- }
1993
- }
1994
- else if (event.key === 'ArrowUp') {
1995
- event.preventDefault();
1996
- const activeOption = this.host.shadowRoot?.getElementById(this.ariaActivedescendant);
1997
- if (activeOption) {
1998
- const prevOption = activeOption.previousElementSibling;
1999
- if (prevOption) {
2000
- this.ariaActivedescendant = prevOption.id;
2001
- }
2002
- else {
2003
- this.ariaActivedescendant = this.filteredTokens[this.filteredTokens.length - 1].label;
2004
- }
2005
- }
2006
- else {
2007
- this.ariaActivedescendant = this.filteredTokens[this.filteredTokens.length - 1].label;
2008
- }
2009
- }
2010
- else if (event.key === 'Escape') {
2011
- event.preventDefault();
2012
- this.resetDropdown();
2013
- }
2014
- else if (event.key === 'Backspace' || event.key === 'Delete') {
2015
- if (selection?.currentText.startsWith('${')) {
2016
- selection?.node?.parentNode && selection.node.parentNode.removeChild(selection.node);
2017
- }
2018
- if (this.titleRef.textContent === '' || selection?.currentText === '' || selection?.allSelected) {
2019
- this.titleRef.innerHTML = '';
2020
- }
2021
- }
2022
- }
2023
- selectOption(e, option) {
2024
- e.preventDefault();
2025
- const word = this.currentWord.fullText;
2026
- const dollarWord = this.currentWord.$value;
2027
- let currentNode = this.titleRef.firstChild;
2028
- let textNode = null;
2029
- while (currentNode) {
2030
- if (currentNode.nodeType === 3) {
2031
- const currentNodeText = currentNode.textContent?.replace(/[\u200B-\u200D\uFEFF]/g, '') || '';
2032
- const wordText = word.replace(/[\u200B-\u200D\uFEFF]/g, '');
2033
- if (currentNodeText.includes(wordText)) {
2034
- textNode = currentNode;
2035
- break;
2036
- }
2037
- }
2038
- currentNode = currentNode.nextSibling;
2039
- }
2040
- if (!textNode) {
2041
- return;
2042
- }
2043
- const text = textNode.textContent || '';
2044
- const index = text.indexOf(dollarWord);
2045
- const textBefore = text.substring(0, index);
2046
- const textAfter = text.substring(index + dollarWord.length);
2047
- const newTextNode = document.createTextNode(textBefore);
2048
- const newRange = document.createRange();
2049
- const tagSpan = document.createElement('span');
2050
- tagSpan.classList.add('highlighted-tag');
2051
- tagSpan.textContent = `${option.value}`;
2052
- const newTextNodeAfter = document.createTextNode(textAfter);
2053
- if (textAfter !== '') {
2054
- textNode.replaceWith(newTextNode, tagSpan, newTextNodeAfter);
2055
- newRange.setStart(newTextNodeAfter, 1);
2056
- }
2057
- else {
2058
- const afterNode = document.createTextNode('\u200B');
2059
- textNode.replaceWith(newTextNode, tagSpan, afterNode);
2060
- newRange.setStart(afterNode, 1);
2061
- }
2062
- this.resetDropdown();
2063
- this.titleRef.focus();
2064
- const sel = window.getSelection();
2065
- newRange.collapse(true);
2066
- sel?.removeAllRanges();
2067
- sel?.addRange(newRange);
2068
- this.updateEventTitle(this.titleRef.textContent || '');
2069
- }
2070
- populateSuggestionsDropdown(query = '') {
2071
- this.filteredTokens = this.availableTokens.filter(obj => {
2072
- return obj.label.startsWith(query.toString()) || obj.value.startsWith(query.toString());
2073
- });
2074
- if (this.filteredTokens.length > 0) {
2075
- this.ariaActivedescendant = this.filteredTokens[0].label;
2076
- }
2077
- }
2078
- updateEventTitle(text) {
2079
- const value = text.replace(/ +/g, ' ');
2080
- if (value === '') {
2081
- this.internals?.setValidity({ customError: true }, `Event title is required`, this.titleRef);
2082
- this.validationError = 'Event title is required';
2083
- }
2084
- else {
2085
- this.internals?.setValidity({ customError: false });
2086
- this.validationError = '';
2087
- }
2088
- this.internals?.setFormValue(value, this.name);
2089
- this.valueChanged.emit({ value: value, name: this.name });
2090
- }
2091
- resetDropdown() {
2092
- this.showTokens = false;
2093
- this.ariaActivedescendant = '';
2094
- }
2095
- getLabelHTML(token) {
2096
- return (h("div", { class: "token-label" }, h("span", { class: "token" }, token.token), h("span", { class: "description" }, token.description)));
2097
- }
2098
- render() {
2099
- return (h(Host, { key: 'ec414f2f4c738230078bed7b7c5477ba5fdbcb70' }, h("div", { key: '17f665e5f307c1b6510891e76daa765449958c3e', class: "nylas-event-title", part: "net" }, h("label", { key: 'e4beac83e857bab219ec4276238f7953645c4711', htmlFor: "title" }, "Event title", h("span", { key: '3033d6ef407f2a3df94dc1f80be2f5e3c378abd0', class: "required" }, "*"), h("span", { key: '29dba11e88726329513ef15078eba34f103914de', class: "label-icon" }, h("tooltip-component", { key: '29a373fc979f15eb3527b9e5a446bd7518ee4562' }, h("info-icon", { key: '12f9a0190185b96a2090cdb0ca7a43f6342cc016', slot: "tooltip-icon" }), h("span", { key: 'dd6e505591f9cded5bc70a812e448b44f1faa4e1', slot: "tooltip-content" }, "Enter a title for your event.")))), h("div", { key: '87807255004e909850b93d600b636d2d2e1d8ed1', class: {
2100
- title: true,
2101
- error: this.validationError !== '',
2102
- }, part: "net__title", ref: el => (this.titleRef = el), contentEditable: "true", onInput: e => this.handleChange(e), onKeyDown: event => this.handleInputKeyDown(event) }), this.showTokens && this.filteredTokens?.length > 0 && (h("div", { class: "token-options", part: "net__dropdown-content" }, h("ul", { tabindex: "-1", role: "listbox", "aria-label": this.name, "aria-activedescendant": this.ariaActivedescendant }, this.filteredTokens.map(option => (h("li", { tabindex: "0", key: option.label, id: option.label, class: { active: this.ariaActivedescendant === option.label }, onClick: e => this.selectOption(e, option), role: "option" }, this.getLabelHTML(option.labelHTML))))))), h("span", { key: '3ba87900ffbc4b69c5f9fac01a8f9f577dd034c5', class: "help-text" }, "Create a dynamic templated event title by typing $. Learn more"), this.validationError != '' && h("span", { class: "error-message" }, this.validationError))));
2103
- }
2104
- static get formAssociated() { return true; }
2105
- get host() { return getElement(this); }
2106
- static get watchers() { return {
2107
- "name": ["elementNameChangedHandler"],
2108
- "ariaActivedescendant": ["ariaActivedescendantChangedHandler"],
2109
- "selectedConfiguration": ["configChangedHandler"]
2110
- }; }
2111
- };
2112
- __decorate$5([
2113
- RegisterComponent({
2114
- name: 'nylas-event-title',
2115
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
2116
- eventToProps: {},
2117
- fireRegisterEvent: true,
2118
- }),
2119
- __metadata$5("design:type", Function),
2120
- __metadata$5("design:paramtypes", []),
2121
- __metadata$5("design:returntype", void 0)
2122
- ], NylasEventTitle.prototype, "render", null);
2123
- NylasEventTitle.style = NylasEventTitleStyle0;
2124
-
2125
- const nylasLimitFutureBookingsCss = ":host{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-limit-future-bookings{display:flex;justify-content:space-between;font-family:var(--nylas-font-family)}@media screen and (max-width: 768px){.nylas-limit-future-bookings{flex-direction:column;gap:0.5rem}}.nylas-limit-future-bookings label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-limit-future-bookings label span.label-icon{margin-left:4px}.nylas-limit-future-bookings label span.label-icon tooltip-component{display:flex}select-dropdown::part(sd_dropdown-button){border:none}";
2126
- const NylasLimitFutureBookingsStyle0 = nylasLimitFutureBookingsCss;
2127
-
2128
- var __decorate$4 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
2129
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2130
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
2131
- r = Reflect.decorate(decorators, target, key, desc);
2132
- else
2133
- for (var i = decorators.length - 1; i >= 0; i--)
2134
- if (d = decorators[i])
2135
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2136
- return c > 3 && r && Object.defineProperty(target, key, r), r;
2137
- };
2138
- var __metadata$4 = (undefined && undefined.__metadata) || function (k, v) {
2139
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
2140
- return Reflect.metadata(k, v);
2141
- };
2142
- const NylasLimitFutureBookings = class {
2143
- constructor(hostRef) {
2144
- registerInstance(this, hostRef);
2145
- this.valueChanged = createEvent(this, "valueChanged", 7);
2146
- if (hostRef.$hostElement$["s-ei"]) {
2147
- this.internals = hostRef.$hostElement$["s-ei"];
2148
- }
2149
- else {
2150
- this.internals = hostRef.$hostElement$.attachInternals();
2151
- hostRef.$hostElement$["s-ei"] = this.internals;
2152
- }
2153
- this.selectedConfiguration = undefined;
2154
- this.availableDaysInFuture = undefined;
2155
- this.name = 'limit-future-bookings';
2156
- this.selectedNumber = 1;
2157
- this.selectedPeriod = 'day';
2158
- }
2159
- elementNameChangedHandler(newValue) {
2160
- debug('nylas-limit-future-bookings', 'elementNameChangedHandler', newValue);
2161
- this.host.setAttribute('name', newValue);
2162
- }
2163
- selectedConfigurationChangedHandler(newVal) {
2164
- const daysInFuture = newVal?.scheduler?.available_days_in_future;
2165
- if (daysInFuture) {
2166
- this.updateNumberAndPeriodFromDays(daysInFuture);
2167
- }
2168
- }
2169
- availableDaysInFutureChanged(newValue) {
2170
- this.updateNumberAndPeriodFromDays(newValue);
2171
- }
2172
- connectedCallback() {
2173
- debug('nylas-limit-future-bookings', 'connectedCallback');
2174
- }
2175
- componentWillLoad() {
2176
- debug('nylas-limit-future-bookings', 'componentWillLoad');
2177
- this.host.setAttribute('name', this.name);
2178
- }
2179
- componentDidLoad() {
2180
- debug('nylas-limit-future-bookings', 'componentDidLoad');
2181
- this.availableDaysInFutureChanged(this.availableDaysInFuture ?? 1);
2182
- if (typeof this.internals.setFormValue !== 'function') {
2183
- return;
2184
- }
2185
- this.internals.setFormValue(this.availableDaysInFuture?.toString() ?? '1', this.name);
2186
- }
2187
- disconnectedCallback() {
2188
- debug('nylas-limit-future-bookings', 'disconnectedCallback');
2189
- }
2190
- timePeriodChangedHandler(event) {
2191
- const { number, period } = event.detail;
2192
- let availableDaysInFuture;
2193
- if (period === 'day') {
2194
- availableDaysInFuture = number;
2195
- }
2196
- else if (period === 'week') {
2197
- availableDaysInFuture = number * 7;
2198
- }
2199
- else {
2200
- availableDaysInFuture = number * 30;
2201
- }
2202
- this.valueChanged.emit({ value: availableDaysInFuture, name: 'availableDaysInFuture' });
2203
- if (typeof this.internals.setFormValue !== 'function') {
2204
- return;
2205
- }
2206
- this.internals.setFormValue(availableDaysInFuture.toString(), this.name);
2207
- }
2208
- updateNumberAndPeriodFromDays(days) {
2209
- let number, period;
2210
- if (days >= 30 && days % 30 === 0) {
2211
- number = days / 30;
2212
- period = 'month';
2213
- }
2214
- else if (days >= 7 && days % 7 === 0) {
2215
- number = days / 7;
2216
- period = 'week';
2217
- }
2218
- else {
2219
- number = days;
2220
- period = 'day';
2221
- }
2222
- this.selectedNumber = number;
2223
- this.selectedPeriod = period;
2224
- }
2225
- render() {
2226
- return (h(Host, { key: '9efaf822025f476c80f4c5124f226e45ef9047f9' }, h("div", { key: 'acb0ed9bb24d9e789c01127b2343194d47c37c5f', class: "nylas-limit-future-bookings", part: "nlfb" }, h("label", { key: 'b4bbe14a0870451be5c7754dbbd3adb029b1d24c' }, "Limit future bookings", h("span", { key: 'e1e671d334ec20347852549c4b4d63fa626a2186', class: "label-icon" }, h("tooltip-component", { key: '378c5a41fe7920cebd1f9de4ea16873e951584cf' }, h("info-icon", { key: 'dee6d8d027c746b19b4de42a7e57754a6dcf0a34', slot: "tooltip-icon" }), h("span", { key: 'f128781fb212013489d7db03e7b5fb1a02681b5a', slot: "tooltip-content" }, "Set a limit on how far in the future bookings can be made.")))), h("time-period-selector", { key: 'fb00fd64c7dec2beb976132a397bb067e72c0cc3', id: "limit-future-bookings", timePeriods: ['day', 'week', 'month'], exportparts: "tps__number-dropdown: nlfb__number-dropdown, tps__number-dropdown-button: nlfb__number-dropdown-button, tps__number-dropdown-content: nlfb__number-dropdown-content, tps__period-dropdown: nlfb__period-dropdown, tps__period-dropdown-button: nlfb__period-dropdown-button, tps__period-dropdown-content: nlfb__period-dropdown-content", defaultSelectedNumber: this.selectedNumber, defaultSelectedPeriod: this.selectedPeriod }))));
2227
- }
2228
- static get formAssociated() { return true; }
2229
- get host() { return getElement(this); }
2230
- static get watchers() { return {
2231
- "name": ["elementNameChangedHandler"],
2232
- "selectedConfiguration": ["selectedConfigurationChangedHandler"],
2233
- "availableDaysInFuture": ["availableDaysInFutureChanged"]
2234
- }; }
2235
- };
2236
- __decorate$4([
2237
- RegisterComponent({
2238
- name: 'nylas-limit-future-bookings',
2239
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
2240
- eventToProps: {},
2241
- fireRegisterEvent: true,
2242
- }),
2243
- __metadata$4("design:type", Function),
2244
- __metadata$4("design:paramtypes", []),
2245
- __metadata$4("design:returntype", void 0)
2246
- ], NylasLimitFutureBookings.prototype, "render", null);
2247
- NylasLimitFutureBookings.style = NylasLimitFutureBookingsStyle0;
2248
-
2249
- const nylasMinBookingNoticeCss = ":host{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-min-booking-notice{display:flex;justify-content:space-between;font-family:var(--nylas-font-family)}@media screen and (max-width: 768px){.nylas-min-booking-notice{flex-direction:column;gap:0.5rem}}.nylas-min-booking-notice label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-min-booking-notice label span.label-icon{margin-left:4px}.nylas-min-booking-notice label span.label-icon tooltip-component{display:flex}select-dropdown::part(sd_dropdown-button){border:none}";
2250
- const NylasMinBookingNoticeStyle0 = nylasMinBookingNoticeCss;
2251
-
2252
- var __decorate$3 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
2253
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2254
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
2255
- r = Reflect.decorate(decorators, target, key, desc);
2256
- else
2257
- for (var i = decorators.length - 1; i >= 0; i--)
2258
- if (d = decorators[i])
2259
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2260
- return c > 3 && r && Object.defineProperty(target, key, r), r;
2261
- };
2262
- var __metadata$3 = (undefined && undefined.__metadata) || function (k, v) {
2263
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
2264
- return Reflect.metadata(k, v);
2265
- };
2266
- const NylasMinBookingNotice = class {
2267
- constructor(hostRef) {
2268
- registerInstance(this, hostRef);
2269
- this.valueChanged = createEvent(this, "valueChanged", 7);
2270
- if (hostRef.$hostElement$["s-ei"]) {
2271
- this.internals = hostRef.$hostElement$["s-ei"];
2272
- }
2273
- else {
2274
- this.internals = hostRef.$hostElement$.attachInternals();
2275
- hostRef.$hostElement$["s-ei"] = this.internals;
2276
- }
2277
- this.selectedConfiguration = undefined;
2278
- this.minBookingNotice = undefined;
2279
- this.name = 'min-booking-notice';
2280
- this.selectedNumber = 1;
2281
- this.selectedPeriod = 'hour';
2282
- }
2283
- elementNameChangedHandler(newValue) {
2284
- debug('nylas-min-booking-notice', 'elementNameChangedHandler', newValue);
2285
- this.host.setAttribute('name', newValue);
2286
- }
2287
- selectedConfigurationChangedHandler(newVal) {
2288
- const minBookingNotice = newVal?.scheduler?.min_booking_notice;
2289
- if (minBookingNotice) {
2290
- this.updateNumberAndPeriodFromMinutes(minBookingNotice);
2291
- }
2292
- }
2293
- availableDaysInFutureChanged(newValue) {
2294
- this.updateNumberAndPeriodFromMinutes(newValue);
2295
- }
2296
- connectedCallback() {
2297
- debug('nylas-min-booking-notice', 'connectedCallback');
2298
- }
2299
- componentWillLoad() {
2300
- debug('nylas-min-booking-notice', 'componentWillLoad');
2301
- this.host.setAttribute('name', this.name);
2302
- }
2303
- componentDidLoad() {
2304
- debug('nylas-min-booking-notice', 'componentDidLoad');
2305
- this.availableDaysInFutureChanged(this.minBookingNotice ?? 1);
2306
- if (typeof this.internals.setFormValue !== 'function') {
2307
- return;
2308
- }
2309
- this.internals.setFormValue(this.minBookingNotice?.toString() ?? '1', this.name);
2310
- }
2311
- disconnectedCallback() {
2312
- debug('nylas-min-booking-notice', 'disconnectedCallback');
2313
- }
2314
- timePeriodChangedHandler(event) {
2315
- const { number, period } = event.detail;
2316
- let totalMinutes;
2317
- const minutesInHour = 60;
2318
- const minutesInDay = minutesInHour * 24;
2319
- const minutesInWeek = minutesInDay * 7;
2320
- const minutesInMonth = minutesInDay * 30;
2321
- if (period === 'minute') {
2322
- totalMinutes = number;
2323
- }
2324
- else if (period === 'hour') {
2325
- totalMinutes = number * minutesInHour;
2326
- }
2327
- else if (period === 'day') {
2328
- totalMinutes = number * minutesInDay;
2329
- }
2330
- else if (period === 'week') {
2331
- totalMinutes = number * minutesInWeek;
2332
- }
2333
- else if (period === 'month') {
2334
- totalMinutes = number * minutesInMonth;
2335
- }
2336
- else {
2337
- totalMinutes = 0;
2338
- }
2339
- this.valueChanged.emit({ value: totalMinutes, name: 'minBookingNotice' });
2340
- if (typeof this.internals.setFormValue !== 'function') {
2341
- return;
2342
- }
2343
- this.internals.setFormValue(totalMinutes.toString(), this.name);
2344
- }
2345
- updateNumberAndPeriodFromMinutes(minutes) {
2346
- const minutesInHour = 60;
2347
- const minutesInDay = minutesInHour * 24;
2348
- const minutesInWeek = minutesInDay * 7;
2349
- const minutesInMonth = minutesInDay * 30;
2350
- let number, period;
2351
- if (minutes >= minutesInMonth) {
2352
- number = Math.floor(minutes / minutesInMonth);
2353
- period = 'month';
2354
- }
2355
- else if (minutes >= minutesInWeek) {
2356
- number = Math.floor(minutes / minutesInWeek);
2357
- period = 'week';
2358
- }
2359
- else if (minutes >= minutesInDay) {
2360
- number = Math.floor(minutes / minutesInDay);
2361
- period = 'day';
2362
- }
2363
- else if (minutes >= minutesInHour) {
2364
- number = Math.floor(minutes / minutesInHour);
2365
- period = 'hour';
2366
- }
2367
- else {
2368
- number = minutes;
2369
- period = 'minute';
2370
- }
2371
- this.selectedNumber = number;
2372
- this.selectedPeriod = period;
2373
- }
2374
- render() {
2375
- return (h(Host, { key: 'b00e1ce3adc1082c819774df6888d86fd93b06b6' }, h("div", { key: '0cd17759b7e1d3790904fe868addfa02065a3115', class: "nylas-min-booking-notice", part: "nmbn" }, h("label", { key: 'c27bc50a60686fb925904c5f86c9f19a7ab8079c' }, "Minimum booking notice", h("span", { key: '67b1a1351adbe6265d549501609af036d993920b', class: "label-icon" }, h("tooltip-component", { key: '4e64d044707c9fe94aa84caa242a0e034c0a89f7' }, h("info-icon", { key: 'bf64b04e4d308449249dae8a19a6c4043f26c1dd', slot: "tooltip-icon" }), h("span", { key: '434e31ddf539c4fcb287b198d780b6593808a607', slot: "tooltip-content" }, "The minimum amount of time in the future for planning the event.")))), h("time-period-selector", { key: 'efd40f4731319bd7da2aed6995279c8068e505ac', id: "min-booking-notice", exportparts: "tps__number-dropdown: nmbn__number-dropdown, tps__number-dropdown-button: nmbn__number-dropdown-button, tps__number-dropdown-content: nmbn__number-dropdown-content, tps__period-dropdown: nmbn__period-dropdown, tps__period-dropdown-button: nmbn__period-dropdown-button, tps__period-dropdown-content: nmbn__period-dropdown-content", timePeriods: ['minute', 'hour', 'day', 'week'], defaultSelectedNumber: this.selectedNumber, defaultSelectedPeriod: this.selectedPeriod }))));
2376
- }
2377
- static get formAssociated() { return true; }
2378
- get host() { return getElement(this); }
2379
- static get watchers() { return {
2380
- "name": ["elementNameChangedHandler"],
2381
- "selectedConfiguration": ["selectedConfigurationChangedHandler"],
2382
- "availableDaysInFuture": ["availableDaysInFutureChanged"]
2383
- }; }
2384
- };
2385
- __decorate$3([
2386
- RegisterComponent({
2387
- name: 'nylas-min-booking-notice',
2388
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
2389
- eventToProps: {},
2390
- fireRegisterEvent: true,
2391
- }),
2392
- __metadata$3("design:type", Function),
2393
- __metadata$3("design:paramtypes", []),
2394
- __metadata$3("design:returntype", void 0)
2395
- ], NylasMinBookingNotice.prototype, "render", null);
2396
- NylasMinBookingNotice.style = NylasMinBookingNoticeStyle0;
2397
-
2398
- const nylasMinCancellationNoticeCss = ":host{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif}.nylas-min-cancellation-notice{display:flex;justify-content:space-between;font-family:var(--nylas-font-family)}@media screen and (max-width: 768px){.nylas-min-cancellation-notice{flex-direction:column;gap:0.5rem}}.nylas-min-cancellation-notice label{display:flex;align-items:center;color:var(--nylas-base-800);font-size:16px;font-style:normal;font-weight:400;line-height:150%;}.nylas-min-cancellation-notice label span.label-icon{margin-left:4px}.nylas-min-cancellation-notice label span.label-icon tooltip-component{display:flex}select-dropdown::part(sd_dropdown-button){border:none}";
2399
- const NylasMinCancellationNoticeStyle0 = nylasMinCancellationNoticeCss;
2400
-
2401
- var __decorate$2 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
2402
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2403
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
2404
- r = Reflect.decorate(decorators, target, key, desc);
2405
- else
2406
- for (var i = decorators.length - 1; i >= 0; i--)
2407
- if (d = decorators[i])
2408
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2409
- return c > 3 && r && Object.defineProperty(target, key, r), r;
2410
- };
2411
- var __metadata$2 = (undefined && undefined.__metadata) || function (k, v) {
2412
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
2413
- return Reflect.metadata(k, v);
2414
- };
2415
- const NylasMinCancellationNotice = class {
2416
- constructor(hostRef) {
2417
- registerInstance(this, hostRef);
2418
- this.valueChanged = createEvent(this, "valueChanged", 7);
2419
- if (hostRef.$hostElement$["s-ei"]) {
2420
- this.internals = hostRef.$hostElement$["s-ei"];
2421
- }
2422
- else {
2423
- this.internals = hostRef.$hostElement$.attachInternals();
2424
- hostRef.$hostElement$["s-ei"] = this.internals;
2425
- }
2426
- this.selectedConfiguration = undefined;
2427
- this.minCancellationNotice = undefined;
2428
- this.name = 'min-cancellation-notice';
2429
- this.selectedNumber = 1;
2430
- this.selectedPeriod = 'day';
2431
- }
2432
- elementNameChangedHandler(newValue) {
2433
- debug('nylas-min-cancellation-notice', 'elementNameChangedHandler', newValue);
2434
- this.host.setAttribute('name', newValue);
2435
- }
2436
- selectedConfigurationChangedHandler(newVal) {
2437
- const minCancellationNotice = newVal?.scheduler?.min_cancellation_notice;
2438
- if (minCancellationNotice) {
2439
- this.updateNumberAndPeriodFromMinutes(minCancellationNotice);
2440
- }
2441
- }
2442
- availableDaysInFutureChanged(newValue) {
2443
- this.updateNumberAndPeriodFromMinutes(newValue);
2444
- }
2445
- connectedCallback() {
2446
- debug('nylas-min-cancellation-notice', 'connectedCallback');
2447
- }
2448
- componentWillLoad() {
2449
- debug('nylas-min-cancellation-notice', 'componentWillLoad');
2450
- this.host.setAttribute('name', this.name);
2451
- }
2452
- componentDidLoad() {
2453
- debug('nylas-min-cancellation-notice', 'componentDidLoad');
2454
- this.availableDaysInFutureChanged(this.minCancellationNotice ?? 1);
2455
- if (typeof this.internals.setFormValue !== 'function') {
2456
- return;
2457
- }
2458
- this.internals.setFormValue(this.minCancellationNotice?.toString() ?? '1', this.name);
2459
- }
2460
- disconnectedCallback() {
2461
- debug('nylas-min-cancellation-notice', 'disconnectedCallback');
2462
- }
2463
- timePeriodChangedHandler(event) {
2464
- const { number, period } = event.detail;
2465
- let totalMinutes;
2466
- const minutesInHour = 60;
2467
- const minutesInDay = minutesInHour * 24;
2468
- const minutesInWeek = minutesInDay * 7;
2469
- const minutesInMonth = minutesInDay * 30;
2470
- if (period === 'minute') {
2471
- totalMinutes = number;
2472
- }
2473
- else if (period === 'hour') {
2474
- totalMinutes = number * minutesInHour;
2475
- }
2476
- else if (period === 'day') {
2477
- totalMinutes = number * minutesInDay;
2478
- }
2479
- else if (period === 'week') {
2480
- totalMinutes = number * minutesInWeek;
2481
- }
2482
- else if (period === 'month') {
2483
- totalMinutes = number * minutesInMonth;
2484
- }
2485
- else {
2486
- totalMinutes = 0;
2487
- }
2488
- this.valueChanged.emit({ value: totalMinutes, name: 'minCancellationNotice' });
2489
- if (typeof this.internals.setFormValue !== 'function') {
2490
- return;
2491
- }
2492
- this.internals.setFormValue(totalMinutes.toString(), this.name);
2493
- }
2494
- updateNumberAndPeriodFromMinutes(minutes) {
2495
- const minutesInHour = 60;
2496
- const minutesInDay = minutesInHour * 24;
2497
- const minutesInWeek = minutesInDay * 7;
2498
- const minutesInMonth = minutesInDay * 30;
2499
- let number, period;
2500
- if (minutes >= minutesInMonth) {
2501
- number = Math.floor(minutes / minutesInMonth);
2502
- period = 'month';
2503
- }
2504
- else if (minutes >= minutesInWeek) {
2505
- number = Math.floor(minutes / minutesInWeek);
2506
- period = 'week';
2507
- }
2508
- else if (minutes >= minutesInDay) {
2509
- number = Math.floor(minutes / minutesInDay);
2510
- period = 'day';
2511
- }
2512
- else if (minutes >= minutesInHour) {
2513
- number = Math.floor(minutes / minutesInHour);
2514
- period = 'hour';
2515
- }
2516
- else {
2517
- number = minutes;
2518
- period = 'minute';
2519
- }
2520
- this.selectedNumber = number;
2521
- this.selectedPeriod = period;
2522
- }
2523
- render() {
2524
- return (h(Host, { key: '6c14649f767cebe544dd5fc3039e4bace051f759' }, h("div", { key: 'e6b0965bb6bc49b6e7ede7a4c2b2c2056a212c96', class: "nylas-min-cancellation-notice", part: "nmcn" }, h("label", { key: '1998d897f882c0783e2012ca85b651c43517ba64' }, "Minimum cancellation notice", h("span", { key: 'eccae26b18bd269648d1bce2affae5d3e469ea02', class: "label-icon" }, h("tooltip-component", { key: '50caa33903115b0da9da25ed3a18cbbf8a4df353' }, h("info-icon", { key: '8b466b236668439cbca8e250d60524b69ce4f7f3', slot: "tooltip-icon" }), h("span", { key: 'c4c9d73798c85d317aa1f89a2b0f1c66c9ca41d2', slot: "tooltip-content" }, "Set the minimum amount of time required to cancel an event.")))), h("time-period-selector", { key: 'bb4c0a9ecfb9bc9ebf88b229c871abd4b8427385', id: "min-cancellation-notice", exportparts: "tps__number-dropdown: nmcn__number-dropdown, tps__number-dropdown-button: nmcn__number-dropdown-button, tps__number-dropdown-content: nmcn__number-dropdown-content, tps__period-dropdown: nmcn__period-dropdown, tps__period-dropdown-button: nmcn__period-dropdown-button, tps__period-dropdown-content: nmcn__period-dropdown-content", timePeriods: ['minute', 'hour', 'day', 'week'], defaultSelectedNumber: this.selectedNumber, defaultSelectedPeriod: this.selectedPeriod }))));
2525
- }
2526
- static get formAssociated() { return true; }
2527
- get host() { return getElement(this); }
2528
- static get watchers() { return {
2529
- "name": ["elementNameChangedHandler"],
2530
- "selectedConfiguration": ["selectedConfigurationChangedHandler"],
2531
- "availableDaysInFuture": ["availableDaysInFutureChanged"]
2532
- }; }
2533
- };
2534
- __decorate$2([
2535
- RegisterComponent({
2536
- name: 'nylas-min-cancellation-notice',
2537
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
2538
- eventToProps: {},
2539
- fireRegisterEvent: true,
2540
- }),
2541
- __metadata$2("design:type", Function),
2542
- __metadata$2("design:paramtypes", []),
2543
- __metadata$2("design:returntype", void 0)
2544
- ], NylasMinCancellationNotice.prototype, "render", null);
2545
- NylasMinCancellationNotice.style = NylasMinCancellationNoticeStyle0;
2546
-
2547
- const nylasParticipantsCustomAvailabilityCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;width:inherit}.nylas-participants-custom-availability{width:inherit;display:flex;flex-direction:column;margin:1rem;border-radius:var(--nylas-border-radius-2x);border:1px solid var(--nylas-base-200)}.nylas-participants-custom-availability .header{padding:1rem}.nylas-participants-custom-availability .header h3{margin:0;font-size:16px;font-weight:600;line-height:20px;color:var(--nylas-base-900);text-align:left}.nylas-participants-custom-availability .header p{margin:0.25rem 0 0 0;font-size:0.875rem;font-weight:400;line-height:20px;color:var(--nylas-base-600);text-align:left}.nylas-participants-custom-availability .content .participant-container{padding-top:8px;border-top:1px solid var(--nylas-base-200)}.nylas-participants-custom-availability .content .participant-container .participant-title{display:flex;justify-content:space-between;align-items:center;padding:4px 16px 12px}.nylas-participants-custom-availability .content .participant-container .participant-title p{margin:0}.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle{display:flex;gap:24px;align-items:center}.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle .chevron{display:flex;align-self:center;cursor:pointer}.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle .chevron:hover,.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle .chevron:active{color:var(--nylas-primary)}.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle .chevron.open{transform:rotate(90deg)}.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle .chevron.closed{transform:rotate(270deg)}.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle .chevron.disabled{cursor:not-allowed;color:var(--nylas-base-300)}.nylas-participants-custom-availability .content .participant-container .participant-title .participant-toggle .chevron.disabled:hover{color:var(--nylas-base-300)}.nylas-participants-custom-availability .content .participant-container nylas-availability-picker::part(nap){margin:0;border:none}";
2548
- const NylasParticipantsCustomAvailabilityStyle0 = nylasParticipantsCustomAvailabilityCss;
2549
-
2550
- var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
2551
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2552
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
2553
- r = Reflect.decorate(decorators, target, key, desc);
2554
- else
2555
- for (var i = decorators.length - 1; i >= 0; i--)
2556
- if (d = decorators[i])
2557
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2558
- return c > 3 && r && Object.defineProperty(target, key, r), r;
2559
- };
2560
- var __metadata$1 = (undefined && undefined.__metadata) || function (k, v) {
2561
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
2562
- return Reflect.metadata(k, v);
2563
- };
2564
- const NylasParticipantsCustomAvailability = class {
2565
- constructor(hostRef) {
2566
- registerInstance(this, hostRef);
2567
- this.valueChanged = createEvent(this, "valueChanged", 7);
2568
- if (hostRef.$hostElement$["s-ei"]) {
2569
- this.internals = hostRef.$hostElement$["s-ei"];
2570
- }
2571
- else {
2572
- this.internals = hostRef.$hostElement$.attachInternals();
2573
- hostRef.$hostElement$["s-ei"] = this.internals;
2574
- }
2575
- this.name = 'participant-custom-availability';
2576
- this.participants = undefined;
2577
- this.selectedParticipants = this.setParticipants(this.participants);
2578
- }
2579
- elementNameChangedHandler(newValue) {
2580
- debug('nylas-participants-custom-availability', 'elementNameChangedHandler', newValue);
2581
- this.host.setAttribute('name', newValue);
2582
- }
2583
- participantsChangedHandler(newValue) {
2584
- debug('nylas-participants-custom-availability', 'participantsChangedHandler', newValue);
2585
- this.selectedParticipants = this.setParticipants(newValue);
2586
- }
2587
- connectedCallback() {
2588
- debug('nylas-participants-custom-availability', 'connectedCallback');
2589
- }
2590
- disconnectedCallback() {
2591
- debug('nylas-participants-custom-availability', 'disconnectedCallback');
2592
- }
2593
- componentWillLoad() {
2594
- debug('nylas-participants-custom-availability', 'componentWillLoad');
2595
- }
2596
- componentDidLoad() {
2597
- debug('nylas-participants-custom-availability', 'componentDidLoad');
2598
- }
2599
- nylasFormSwitchToggledHandler(event) {
2600
- debug('nylas-participants-custom-availability', 'nylasFormSwitchToggledHandler', event.detail);
2601
- this.selectedParticipants[event.detail.name]['isOpen'] = event.detail.checked;
2602
- this.selectedParticipants[event.detail.name]['setCustom'] = event.detail.checked;
2603
- this.selectedParticipants = { ...this.selectedParticipants };
2604
- }
2605
- handleValueChanged(event) {
2606
- debug('[nylas-editor-tabs]', 'handleValueChanged', event);
2607
- const { name, value } = event.detail;
2608
- if (!name.startsWith('participant-')) {
2609
- return;
2610
- }
2611
- if (!this.participantFormRef.checkValidity()) {
2612
- this.internals.setValidity({ customError: true }, 'Please fix the overlapping time ranges.');
2613
- return;
2614
- }
2615
- else {
2616
- this.internals.setValidity({});
2617
- }
2618
- const jsonValue = JSON.parse(value);
2619
- const key = name.split('-')[2];
2620
- if (!this.selectedParticipants[key])
2621
- return;
2622
- this.selectedParticipants[key]['openHours'] = jsonValue.openHours;
2623
- this.selectedParticipants = { ...this.selectedParticipants };
2624
- const participantOpenHours = {};
2625
- this.participants.forEach(participant => {
2626
- participantOpenHours[participant.email] = this.selectedParticipants[participant.email].openHours;
2627
- });
2628
- this.internals.setFormValue(JSON.stringify(participantOpenHours), this.name);
2629
- this.valueChanged.emit({ value: JSON.stringify(participantOpenHours), name: this.name });
2630
- }
2631
- setParticipants(participants) {
2632
- const selectedParticipants = {};
2633
- participants.forEach(participant => {
2634
- const isOpen = participant.is_organizer ? true : false;
2635
- selectedParticipants[participant.email] = {
2636
- isOpen: isOpen,
2637
- setCustom: !!participant.availability?.open_hours ? true : false,
2638
- openHours: participant.availability?.open_hours || [],
2639
- name: participant.name || participant.email,
2640
- availability: participant.availability,
2641
- };
2642
- });
2643
- return selectedParticipants;
2644
- }
2645
- render() {
2646
- return (h(Host, { key: '051df44e8bf6bab14cfbccb0a3c5f920993cbae9' }, h("div", { key: '128d044cb2bbee76d695d6f5d4bc38a211d06360', class: "nylas-participants-custom-availability", part: "npca" }, h("div", { key: 'ed326c442f9663b0613e5cf62a31aabf5fa1034d', class: "header", part: "npca__header" }, h("h3", { key: '10994aace54d17110ab2e70fc82a5c11231b5a23' }, "Set Custom Availability for Participants"), h("p", { key: '6df3bc37aec02f5a4468f6c6515c6de2c696e817' }, "Set custom availability for scheduling meetings, or default to general availability.")), h("div", { key: 'e1e67385b15430e8a7eb6d8411f9b87742621969', class: "content", part: "npca__content" }, h("form", { key: '589df249c050b132dc8da5b3ef7e58fa829ae300', ref: el => (this.participantFormRef = el) }, Object.keys(this.selectedParticipants).map((key, index) => {
2647
- const participant = this.selectedParticipants[key];
2648
- if (!participant || !participant.name || !participant.availability)
2649
- return;
2650
- return (h("div", { class: "participant-container", part: "npca__participant-container", key: `participant-conatiner-${index}` }, h("div", { class: "participant-title", part: "npca__participant-title" }, h("p", null, "Set ", participant.name, "'s custom availability"), h("div", { class: "participant-toggle", part: "npca__participant-toggle--container" }, h("toggle-switch", { exportparts: "ts_label: npca__toggle-label, ts_input: npca_toggle-input, ts_slider: npca_toggle-slider", name: key, checked: !!participant.openHours && participant.openHours.length > 0 }), h("span", { class: `chevron ${participant.isOpen ? 'open' : 'closed'} ${participant.setCustom ? '' : 'disabled'}`, onClick: () => {
2651
- if (!participant.setCustom)
2652
- return;
2653
- this.selectedParticipants[key].isOpen = !participant.isOpen;
2654
- this.selectedParticipants = { ...this.selectedParticipants };
2655
- } }, h("chevron-icon", { width: "24", height: "24" })))), participant.isOpen && (h("nylas-availability-picker", { key: index, name: `participant-${index}-${key}`, openHours: participant.openHours, defaultTimezone: participant.openHours?.[0]?.timezone, hideHeader: true }))));
2656
- }))))));
2657
- }
2658
- static get formAssociated() { return true; }
2659
- get host() { return getElement(this); }
2660
- static get watchers() { return {
2661
- "name": ["elementNameChangedHandler"],
2662
- "participants": ["participantsChangedHandler"]
2663
- }; }
2664
- };
2665
- __decorate$1([
2666
- RegisterComponent({
2667
- name: 'nylas-participants-custom-availability',
2668
- eventToProps: {},
2669
- fireRegisterEvent: true,
2670
- }),
2671
- __metadata$1("design:type", Function),
2672
- __metadata$1("design:paramtypes", []),
2673
- __metadata$1("design:returntype", void 0)
2674
- ], NylasParticipantsCustomAvailability.prototype, "render", null);
2675
- NylasParticipantsCustomAvailability.style = NylasParticipantsCustomAvailabilityStyle0;
2676
-
2677
- const nylasTimeslotIntervalCss = ":host{display:block;--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;width:inherit}.nylas-timeslot-interval{width:inherit;display:flex;flex-direction:column;margin:1rem;border-radius:var(--nylas-border-radius-2x);border:1px solid var(--nylas-base-200)}.nylas-timeslot-interval .header{padding:1rem;border-bottom:1px solid var(--nylas-base-200)}.nylas-timeslot-interval .header h3{margin:0;font-size:1rem;font-weight:600;line-height:20px;color:var(--nylas-base-900);text-align:left}.nylas-timeslot-interval .header p{margin:0.25rem 0 0 0;font-size:0.875rem;font-weight:400;line-height:20px;color:var(--nylas-base-600);text-align:left}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown{padding:1rem;display:flex;flex-direction:column;gap:4px}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown span.label{display:flex;align-items:center;gap:4px;color:var(--nylas-base-800)}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown span.label tooltip-component{display:flex}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown select-dropdown{margin-bottom:1.5rem}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown select-dropdown::part(sd_dropdown){width:100%}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown select-dropdown::part(sd_dropdown-content){width:100%;max-width:unset}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown select-dropdown::part(sd_dropdown-button){width:100%;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--nylas-base-200);border-radius:var(--nylas-border-radius-2x);padding:1rem}.nylas-timeslot-interval .nylas-timeslot-interval__dropdown select-dropdown::part(sd_dropdown-button-selected-label){max-width:calc(100% - 2rem);font-family:var(--nylas-font-family);font-size:16px;line-height:24px}";
2678
- const NylasTimeslotIntervalStyle0 = nylasTimeslotIntervalCss;
2679
-
2680
- var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
2681
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
2682
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
2683
- r = Reflect.decorate(decorators, target, key, desc);
2684
- else
2685
- for (var i = decorators.length - 1; i >= 0; i--)
2686
- if (d = decorators[i])
2687
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2688
- return c > 3 && r && Object.defineProperty(target, key, r), r;
2689
- };
2690
- var __metadata = (undefined && undefined.__metadata) || function (k, v) {
2691
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function")
2692
- return Reflect.metadata(k, v);
2693
- };
2694
- const defaultRoundToMinustes = 15;
2695
- const NylasTimeslotInterval = class {
2696
- constructor(hostRef) {
2697
- registerInstance(this, hostRef);
2698
- this.valueChanged = createEvent(this, "valueChanged", 7);
2699
- if (hostRef.$hostElement$["s-ei"]) {
2700
- this.internals = hostRef.$hostElement$["s-ei"];
2701
- }
2702
- else {
2703
- this.internals = hostRef.$hostElement$.attachInternals();
2704
- hostRef.$hostElement$["s-ei"] = this.internals;
2705
- }
2706
- this.selectedConfiguration = undefined;
2707
- this.name = 'timeslot-picker';
2708
- this.eventDurationMinutes = this.selectedConfiguration?.availability?.duration_minutes ?? 5;
2709
- this.defaultIntervalMinutes = this.selectedConfiguration?.availability?.interval_minutes ?? this.eventDurationMinutes;
2710
- this.defaultRoundTo = this.selectedConfiguration?.availability?.round_to ?? undefined;
2711
- this.selectedInterval = this.defaultIntervalMinutes;
2712
- this.selectedRoundTo = this.defaultRoundTo && this.defaultRoundTo === this.defaultIntervalMinutes ? true : false;
2713
- }
2714
- elementNameChangedHandler(newValue) {
2715
- debug('nylas-timeslot-interval', 'elementNameChangedHandler', newValue);
2716
- this.host.setAttribute('name', newValue);
2717
- }
2718
- selectedConfigurationChangedHandler(newValue) {
2719
- debug('nylas-timeslot-interval', 'selectedConfigurationChangedHandler', newValue);
2720
- this.defaultIntervalMinutes = newValue.availability?.interval_minutes ?? this.eventDurationMinutes;
2721
- this.defaultRoundTo = newValue.availability?.round_to ?? undefined;
2722
- this.selectedInterval = this.defaultIntervalMinutes;
2723
- this.selectedRoundTo = this.defaultRoundTo && this.defaultRoundTo === this.defaultIntervalMinutes ? true : false;
2724
- }
2725
- connectedCallback() {
2726
- debug('nylas-timeslot-interval', 'connectedCallback');
2727
- }
2728
- disconnectedCallback() {
2729
- debug('nylas-timeslot-interval', 'disconnectedCallback');
2730
- }
2731
- componentWillLoad() {
2732
- debug('nylas-timeslot-interval', 'componentWillLoad');
2733
- this.host.setAttribute('name', this.name);
2734
- }
2735
- componentDidLoad() {
2736
- debug('nylas-timeslot-interval', 'componentDidLoad');
2737
- }
2738
- componentWillUpdate() {
2739
- debug('nylas-timeslot-interval', 'componentWillUpdate');
2740
- }
2741
- componentDidUpdate() {
2742
- debug('nylas-timeslot-interval', 'componentDidUpdate');
2743
- }
2744
- componentWillRender() {
2745
- debug('nylas-timeslot-interval', 'componentWillRender');
2746
- }
2747
- componentDidRender() {
2748
- debug('nylas-timeslot-interval', 'componentDidRender');
2749
- }
2750
- nylasFormDropdownChangedHandler(event) {
2751
- debug('nylas-timeslot-interval', 'nylasFormDropdownChangedHandler', event.detail);
2752
- const value = event.detail.value;
2753
- if (value === 'duration') {
2754
- this.selectedInterval = this.eventDurationMinutes;
2755
- }
2756
- else {
2757
- this.selectedInterval = parseInt(event.detail.value);
2758
- }
2759
- console.log('nylasFormDropdownChanged selectedRoundTo', this.selectedRoundTo);
2760
- this.valueChanged.emit({
2761
- value: JSON.stringify({
2762
- interval: this.selectedInterval,
2763
- roundTo: this.selectedRoundTo ? this.selectedInterval : defaultRoundToMinustes,
2764
- }),
2765
- name: this.name,
2766
- });
2767
- if (typeof this.internals.setFormValue === 'function') {
2768
- this.internals.setFormValue(JSON.stringify({ interval: this.selectedInterval, roundTo: this.selectedRoundTo ? this.selectedInterval : defaultRoundToMinustes }), this.name);
2769
- }
2770
- }
2771
- radioSelectionChangedHandler(event) {
2772
- debug('nylas-timeslot-interval', 'radioSelectionChangedHandler', event.detail);
2773
- const value = event.detail.value;
2774
- if (value === 'no-rounding') {
2775
- this.selectedRoundTo = false;
2776
- }
2777
- else {
2778
- this.selectedRoundTo = true;
2779
- }
2780
- console.log('selectedRoundTo', this.selectedRoundTo);
2781
- this.valueChanged.emit({
2782
- value: JSON.stringify({
2783
- interval: this.selectedInterval,
2784
- roundTo: this.selectedRoundTo ? this.selectedInterval : defaultRoundToMinustes,
2785
- }),
2786
- name: this.name,
2787
- });
2788
- if (typeof this.internals.setFormValue === 'function') {
2789
- this.internals.setFormValue(JSON.stringify({ interval: this.selectedInterval, roundTo: this.selectedRoundTo ? this.selectedInterval : defaultRoundToMinustes }), this.name);
2790
- }
2791
- }
2792
- render() {
2793
- const intervalPreferenceOptions = [
2794
- { value: 'duration', label: 'Length of the booking' },
2795
- { value: '5', label: '5 mins' },
2796
- { value: '10', label: '10 mins' },
2797
- { value: '15', label: '15 mins' },
2798
- { value: '20', label: '20 mins' },
2799
- { value: '30', label: '30 mins' },
2800
- { value: '45', label: '45 mins' },
2801
- { value: '60', label: '60 mins' },
2802
- ];
2803
- return (h(Host, { key: 'ebad4dc8f82dc565f4608c262d54f06495a69144' }, h("div", { key: '46641f5cd23afc527d14c57fa62fe2627d1a92f5', class: "nylas-timeslot-interval", part: "nti" }, h("div", { key: '729c8356b955ba357bd00f3cdf28c51bb42b741d', class: "header", part: "nti__header" }, h("h3", { key: '348543e170e107ea65c74a6154739627e7c4a271' }, "Time-slot interval preferences"), h("p", { key: '1cf34b79990edef1950d6c970932e5e0805e6d0a' }, "Choose your interval preference for time-slots.")), h("div", { key: '965fe8f8e235f9696bc237bc7774ca6fdea2cd42', class: "nylas-timeslot-interval__dropdown" }, h("span", { key: '6346e2f31c9322cc3264885f362ce2b29c4a4c2e', class: "label", part: "nti__input-label" }, "Select interval preference", h("tooltip-component", { key: '27901960cae97d4809153aac5d427c8c2ff7bf1e' }, h("info-icon", { key: '94c81d2c169da3714d2a1955da0fbe542b688fb6', slot: "tooltip-icon" }), h("span", { key: '6e8660e7696c16d81214d97e5e2087579f9fa1bd', slot: "tooltip-content" }, "Set the interval preference for the time-slots."))), h("select-dropdown", { key: '49b886894bb4d405ed13578809609511830389f1', name: "booking-calendar", options: intervalPreferenceOptions, withSearch: false, exportparts: "sd_dropdown: nti__dropdown, sd_dropdown-button: nti__dropdown-button, sd_dropdown-content: nti__dropdown-content", defaultSelectedOption: this.defaultIntervalMinutes == this.eventDurationMinutes
2804
- ? intervalPreferenceOptions[0]
2805
- : intervalPreferenceOptions.find(op => op.value == this.defaultIntervalMinutes.toString()) ?? intervalPreferenceOptions[0] }), h("span", { key: '40079758106c1e7075b247f81a3bc30e11eb1138', class: "label", part: "nti__input-label" }, "Select the type of time-slot rounding", h("tooltip-component", { key: 'c1a1b86a732439b5474be36a1eb67d0a1fabe52c' }, h("info-icon", { key: '9e185781f8def48475c5f65cff916e5be6423b72', slot: "tooltip-icon" }), h("span", { key: 'df108083daab268e8980194ebff8485c945aab1c', slot: "tooltip-content" }, "Select if you want to round the time slots to the nearest interval."))), h("radio-button-group", { key: 'eb4c58b028ac0e2dd0468c30c1839558ae57178a', name: "interval-preference", defaultSelectedValue: this.defaultRoundTo && this.defaultRoundTo === this.defaultIntervalMinutes ? 'rounding' : 'no-rounding', options: [
2806
- { value: 'no-rounding', label: 'Default', description: 'Time-slots will be rounded to the nearest quarter-hour.' },
2807
- {
2808
- value: 'rounding',
2809
- label: 'Interval rounding',
2810
- description: 'Time-slots will begin at times rounded to the interval value.',
2811
- },
2812
- ] })))));
2813
- }
2814
- static get formAssociated() { return true; }
2815
- get host() { return getElement(this); }
2816
- static get watchers() { return {
2817
- "name": ["elementNameChangedHandler"],
2818
- "selectedConfiguration": ["selectedConfigurationChangedHandler"]
2819
- }; }
2820
- };
2821
- __decorate([
2822
- RegisterComponent({
2823
- name: 'nylas-timeslot-interval',
2824
- stateToProps: new Map([['schedulerConfig.selectedConfiguration', 'selectedConfiguration']]),
2825
- fireRegisterEvent: true,
2826
- }),
2827
- __metadata("design:type", Function),
2828
- __metadata("design:paramtypes", []),
2829
- __metadata("design:returntype", void 0)
2830
- ], NylasTimeslotInterval.prototype, "render", null);
2831
- NylasTimeslotInterval.style = NylasTimeslotIntervalStyle0;
2832
-
2833
- const iconCss = ".sc-people-icon-h{display:flex}";
2834
- const PeopleIconStyle0 = iconCss;
2835
-
2836
- const PeopleIcon = class {
2837
- constructor(hostRef) {
2838
- registerInstance(this, hostRef);
2839
- this.width = '20';
2840
- this.height = '20';
2841
- }
2842
- render() {
2843
- return (h("svg", { key: '4a54f616162baf613895348e27cafd2088f5fd16', xmlns: "http://www.w3.org/2000/svg", width: this.width, height: this.height, fill: "none", viewBox: "0 0 20 20" }, h("path", { key: '80e1ca7240235b635a08369ba836e727825b7be4', fill: "currentColor", d: "M11 10a2 2 0 0 1 2 2v1.5c0 2.054-2.088 3.5-5.5 3.5S2 15.554 2 13.5V12a2 2 0 0 1 2-2h7Zm0 1H4a1 1 0 0 0-1 1v1.5C3 14.907 4.579 16 7.5 16c2.921 0 4.5-1.093 4.5-2.5V12a1 1 0 0 0-1-1Zm5-1a2 2 0 0 1 2 2v.5c0 2.089-1.568 3.5-4.5 3.5-.141 0-.28-.003-.414-.01.208-.242.382-.502.522-.781l.097-.213h.039C15.976 14.931 17 13.96 17 12.5V12a1 1 0 0 0-1-1h-2.171a3 3 0 0 0-.594-1H16ZM7.5 2a3.5 3.5 0 1 1 0 7 3.5 3.5 0 0 1 0-7Zm7 2a2.5 2.5 0 1 1 0 5 2.5 2.5 0 0 1 0-5Zm-7-1a2.5 2.5 0 1 0 0 5 2.5 2.5 0 0 0 0-5Zm7 2a1.5 1.5 0 1 0 0 3 1.5 1.5 0 0 0 0-3Z" })));
2844
- }
2845
- };
2846
- PeopleIcon.style = PeopleIconStyle0;
2847
-
2848
- const radioButtonGroupCss = ".radio-group{display:flex;flex-direction:column}.radio-group label{display:flex;font-family:var(--nylas-font-family);cursor:pointer}.radio-group label .radio-option{display:flex;align-items:flex-start;gap:0.5rem}.radio-group label .radio-option input[type=radio]{cursor:pointer}.radio-group label .radio-option input[type=radio i]{width:20px;height:20px;color:var(--nylas-primary);margin-top:16px}.radio-group label .radio-option p{display:flex;flex-direction:column;gap:0.5rem}.radio-group label .radio-option p .title{font-size:16px;font-weight:500;line-height:20px;color:var(--nylas-base-800)}.radio-group label .radio-option p .description{font-size:14px;font-weight:400;line-height:20px;color:var(--nylas-base-600)}";
2849
- const RadioButtonGroupStyle0 = radioButtonGroupCss;
2850
-
2851
- const RadioButtonGroup = class {
2852
- constructor(hostRef) {
2853
- registerInstance(this, hostRef);
2854
- this.radioSelectionChanged = createEvent(this, "radioSelectionChanged", 7);
2855
- this.name = 'radio-group';
2856
- this.options = [];
2857
- this.defaultSelectedValue = '';
2858
- this.selectedValue = this.defaultSelectedValue;
2859
- }
2860
- handleChange(value) {
2861
- this.selectedValue = value;
2862
- this.radioSelectionChanged.emit({
2863
- value,
2864
- name: this.name,
2865
- });
2866
- }
2867
- render() {
2868
- return (h("div", { key: '82c0a38507193f6e941c820c38f9e5c477dc14dc', class: "radio-group" }, this.options.map(option => (h("label", null, h("div", { class: "radio-option" }, h("input", { type: "radio", name: this.name, value: option.value, checked: this.selectedValue === option.value, onChange: () => this.handleChange(option.value) }), h("p", null, h("span", { class: "title" }, option.label), h("span", { class: "description" }, option.description))))))));
2869
- }
2870
- };
2871
- RadioButtonGroup.style = RadioButtonGroupStyle0;
2872
-
2873
- const toggleSwitchCss = ".switch{--nylas-primary:#2563eb;--nylas-error:#cc4841;--nylas-error-pressed:#992222;--nylas-wraning:#f06c00;--nylas-success:#16a392;--nylas-info:#2b8fc2;--nylas-base-0:#ffffff;--nylas-base-25:#fcfcfd;--nylas-base-50:#f8f9fc;--nylas-base-100:#eaecf5;--nylas-base-200:#d5d9eb;--nylas-base-300:#b3b8d8;--nylas-base-400:#717bbc;--nylas-base-500:#4e5ba6;--nylas-base-600:#3e4784;--nylas-base-700:#263f72;--nylas-base-800:#293056;--nylas-base-900:#101323;--nylas-base-950:#0e101b;--nylas-border-radius:0.25rem;--nylas-border-radius-2x:0.5rem;--nylas-border-radius-3x:0.75rem;--nylas-font-family:\"Inter\", sans-serif;display:inline-block;height:34px;position:relative;width:60px}.switch input{display:none}.slider{background-color:var(--nylas-base-400);bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:0.4s}.slider:before{background-color:var(--nylas-base-0);bottom:4px;content:\"\";height:32px;left:4px;position:absolute;transition:0.4s;width:32px}input:checked+.slider{background-color:var(--nylas-success)}input:checked+.slider:before{transform:translateX(32px)}.slider.round{border-radius:35px;width:72px;height:40px}.slider.round:before{border-radius:50%}";
2874
- const ToggleSwitchStyle0 = toggleSwitchCss;
2875
-
2876
- const ToggleSwitchComponent = class {
2877
- constructor(hostRef) {
2878
- registerInstance(this, hostRef);
2879
- this.nylasFormSwitchToggled = createEvent(this, "nylasFormSwitchToggled", 7);
2880
- this.name = 'toggle-switch';
2881
- this.checked = false;
2882
- this.label = '';
2883
- this.isChecked = this.checked;
2884
- }
2885
- componentWillLoad() {
2886
- this.isChecked = this.checked;
2887
- }
2888
- toggleCheck() {
2889
- this.isChecked = !this.isChecked;
2890
- this.nylasFormSwitchToggled.emit({
2891
- checked: this.isChecked,
2892
- name: this.name,
2893
- label: this.label,
2894
- });
2895
- }
2896
- render() {
2897
- return (h("label", { key: 'a0da5f3c6cac6310e9368ec4a5ed737decd04b5b', class: "switch", part: "ts_label" }, h("input", { key: '89e844d8135eadd471b960910794143ab1699afb', type: "checkbox", part: "ts_input", name: this.name, checked: this.isChecked, onChange: () => this.toggleCheck() }), h("div", { key: '19e8cea0befc42520c775555c8de96ac83d1612d', class: "slider round", part: "ts_slider" })));
2898
- }
2899
- };
2900
- ToggleSwitchComponent.style = ToggleSwitchStyle0;
2901
-
2902
- export { CalendarInfoIcon as calendar_info_icon, CalendarPatternsIcon as calendar_patterns_icon, CheckboxComponent as checkbox_component, FlowIcon as flow_icon, LocationIcon as location_icon, LocationOffIcon as location_off_icon, MultiSelectDropdown as multi_select_dropdown, NylasAdditionalParticipants as nylas_additional_participants, NylasAvailabilityPicker as nylas_availability_picker, NylasBookingCalendarPicker as nylas_booking_calendar_picker, NylasBufferTime as nylas_buffer_time, NylasCalendarPicker as nylas_calendar_picker, NylasCancellationPolicy as nylas_cancellation_policy, NylasCustomizeBookingSettings as nylas_customize_booking_settings, NylasEventDescription as nylas_event_description, NylasEventDuration as nylas_event_duration, NylasEventInfo as nylas_event_info, NylasEventLimits as nylas_event_limits, NylasEventLocation as nylas_event_location, NylasEventTitle as nylas_event_title, NylasLimitFutureBookings as nylas_limit_future_bookings, NylasMinBookingNotice as nylas_min_booking_notice, NylasMinCancellationNotice as nylas_min_cancellation_notice, NylasParticipantsCustomAvailability as nylas_participants_custom_availability, NylasTimeslotInterval as nylas_timeslot_interval, PeopleIcon as people_icon, RadioButtonGroup as radio_button_group, ToggleSwitchComponent as toggle_switch };
2903
-
2904
- //# sourceMappingURL=calendar-info-icon_28.entry.js.map