@sneat/extensions-schedulus-shared 0.3.0

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 (194) hide show
  1. package/esm2022/index.js +2 -0
  2. package/esm2022/index.js.map +1 -0
  3. package/esm2022/lib/components/calendar/calendar-base.component.js +83 -0
  4. package/esm2022/lib/components/calendar/calendar-base.component.js.map +1 -0
  5. package/esm2022/lib/components/calendar/calendar-brief.component.js +57 -0
  6. package/esm2022/lib/components/calendar/calendar-brief.component.js.map +1 -0
  7. package/esm2022/lib/components/calendar/calendar-component-types.js +2 -0
  8. package/esm2022/lib/components/calendar/calendar-component-types.js.map +1 -0
  9. package/esm2022/lib/components/calendar/calendar-state.service.js +90 -0
  10. package/esm2022/lib/components/calendar/calendar-state.service.js.map +1 -0
  11. package/esm2022/lib/components/calendar/calendar.component.js +284 -0
  12. package/esm2022/lib/components/calendar/calendar.component.js.map +1 -0
  13. package/esm2022/lib/components/calendar/components/calendar-add-buttons/calendar-add-buttons.component.js +45 -0
  14. package/esm2022/lib/components/calendar/components/calendar-add-buttons/calendar-add-buttons.component.js.map +1 -0
  15. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-base.component.js +26 -0
  16. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-base.component.js.map +1 -0
  17. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-card.component.js +67 -0
  18. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-card.component.js.map +1 -0
  19. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-tab.component.js +74 -0
  20. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-tab.component.js.map +1 -0
  21. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-title.component.js +27 -0
  22. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-title.component.js.map +1 -0
  23. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day.component.js +129 -0
  24. package/esm2022/lib/components/calendar/components/calendar-day/calendar-day.component.js.map +1 -0
  25. package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.component.js +162 -0
  26. package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.component.js.map +1 -0
  27. package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.js +17 -0
  28. package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.js.map +1 -0
  29. package/esm2022/lib/components/calendar/components/calendar-filter/contacts-filter.component.js +95 -0
  30. package/esm2022/lib/components/calendar/components/calendar-filter/contacts-filter.component.js.map +1 -0
  31. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-card.component.js +50 -0
  32. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-card.component.js.map +1 -0
  33. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-tab.component.js +18 -0
  34. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-tab.component.js.map +1 -0
  35. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-title.component.js +15 -0
  36. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-title.component.js.map +1 -0
  37. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week.component.js +78 -0
  38. package/esm2022/lib/components/calendar/components/calendar-week/calendar-week.component.js.map +1 -0
  39. package/esm2022/lib/components/calendar/components/calendar-weekday/calendar-weekday.component.js +66 -0
  40. package/esm2022/lib/components/calendar/components/calendar-weekday/calendar-weekday.component.js.map +1 -0
  41. package/esm2022/lib/components/calendar/components/day-slot-item/day-slot-item.component.js +93 -0
  42. package/esm2022/lib/components/calendar/components/day-slot-item/day-slot-item.component.js.map +1 -0
  43. package/esm2022/lib/components/calendar/components/day-slot-item/slot-context-menu.component.js +324 -0
  44. package/esm2022/lib/components/calendar/components/day-slot-item/slot-context-menu.component.js.map +1 -0
  45. package/esm2022/lib/components/calendar/components/recurrings-tab/recurrings-tab.component.js +36 -0
  46. package/esm2022/lib/components/calendar/components/recurrings-tab/recurrings-tab.component.js.map +1 -0
  47. package/esm2022/lib/components/calendar/components/singles-tab/single-happenings-list.component.js +65 -0
  48. package/esm2022/lib/components/calendar/components/singles-tab/single-happenings-list.component.js.map +1 -0
  49. package/esm2022/lib/components/calendar/components/singles-tab/singles-tab.component.js +106 -0
  50. package/esm2022/lib/components/calendar/components/singles-tab/singles-tab.component.js.map +1 -0
  51. package/esm2022/lib/components/calendar/components/timing-badge/timing-badge.component.js +25 -0
  52. package/esm2022/lib/components/calendar/components/timing-badge/timing-badge.component.js.map +1 -0
  53. package/esm2022/lib/components/calendar/weekday.js +2 -0
  54. package/esm2022/lib/components/calendar/weekday.js.map +1 -0
  55. package/esm2022/lib/components/calendar-core.js +64 -0
  56. package/esm2022/lib/components/calendar-core.js.map +1 -0
  57. package/esm2022/lib/components/calendar-filter.service.js +28 -0
  58. package/esm2022/lib/components/calendar-filter.service.js.map +1 -0
  59. package/esm2022/lib/components/calendar-slots.js +30 -0
  60. package/esm2022/lib/components/calendar-slots.js.map +1 -0
  61. package/esm2022/lib/components/happening-base.component.js +188 -0
  62. package/esm2022/lib/components/happening-base.component.js.map +1 -0
  63. package/esm2022/lib/components/happening-card/happening-card.component.js +69 -0
  64. package/esm2022/lib/components/happening-card/happening-card.component.js.map +1 -0
  65. package/esm2022/lib/components/happening-component-base-params.js +37 -0
  66. package/esm2022/lib/components/happening-component-base-params.js.map +1 -0
  67. package/esm2022/lib/components/happening-form/happening-form.component.js +348 -0
  68. package/esm2022/lib/components/happening-form/happening-form.component.js.map +1 -0
  69. package/esm2022/lib/components/happening-form/happening-price-form/happening-price-modal.component.js +161 -0
  70. package/esm2022/lib/components/happening-form/happening-price-form/happening-price-modal.component.js.map +1 -0
  71. package/esm2022/lib/components/happening-form/happening-prices/happening-prices.component.js +142 -0
  72. package/esm2022/lib/components/happening-form/happening-prices/happening-prices.component.js.map +1 -0
  73. package/esm2022/lib/components/happening-participants/happening-participants.component.js +195 -0
  74. package/esm2022/lib/components/happening-participants/happening-participants.component.js.map +1 -0
  75. package/esm2022/lib/components/happening-slot-form/happening-slot-form.component.js +505 -0
  76. package/esm2022/lib/components/happening-slot-form/happening-slot-form.component.js.map +1 -0
  77. package/esm2022/lib/components/happening-slot-form/happening-slot-modal.component.js +140 -0
  78. package/esm2022/lib/components/happening-slot-form/happening-slot-modal.component.js.map +1 -0
  79. package/esm2022/lib/components/happening-slot-form/happening-slot-modal.service.js +47 -0
  80. package/esm2022/lib/components/happening-slot-form/happening-slot-modal.service.js.map +1 -0
  81. package/esm2022/lib/components/happening-slot-participants/happening-slot-participants.component.js +74 -0
  82. package/esm2022/lib/components/happening-slot-participants/happening-slot-participants.component.js.map +1 -0
  83. package/esm2022/lib/components/happening-slots/happening-slots.component.js +130 -0
  84. package/esm2022/lib/components/happening-slots/happening-slots.component.js.map +1 -0
  85. package/esm2022/lib/components/index.js +20 -0
  86. package/esm2022/lib/components/index.js.map +1 -0
  87. package/esm2022/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.js +68 -0
  88. package/esm2022/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.js.map +1 -0
  89. package/esm2022/lib/components/start-end-datetime-form/start-end-datetime-form.component.js +377 -0
  90. package/esm2022/lib/components/start-end-datetime-form/start-end-datetime-form.component.js.map +1 -0
  91. package/esm2022/lib/components/start-end-datetime-form/time-selector.component.js +92 -0
  92. package/esm2022/lib/components/start-end-datetime-form/time-selector.component.js.map +1 -0
  93. package/esm2022/lib/components/swipeable-base.component.js +112 -0
  94. package/esm2022/lib/components/swipeable-base.component.js.map +1 -0
  95. package/esm2022/lib/components/swipeable-ui.js +64 -0
  96. package/esm2022/lib/components/swipeable-ui.js.map +1 -0
  97. package/esm2022/lib/components/week.js +2 -0
  98. package/esm2022/lib/components/week.js.map +1 -0
  99. package/esm2022/lib/components/weekday-functions.js +13 -0
  100. package/esm2022/lib/components/weekday-functions.js.map +1 -0
  101. package/esm2022/lib/components/weekdays/weekdays-form-base.js +72 -0
  102. package/esm2022/lib/components/weekdays/weekdays-form-base.js.map +1 -0
  103. package/esm2022/lib/index.js +3 -0
  104. package/esm2022/lib/index.js.map +1 -0
  105. package/esm2022/lib/modals/happening-title-modal/happening-title-modal.component.js +87 -0
  106. package/esm2022/lib/modals/happening-title-modal/happening-title-modal.component.js.map +1 -0
  107. package/esm2022/lib/services/calendar-data-provider.js +271 -0
  108. package/esm2022/lib/services/calendar-data-provider.js.map +1 -0
  109. package/esm2022/lib/services/calendar-day.js +179 -0
  110. package/esm2022/lib/services/calendar-day.js.map +1 -0
  111. package/esm2022/lib/services/calendar-day.service.js +37 -0
  112. package/esm2022/lib/services/calendar-day.service.js.map +1 -0
  113. package/esm2022/lib/services/calendar-nav.service.js +36 -0
  114. package/esm2022/lib/services/calendar-nav.service.js.map +1 -0
  115. package/esm2022/lib/services/calendar-space.js +152 -0
  116. package/esm2022/lib/services/calendar-space.js.map +1 -0
  117. package/esm2022/lib/services/calendar-types.js +52 -0
  118. package/esm2022/lib/services/calendar-types.js.map +1 -0
  119. package/esm2022/lib/services/calendarium-services.module.js +16 -0
  120. package/esm2022/lib/services/calendarium-services.module.js.map +1 -0
  121. package/esm2022/lib/services/calendarium-space.service.js +16 -0
  122. package/esm2022/lib/services/calendarium-space.service.js.map +1 -0
  123. package/esm2022/lib/services/happening.service.js +225 -0
  124. package/esm2022/lib/services/happening.service.js.map +1 -0
  125. package/esm2022/lib/services/index.js +6 -0
  126. package/esm2022/lib/services/index.js.map +1 -0
  127. package/esm2022/sneat-extensions-schedulus-shared.js +5 -0
  128. package/esm2022/sneat-extensions-schedulus-shared.js.map +1 -0
  129. package/index.d.ts +1 -0
  130. package/lib/components/calendar/calendar-base.component.d.ts +23 -0
  131. package/lib/components/calendar/calendar-brief.component.d.ts +11 -0
  132. package/lib/components/calendar/calendar-component-types.d.ts +1 -0
  133. package/lib/components/calendar/calendar-state.service.d.ts +15 -0
  134. package/lib/components/calendar/calendar.component.d.ts +32 -0
  135. package/lib/components/calendar/components/calendar-add-buttons/calendar-add-buttons.component.d.ts +13 -0
  136. package/lib/components/calendar/components/calendar-day/calendar-day-base.component.d.ts +10 -0
  137. package/lib/components/calendar/components/calendar-day/calendar-day-card.component.d.ts +17 -0
  138. package/lib/components/calendar/components/calendar-day/calendar-day-tab.component.d.ts +19 -0
  139. package/lib/components/calendar/components/calendar-day/calendar-day-title.component.d.ts +10 -0
  140. package/lib/components/calendar/components/calendar-day/calendar-day.component.d.ts +30 -0
  141. package/lib/components/calendar/components/calendar-filter/calendar-filter.component.d.ts +39 -0
  142. package/lib/components/calendar/components/calendar-filter/calendar-filter.d.ts +10 -0
  143. package/lib/components/calendar/components/calendar-filter/contacts-filter.component.d.ts +20 -0
  144. package/lib/components/calendar/components/calendar-week/calendar-week-card.component.d.ts +15 -0
  145. package/lib/components/calendar/components/calendar-week/calendar-week-tab.component.d.ts +9 -0
  146. package/lib/components/calendar/components/calendar-week/calendar-week-title.component.d.ts +7 -0
  147. package/lib/components/calendar/components/calendar-week/calendar-week.component.d.ts +20 -0
  148. package/lib/components/calendar/components/calendar-weekday/calendar-weekday.component.d.ts +23 -0
  149. package/lib/components/calendar/components/day-slot-item/day-slot-item.component.d.ts +19 -0
  150. package/lib/components/calendar/components/day-slot-item/slot-context-menu.component.d.ts +40 -0
  151. package/lib/components/calendar/components/recurrings-tab/recurrings-tab.component.d.ts +15 -0
  152. package/lib/components/calendar/components/singles-tab/single-happenings-list.component.d.ts +22 -0
  153. package/lib/components/calendar/components/singles-tab/singles-tab.component.d.ts +29 -0
  154. package/lib/components/calendar/components/timing-badge/timing-badge.component.d.ts +17 -0
  155. package/lib/components/calendar/weekday.d.ts +7 -0
  156. package/lib/components/calendar-core.d.ts +10 -0
  157. package/lib/components/calendar-filter.service.d.ts +8 -0
  158. package/lib/components/calendar-slots.d.ts +5 -0
  159. package/lib/components/happening-base.component.d.ts +46 -0
  160. package/lib/components/happening-card/happening-card.component.d.ts +11 -0
  161. package/lib/components/happening-component-base-params.d.ts +16 -0
  162. package/lib/components/happening-form/happening-form.component.d.ts +52 -0
  163. package/lib/components/happening-form/happening-price-form/happening-price-modal.component.d.ts +29 -0
  164. package/lib/components/happening-form/happening-prices/happening-prices.component.d.ts +16 -0
  165. package/lib/components/happening-participants/happening-participants.component.d.ts +24 -0
  166. package/lib/components/happening-slot-form/happening-slot-form.component.d.ts +76 -0
  167. package/lib/components/happening-slot-form/happening-slot-modal.component.d.ts +26 -0
  168. package/lib/components/happening-slot-form/happening-slot-modal.service.d.ts +18 -0
  169. package/lib/components/happening-slot-participants/happening-slot-participants.component.d.ts +19 -0
  170. package/lib/components/happening-slots/happening-slots.component.d.ts +28 -0
  171. package/lib/components/index.d.ts +5 -0
  172. package/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.d.ts +16 -0
  173. package/lib/components/start-end-datetime-form/start-end-datetime-form.component.d.ts +53 -0
  174. package/lib/components/start-end-datetime-form/time-selector.component.d.ts +15 -0
  175. package/lib/components/swipeable-base.component.d.ts +25 -0
  176. package/lib/components/swipeable-ui.d.ts +24 -0
  177. package/lib/components/week.d.ts +4 -0
  178. package/lib/components/weekday-functions.d.ts +3 -0
  179. package/lib/components/weekdays/weekdays-form-base.d.ts +31 -0
  180. package/lib/index.d.ts +2 -0
  181. package/lib/modals/happening-title-modal/happening-title-modal.component.d.ts +24 -0
  182. package/lib/services/calendar-data-provider.d.ts +33 -0
  183. package/lib/services/calendar-day.d.ts +45 -0
  184. package/lib/services/calendar-day.service.d.ts +18 -0
  185. package/lib/services/calendar-nav.service.d.ts +14 -0
  186. package/lib/services/calendar-space.d.ts +23 -0
  187. package/lib/services/calendar-types.d.ts +10 -0
  188. package/lib/services/calendarium-services.module.d.ts +6 -0
  189. package/lib/services/calendarium-space.service.d.ts +8 -0
  190. package/lib/services/happening.service.d.ts +99 -0
  191. package/lib/services/index.d.ts +5 -0
  192. package/package.json +26 -0
  193. package/sneat-extensions-schedulus-shared.d.ts +5 -0
  194. package/tsconfig.lib.prod.tsbuildinfo +1 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"happening-slots.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/extensions/schedulus/shared/src/lib/components/happening-slots/happening-slots.component.ts","../../../../../../../../../libs/extensions/schedulus/shared/src/lib/components/happening-slots/happening-slots.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n computed,\n EventEmitter,\n input,\n Output,\n signal,\n inject,\n} from '@angular/core';\nimport {\n IonBadge,\n IonButton,\n IonButtons,\n IonIcon,\n IonItem,\n IonLabel,\n IonSpinner,\n IonText,\n} from '@ionic/angular/standalone';\nimport { Numeral2Pipe } from '@sneat/components';\nimport {\n IHappeningSlot,\n WeekdayCode2,\n IHappeningContext,\n IHappeningSlotWithID,\n WdToWeekdayPipe,\n} from '@sneat/mod-schedulus-core';\nimport { ErrorLogger, IErrorLogger } from '@sneat/core';\nimport {\n HappeningService,\n IDeleteSlotRequest,\n} from '../../services/happening.service';\nimport {\n HappeningSlotModalService,\n HappeningSlotModalServiceModule,\n} from '../happening-slot-form/happening-slot-modal.service';\n\nexport interface AddSlotParams {\n wd?: WeekdayCode2;\n}\n\n@Component({\n imports: [\n HappeningSlotModalServiceModule,\n WdToWeekdayPipe,\n Numeral2Pipe,\n IonLabel,\n IonButtons,\n IonButton,\n IonIcon,\n IonItem,\n IonText,\n IonBadge,\n IonSpinner,\n ],\n changeDetection: ChangeDetectionStrategy.OnPush,\n selector: 'sneat-happening-slots',\n templateUrl: './happening-slots.component.html',\n})\nexport class HappeningSlotsComponent {\n private readonly errorLogger = inject<IErrorLogger>(ErrorLogger);\n private readonly happeningService = inject(HappeningService);\n private readonly happeningSlotModalService = inject(\n HappeningSlotModalService,\n );\n\n public readonly happening = input.required<IHappeningContext>();\n\n public readonly wd = input<WeekdayCode2 | undefined>();\n\n @Output() readonly slotSelected = new EventEmitter<IHappeningSlot>();\n @Output() readonly happeningChange = new EventEmitter<IHappeningContext>();\n\n protected readonly $slots = computed<IHappeningSlotWithID[] | undefined>(() =>\n Object.entries(this.happening().brief?.slots || {}).map(([id, slot]) =>\n Object.assign(slot, { id }),\n ),\n );\n\n protected readonly hasAnyWd = (\n slot: IHappeningSlotWithID,\n ...wds: readonly WeekdayCode2[]\n ) => wds.some((wd) => !!slot.weekdays?.includes(wd));\n\n protected removeSlot(event: Event, slot: IHappeningSlotWithID): void {\n event.preventDefault();\n event.stopPropagation();\n const happening = this.happening();\n if (!happening.brief) {\n throw new Error('!this.happening?.brief');\n }\n if (happening.id) {\n this.deleteSlot(slot);\n } else {\n this.removeSlotFromHappening(slot);\n }\n }\n\n private removeSlotFromHappening(slot: IHappeningSlotWithID): void {\n const happening = this.happening();\n if (!happening.brief) {\n throw new Error('!this.happening');\n }\n this.onHappeningChanged({\n ...happening,\n brief: {\n ...happening.brief,\n slots: Object.fromEntries(\n Object.entries(happening.brief?.slots || {}).filter(\n ([id]) => id !== slot.id,\n ),\n ),\n },\n });\n }\n\n private deleteSlot(slot: IHappeningSlotWithID): void {\n const happening = this.happening();\n if (!happening.brief) {\n throw new Error('!this.happening?.brief');\n }\n const happeningID = happening.id;\n if (!happeningID) {\n throw new Error('!happeningID');\n }\n const spaceID = happening.space.id;\n if (!spaceID) {\n throw new Error('!spaceID');\n }\n const request: IDeleteSlotRequest = {\n spaceID: spaceID,\n happeningID,\n slotID: slot.id,\n };\n\n this.$deletingSlotIDs.set([...this.$deletingSlotIDs(), slot.id]);\n\n const removeFromDeletingSlotIDs = (delay: number) =>\n setTimeout(\n () =>\n this.$deletingSlotIDs.set(\n this.$deletingSlotIDs().filter((id) => id !== slot.id),\n ),\n delay,\n );\n this.happeningService.deleteSlot(request).subscribe({\n next: () => {\n this.removeSlotFromHappening(slot);\n removeFromDeletingSlotIDs(0);\n },\n error: (err) => {\n this.errorLogger.logError(err, 'failed to delete slot');\n removeFromDeletingSlotIDs(300);\n },\n });\n }\n\n protected readonly $deletingSlotIDs = signal<readonly string[]>([]);\n\n protected selectSlot(event: Event, slot: IHappeningSlotWithID): void {\n this.slotSelected.emit(slot);\n this.showEditSlot(event, slot);\n }\n\n protected onHappeningChanged(happening: IHappeningContext): void {\n this.happeningChange.emit(happening);\n }\n\n protected editingSlot?: IHappeningSlot;\n\n protected showEditSlot(event: Event, slot: IHappeningSlotWithID): void {\n event.stopPropagation();\n event.preventDefault();\n const happening = this.happening();\n this.happeningSlotModalService\n .editSingleHappeningSlot(event, happening, undefined, slot)\n .catch(this.errorLogger.logErrorHandler('failed to open edit modal'));\n\n // this.addSlotParams = undefined;\n // this.editingSlot = slot;\n // this.isShowingSlotFormModal = true;\n }\n\n protected showAddSlot(event: Event): void {\n const happening = this.happening();\n this.happeningSlotModalService\n .editSingleHappeningSlot(event, happening)\n .catch(this.errorLogger.logErrorHandler('failed to open edit modal'));\n\n // this.editingSlot = undefined;\n // this.addSlotParams = params;\n // this.isShowingSlotFormModal = true;\n }\n\n // onSlotFormModalDismissed(event: Event): void {\n // \tconsole.log('onAddSlotModalDismissed(), event:', event);\n // \tthis.editingSlot = undefined;\n // \tthis.isShowingSlotFormModal = false;\n // \tthis.addSlotDismissed.next();\n // }\n}\n","<ion-item color=\"light\" class=\"sneat-tiny-end-padding\">\n <ion-label>When</ion-label>\n <ion-buttons slot=\"end\">\n <ion-button\n title=\"Add slot\"\n (click)=\"showAddSlot($event)\"\n [color]=\"$slots()?.length ? 'primary' : 'danger'\"\n >\n <ion-icon name=\"add-outline\" slot=\"start\" />\n <ion-label>Add slot</ion-label>\n </ion-button>\n </ion-buttons>\n</ion-item>\n@if ($slots() && !$slots()?.length) {\n <ion-item>\n <ion-label><i>No slots have been added yet.</i></ion-label>\n </ion-item>\n}\n@for (slot of $slots(); track slot.id; let last = $last) {\n <ion-item\n button=\"button\"\n class=\"with-buttons sneat-tiny-end-padding\"\n [lines]=\"last ? 'full' : 'inset'\"\n (click)=\"selectSlot($event, slot)\"\n >\n @if (slot.start || slot.end) {\n <ion-buttons slot=\"start\">\n <!-- TODO(help-wanted): align to the top -->\n <div style=\"text-align: center\">\n @if (slot.start) {\n <ion-badge style=\"display: block\" color=\"light\">\n @if (slot.start.date) {\n <b>{{ slot.start.date }}</b>\n }\n\n &#64; {{ slot.start.time }}\n </ion-badge>\n }\n @if (slot.durationMinutes) {\n <ion-text\n color=\"medium\"\n style=\"display: block; font-size: small; margin-top: 0.75em\"\n >\n {{ slot.durationMinutes }} mins\n </ion-text>\n }\n </div>\n </ion-buttons>\n }\n\n @if (slot.repeats === \"monthly\") {\n @if (slot.start) {\n on\n } @else {\n On\n }\n {{ slot.day | numeral }}\n of every month\n }\n\n @if (slot.repeats === \"yearly\") {\n Every year on {{ slot.day | numeral }} of {{ slot.month }}\n }\n\n <ion-label text-wrap>\n <p>\n @if (slot.weekdays?.length === 7) {\n Every day\n } @else if (\n slot.weekdays?.length === 5 && !hasAnyWd(slot, \"sa\", \"su\")\n ) {\n Weekdays\n } @else if (slot.weekdays?.length === 2 && hasAnyWd(slot, \"sa\", \"su\")) {\n Weekends\n } @else {\n @for (wd of slot.weekdays; track wd) {\n <ion-badge color=\"light\" style=\"margin-right: 4px\">\n {{ wd | wdToWeekday }}\n </ion-badge>\n }\n }\n </p>\n <p>\n @if (slot.location && (slot.location.title || slot.location.address)) {\n &#64; {{ slot.location.title || slot.location.address }}\n @if (slot.end) {\n , ends at\n {{ slot.end.time }}\n }\n } @else if (slot.end) {\n Ends at {{ slot.end.time }}\n }\n </p>\n </ion-label>\n <ion-buttons slot=\"end\">\n @if (!$deletingSlotIDs().includes(slot.id)) {\n <ion-button\n title=\"Edit\"\n color=\"medium\"\n (click)=\"showEditSlot($event, slot)\"\n >\n <ion-icon name=\"create-outline\" />\n </ion-button>\n }\n @if (!happening().id || ($slots()?.length || 0) > 1) {\n <ion-button\n [disabled]=\"$deletingSlotIDs().includes(slot.id)\"\n (click)=\"removeSlot($event, slot)\"\n color=\"medium\"\n >\n @if ($deletingSlotIDs().includes(slot.id)) {\n @if ($deletingSlotIDs().includes(slot.id)) {\n <ion-spinner name=\"lines-small\" slot=\"end\" />\n }\n <ion-label style=\"text-transform: none\">Deleting...</ion-label>\n } @else {\n <ion-icon name=\"close-outline\" />\n }\n </ion-button>\n }\n </ion-buttons>\n </ion-item>\n}\n<!--<ion-modal-->\n<!--\t#addSlotModal-->\n<!--\t[isOpen]=\"isShowingSlotFormModal\"-->\n<!--\t(ionModalDidDismiss)=\"onSlotFormModalDismissed($event)\"-->\n<!--&gt;-->\n<!--\t&lt;!&ndash;\tclass=\"auto-height\"&ndash;&gt;-->\n\n<!--\t<ng-template>-->\n<!--\t\t<ion-header>-->\n<!--\t\t\t<ion-toolbar color=\"primary\">-->\n<!--\t\t\t\t<ion-title>-->\n<!--\t\t\t\t\t@if (editingSlot) {-->\n<!--\t\t\t\t\t\t{{ happening?.brief?.title || \"Edit happening\" }}-->\n<!--\t\t\t\t\t} @else {-->\n<!--\t\t\t\t\t\tNew slot-->\n<!--\t\t\t\t\t}-->\n<!--\t\t\t\t</ion-title>-->\n<!--\t\t\t\t<ion-buttons slot=\"end\">-->\n<!--\t\t\t\t\t<ion-button (click)=\"addSlotModal.dismiss()\">-->\n<!--\t\t\t\t\t\t<ion-icon name=\"close-outline\" slot=\"icon-only\" />-->\n<!--\t\t\t\t\t</ion-button>-->\n<!--\t\t\t\t</ion-buttons>-->\n<!--\t\t\t</ion-toolbar>-->\n<!--\t\t</ion-header>-->\n<!--\t\t<ion-content>-->\n<!--\t\t\t&lt;!&ndash;\t\t\t<div class=\"modal-wrapper\">&ndash;&gt;-->\n<!--\t\t\t<sneat-happening-slot-form-->\n<!--\t\t\t\tclass=\"modal-content\"-->\n<!--\t\t\t\tmode=\"modal\"-->\n<!--\t\t\t\t[wd]=\"addSlotParams?.wd\"-->\n<!--\t\t\t\t[(happening)]=\"happening\"-->\n<!--\t\t\t\t[slot]=\"editingSlot\"-->\n<!--\t\t\t\t[isToDo]=\"false\"-->\n<!--\t\t\t\t(slotAdded)=\"onSlotAdded($event)\"-->\n<!--\t\t\t\t(happeningChange)=\"onHappeningChanged($event)\"-->\n<!--\t\t\t/>-->\n<!--\t\t\t&lt;!&ndash;\t\t\t</div>&ndash;&gt;-->\n<!--\t\t</ion-content>-->\n<!--\t</ng-template>-->\n<!--</ion-modal>-->\n"]}
@@ -0,0 +1,20 @@
1
+ export * from './calendar/calendar-brief.component';
2
+ export * from './calendar/calendar-component-types';
3
+ export * from './calendar/calendar.component';
4
+ // export * from './calendar/weekday';
5
+ // export * from './calendar-filter.service';
6
+ // export * from './day-tasks/day-tasks.component';
7
+ //
8
+ // // export * from './calendar/calendar-component.module';
9
+ // export * from './calendar/components/calendar-day/calendar-day.component';
10
+ //
11
+ // export * from './calendar/calendar-brief-component2.component';
12
+ export * from './happening-form/happening-form.component';
13
+ export * from './happening-component-base-params';
14
+ // export * from './schedule-core';
15
+ // export * from './schedule-slots';
16
+ // export * from './weekday-functions';
17
+ // export { Week } from './week';
18
+ //
19
+ // export { CalendarDayTitleComponent } from './calendar/components/calendar-day/calendar-day-title.component';
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../libs/extensions/schedulus/shared/src/lib/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,qCAAqC,CAAC;AACpD,cAAc,qCAAqC,CAAC;AACpD,cAAc,+BAA+B,CAAC;AAC9C,sCAAsC;AACtC,6CAA6C;AAC7C,mDAAmD;AACnD,EAAE;AACF,2DAA2D;AAC3D,6EAA6E;AAC7E,EAAE;AACF,kEAAkE;AAClE,cAAc,2CAA2C,CAAC;AAC1D,cAAc,mCAAmC,CAAC;AAClD,mCAAmC;AACnC,oCAAoC;AACpC,uCAAuC;AACvC,iCAAiC;AACjC,EAAE;AACF,+GAA+G","sourcesContent":["export * from './calendar/calendar-brief.component';\nexport * from './calendar/calendar-component-types';\nexport * from './calendar/calendar.component';\n// export * from './calendar/weekday';\n// export * from './calendar-filter.service';\n// export * from './day-tasks/day-tasks.component';\n//\n// // export * from './calendar/calendar-component.module';\n// export * from './calendar/components/calendar-day/calendar-day.component';\n//\n// export * from './calendar/calendar-brief-component2.component';\nexport * from './happening-form/happening-form.component';\nexport * from './happening-component-base-params';\n// export * from './schedule-core';\n// export * from './schedule-slots';\n// export * from './weekday-functions';\n// export { Week } from './week';\n//\n// export { CalendarDayTitleComponent } from './calendar/components/calendar-day/calendar-day-title.component';\n"]}
@@ -0,0 +1,68 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, signal, } from '@angular/core';
2
+ import { IonCheckbox, IonCol, IonGrid, IonInput, IonItem, IonRow, } from '@ionic/angular/standalone';
3
+ import * as i0 from "@angular/core";
4
+ export class StartEndDatesRangeFormComponent {
5
+ constructor() {
6
+ this.timingChange = new EventEmitter();
7
+ this.startEnabled = signal(false, ...(ngDevMode ? [{ debugName: "startEnabled" }] : []));
8
+ this.endEnabled = signal(false, ...(ngDevMode ? [{ debugName: "endEnabled" }] : []));
9
+ }
10
+ onStartChecked(event) {
11
+ const ce = event;
12
+ const checked = ce.detail.checked;
13
+ this.startEnabled.set(checked);
14
+ let start = this.timing?.start;
15
+ if (!start?.date) {
16
+ start = { ...start, date: new Date().toISOString().substring(0, 10) };
17
+ const timing = { ...this.timing, start };
18
+ this.timing = timing;
19
+ this.timingChange.emit(timing);
20
+ }
21
+ }
22
+ onEndChecked(event) {
23
+ const ce = event;
24
+ const checked = ce.detail.checked;
25
+ this.endEnabled.set(checked);
26
+ }
27
+ onStartChanged(event) {
28
+ const ce = event;
29
+ const date = ce.detail.value;
30
+ const start = this.timing?.start;
31
+ const timing = { ...this.timing, start: { ...start, date } };
32
+ this.timingChange.emit(timing);
33
+ }
34
+ onEndChanged(event) {
35
+ const ce = event;
36
+ const date = ce.detail.value;
37
+ const end = this.timing?.end;
38
+ const timing = {
39
+ ...this.timing,
40
+ end: { ...end, date },
41
+ start: this.timing?.start || { date, time: '' },
42
+ };
43
+ this.timingChange.emit(timing);
44
+ }
45
+ ngOnChanges(changes) {
46
+ // console.log('StartEndDatesRangeFormComponent.ngOnChanges', { changes });
47
+ if (changes['timing']) {
48
+ if (this.timing?.start?.date && !this.startEnabled()) {
49
+ this.startEnabled.set(true);
50
+ }
51
+ if (this.timing?.end?.date && !this.startEnabled()) {
52
+ this.endEnabled.set(true);
53
+ }
54
+ }
55
+ }
56
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: StartEndDatesRangeFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
57
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.2.0", type: StartEndDatesRangeFormComponent, isStandalone: true, selector: "sneat-start-end-dates-range-form", inputs: { timing: "timing" }, outputs: { timingChange: "timingChange" }, usesOnChanges: true, ngImport: i0, template: "<ion-grid class=\"ion-grid-layout\">\n <ion-row>\n <ion-col size=\"6\">\n <ion-item>\n <ion-checkbox\n labelPlacement=\"end\"\n slot=\"start\"\n (ionChange)=\"onStartChecked($event)\"\n >First on</ion-checkbox\n >\n </ion-item>\n </ion-col>\n <ion-col size=\"6\">\n <ion-item>\n <ion-input\n [value]=\"timing?.start?.date\"\n type=\"date\"\n [disabled]=\"!startEnabled()\"\n (ionChange)=\"onStartChanged($event)\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n <ion-row>\n <ion-col size=\"6\">\n <ion-item lines=\"none\">\n <ion-checkbox\n labelPlacement=\"end\"\n slot=\"start\"\n (ionChange)=\"onEndChecked($event)\"\n >Last on</ion-checkbox\n >\n </ion-item>\n </ion-col>\n <ion-col size=\"6\">\n <ion-item lines=\"none\">\n <ion-input\n type=\"date\"\n [disabled]=\"!endEnabled()\"\n (ionChange)=\"onEndChanged($event)\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n</ion-grid>\n", dependencies: [{ kind: "component", type: IonGrid, selector: "ion-grid", inputs: ["fixed"] }, { kind: "component", type: IonRow, selector: "ion-row" }, { kind: "component", type: IonCol, selector: "ion-col", inputs: ["offset", "offsetLg", "offsetMd", "offsetSm", "offsetXl", "offsetXs", "pull", "pullLg", "pullMd", "pullSm", "pullXl", "pullXs", "push", "pushLg", "pushMd", "pushSm", "pushXl", "pushXs", "size", "sizeLg", "sizeMd", "sizeSm", "sizeXl", "sizeXs"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonCheckbox, selector: "ion-checkbox", inputs: ["checked", "color", "disabled", "errorText", "helperText", "indeterminate", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "size", "spellcheck", "step", "type", "value"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
58
+ }
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: StartEndDatesRangeFormComponent, decorators: [{
60
+ type: Component,
61
+ args: [{ selector: 'sneat-start-end-dates-range-form', changeDetection: ChangeDetectionStrategy.OnPush, imports: [IonGrid, IonRow, IonCol, IonItem, IonCheckbox, IonInput], template: "<ion-grid class=\"ion-grid-layout\">\n <ion-row>\n <ion-col size=\"6\">\n <ion-item>\n <ion-checkbox\n labelPlacement=\"end\"\n slot=\"start\"\n (ionChange)=\"onStartChecked($event)\"\n >First on</ion-checkbox\n >\n </ion-item>\n </ion-col>\n <ion-col size=\"6\">\n <ion-item>\n <ion-input\n [value]=\"timing?.start?.date\"\n type=\"date\"\n [disabled]=\"!startEnabled()\"\n (ionChange)=\"onStartChanged($event)\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n <ion-row>\n <ion-col size=\"6\">\n <ion-item lines=\"none\">\n <ion-checkbox\n labelPlacement=\"end\"\n slot=\"start\"\n (ionChange)=\"onEndChecked($event)\"\n >Last on</ion-checkbox\n >\n </ion-item>\n </ion-col>\n <ion-col size=\"6\">\n <ion-item lines=\"none\">\n <ion-input\n type=\"date\"\n [disabled]=\"!endEnabled()\"\n (ionChange)=\"onEndChanged($event)\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n</ion-grid>\n" }]
62
+ }], propDecorators: { timing: [{
63
+ type: Input,
64
+ args: [{ required: true }]
65
+ }], timingChange: [{
66
+ type: Output
67
+ }] } });
68
+ //# sourceMappingURL=start-end-dates-range-form.component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"start-end-dates-range-form.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/extensions/schedulus/shared/src/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.ts","../../../../../../../../../libs/extensions/schedulus/shared/src/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n EventEmitter,\n Input,\n OnChanges,\n Output,\n signal,\n SimpleChanges,\n} from '@angular/core';\nimport {\n IonCheckbox,\n IonCol,\n IonGrid,\n IonInput,\n IonItem,\n IonRow,\n} from '@ionic/angular/standalone';\nimport { IDateTime, ITiming } from '@sneat/mod-schedulus-core';\n\n@Component({\n selector: 'sneat-start-end-dates-range-form',\n templateUrl: './start-end-dates-range-form.component.html',\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [IonGrid, IonRow, IonCol, IonItem, IonCheckbox, IonInput],\n})\nexport class StartEndDatesRangeFormComponent implements OnChanges {\n @Input({ required: true }) timing?: ITiming;\n @Output() timingChange = new EventEmitter<ITiming>();\n\n protected startEnabled = signal(false);\n protected endEnabled = signal(false);\n\n protected onStartChecked(event: Event): void {\n const ce = event as CustomEvent;\n const checked = ce.detail.checked;\n this.startEnabled.set(checked);\n let start = this.timing?.start;\n if (!start?.date) {\n start = { ...start, date: new Date().toISOString().substring(0, 10) };\n const timing = { ...this.timing, start };\n this.timing = timing;\n this.timingChange.emit(timing);\n }\n }\n\n protected onEndChecked(event: Event): void {\n const ce = event as CustomEvent;\n const checked = ce.detail.checked;\n this.endEnabled.set(checked);\n }\n\n protected onStartChanged(event: Event): void {\n const ce = event as CustomEvent;\n const date = ce.detail.value;\n const start: IDateTime | undefined = this.timing?.start;\n const timing = { ...this.timing, start: { ...start, date } };\n this.timingChange.emit(timing);\n }\n\n protected onEndChanged(event: Event): void {\n const ce = event as CustomEvent;\n const date = ce.detail.value;\n const end: IDateTime | undefined = this.timing?.end;\n const timing: ITiming = {\n ...this.timing,\n end: { ...end, date },\n start: this.timing?.start || { date, time: '' },\n };\n this.timingChange.emit(timing);\n }\n\n public ngOnChanges(changes: SimpleChanges): void {\n // console.log('StartEndDatesRangeFormComponent.ngOnChanges', { changes });\n if (changes['timing']) {\n if (this.timing?.start?.date && !this.startEnabled()) {\n this.startEnabled.set(true);\n }\n if (this.timing?.end?.date && !this.startEnabled()) {\n this.endEnabled.set(true);\n }\n }\n }\n}\n","<ion-grid class=\"ion-grid-layout\">\n <ion-row>\n <ion-col size=\"6\">\n <ion-item>\n <ion-checkbox\n labelPlacement=\"end\"\n slot=\"start\"\n (ionChange)=\"onStartChecked($event)\"\n >First on</ion-checkbox\n >\n </ion-item>\n </ion-col>\n <ion-col size=\"6\">\n <ion-item>\n <ion-input\n [value]=\"timing?.start?.date\"\n type=\"date\"\n [disabled]=\"!startEnabled()\"\n (ionChange)=\"onStartChanged($event)\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n <ion-row>\n <ion-col size=\"6\">\n <ion-item lines=\"none\">\n <ion-checkbox\n labelPlacement=\"end\"\n slot=\"start\"\n (ionChange)=\"onEndChecked($event)\"\n >Last on</ion-checkbox\n >\n </ion-item>\n </ion-col>\n <ion-col size=\"6\">\n <ion-item lines=\"none\">\n <ion-input\n type=\"date\"\n [disabled]=\"!endEnabled()\"\n (ionChange)=\"onEndChanged($event)\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n</ion-grid>\n"]}
@@ -0,0 +1,377 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, inject, } from '@angular/core';
2
+ import { FormControl, FormsModule, ReactiveFormsModule, UntypedFormGroup, Validators, } from '@angular/forms';
3
+ import { IonAccordion, IonAccordionGroup, IonButton, IonButtons, IonCol, IonDatetime, IonGrid, IonIcon, IonInput, IonItem, IonLabel, IonModal, IonPopover, IonRow, IonSelect, IonSelectOption, ModalController, } from '@ionic/angular/standalone';
4
+ import { dateToIso, isoStringsToDate, isValidaTimeString, isValidDateString, SneatSelectAllOnFocusDirective, } from '@sneat/core';
5
+ import { emptyTiming } from '@sneat/mod-schedulus-core';
6
+ import { dateToTimeOnlyStr } from '@sneat/mod-schedulus-core';
7
+ import { ErrorLogger } from '@sneat/core';
8
+ import { isTomorrow } from '../calendar-core';
9
+ import { StartEndDatesRangeFormComponent } from '../start-end-dates-range-form/start-end-dates-range-form.component';
10
+ import { TimeSelectorComponent } from './time-selector.component';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/forms";
13
+ export class StartEndDatetimeFormComponent {
14
+ onTimingChanged(timing) {
15
+ this.timingChange.emit(timing);
16
+ }
17
+ get disabled() {
18
+ return !this.mode;
19
+ }
20
+ get hideStartDate() {
21
+ return this.mode === 'recurring';
22
+ }
23
+ // public get timing(): ITiming {
24
+ // let start: IDateTime = {
25
+ // time: this.startTime.value || '',
26
+ // };
27
+ // if (this.startDate.value) {
28
+ // start = { ...start, date: this.startDate.value };
29
+ // }
30
+ // let end: IDateTime = {
31
+ // time: this.endTime.value || '',
32
+ // };
33
+ // if (this.endDate.value) {
34
+ // end = { ...end, date: this.endDate.value };
35
+ // }
36
+ // const timing: ITiming = {
37
+ // start, end,
38
+ // durationMinutes: Number(this.duration.value),
39
+ // };
40
+ // return timing;
41
+ // }
42
+ // Is public property as might be used by component's parent component
43
+ get isValid() {
44
+ this.form.markAllAsTouched();
45
+ return (isValidaTimeString(this.startTime.value || '') &&
46
+ (!this.endTime.value || isValidaTimeString(this.endTime.value)));
47
+ }
48
+ constructor() {
49
+ this.errorLogger = inject(ErrorLogger);
50
+ this.modalController = inject(ModalController);
51
+ this.timing = emptyTiming;
52
+ this.timingChange = new EventEmitter();
53
+ this.addClick = new EventEmitter();
54
+ this.today = new Date();
55
+ this.maxDate = new Date(this.today.getFullYear() + 1, 11, 31)
56
+ .toISOString()
57
+ .substring(0, 10);
58
+ this.tab = 'duration';
59
+ this.durationUnits = 'minutes';
60
+ // protected startDateVal? = new Date().toISOString().substring(0, 10);
61
+ this.startDate = new FormControl('', //TODO: set to current date only for single happenings: new Date().toISOString().substring(0, 10),
62
+ {
63
+ // dateToIso(new Date())
64
+ validators: Validators.required,
65
+ });
66
+ this.endDate = new FormControl('', {
67
+ // validators: Validators.required,
68
+ });
69
+ this.startTime = new FormControl('', {
70
+ validators: [Validators.required, Validators.pattern(/[0-2]\d:[0-5]\d/)],
71
+ });
72
+ this.endTime = new FormControl('', {
73
+ validators: [Validators.required, Validators.pattern(/[0-2]\d:[0-5]\d/)],
74
+ });
75
+ this.duration = new FormControl(60, {
76
+ validators: [Validators.required],
77
+ });
78
+ this.form = new UntypedFormGroup({
79
+ startDate: this.startDate,
80
+ startTime: this.startTime,
81
+ endTime: this.endTime,
82
+ duration: this.duration,
83
+ });
84
+ this.isTomorrow = isTomorrow;
85
+ this.endTime.disable();
86
+ }
87
+ ngOnChanges(changes) {
88
+ if (changes['date']) {
89
+ this.onDateChanged();
90
+ }
91
+ const happeningSlotChange = changes['timing'];
92
+ if (happeningSlotChange?.currentValue) {
93
+ this.onTimingChange();
94
+ }
95
+ }
96
+ onDateChanged() {
97
+ if (this.mode === 'single') {
98
+ if (!this.startDate.dirty) {
99
+ const date = this.date || new Date().toISOString().substring(0, 10);
100
+ this.startDate.setValue(date);
101
+ }
102
+ }
103
+ else {
104
+ this.startDate.setValue('');
105
+ }
106
+ }
107
+ onTimingChange() {
108
+ // if (this.happeningSlot.repeats === 'UNKNOWN') {
109
+ // this.setRepeatsBasedOnHappeningType();
110
+ // }
111
+ if (!this.startDate.dirty) {
112
+ const startDate = this.timing.start?.date;
113
+ if (startDate) {
114
+ this.startDate.setValue(startDate);
115
+ }
116
+ }
117
+ if (!this.startTime.dirty) {
118
+ this.startTime.setValue(this.timing.start?.time || '');
119
+ }
120
+ if (!this.endDate.dirty) {
121
+ this.endDate.setValue(this.timing.end?.date || '');
122
+ }
123
+ if (!this.endTime.dirty) {
124
+ this.endTime.setValue(this.timing.end?.time || '');
125
+ }
126
+ this.setDuration();
127
+ }
128
+ setStartTime(value) {
129
+ if (!isValidaTimeString(value)) {
130
+ this.errorLogger.logError(new Error('not valid time string:' + value), 'Invalid start time');
131
+ return;
132
+ }
133
+ this.modalController.dismiss().catch(console.error);
134
+ this.startTime.setValue(value);
135
+ this.timing = {
136
+ ...this.timing,
137
+ start: { ...this.timing.start, time: value },
138
+ };
139
+ this.setEndTime();
140
+ this.emitTimingChanged('setStartTime');
141
+ setTimeout(() => {
142
+ this.durationInput
143
+ ?.setFocus()
144
+ .then(() => {
145
+ // TODO: Remove this workaround once SneatSelectAllOnFocusDirective is fixed
146
+ this.durationInput?.getInputElement()?.then((el) => el.select());
147
+ })
148
+ .catch(this.errorLogger.logErrorHandler('Failed to set focus to duration input'));
149
+ }, 50);
150
+ }
151
+ addToStart(v) {
152
+ let d = undefined;
153
+ try {
154
+ let startDate = this.startDate.value || '';
155
+ let startTime = this.startTime.value || '';
156
+ d = isoStringsToDate(startDate || '2000-01-01', startTime);
157
+ if (v.days) {
158
+ d.setDate(d.getDate() + v.days);
159
+ }
160
+ if (v.hours) {
161
+ d.setTime(d.getTime() + v.hours * 60 * 60 * 1000);
162
+ }
163
+ if (this.startDate.value) {
164
+ // For recurring events startDate is not set
165
+ startDate = dateToIso(d);
166
+ this.timing = {
167
+ ...this.timing,
168
+ start: { ...this.timing.start, date: startDate },
169
+ };
170
+ this.startDate.setValue(startDate);
171
+ }
172
+ if (this.startTime.value) {
173
+ startTime = dateToTimeOnlyStr(d);
174
+ this.timing = {
175
+ ...this.timing,
176
+ start: { ...this.timing.start, time: startTime },
177
+ };
178
+ this.startTime.setValue(startTime);
179
+ }
180
+ this.setEndTime();
181
+ this.emitTimingChanged('addToStart');
182
+ }
183
+ catch (e) {
184
+ throw new Error(`failed to add ${JSON.stringify(v)} to ${d} [${this.startDate.value} ${this.startTime.value}]: ${e}`, { cause: e });
185
+ }
186
+ }
187
+ // private setRepeatsBasedOnHappeningType(): void {
188
+ // switch (this.mode) {
189
+ // case 'recurring':
190
+ // this.happeningSlot = {...this.happeningSlot};
191
+ // break;
192
+ // case 'single':
193
+ // this.happeningSlot = {...this.happeningSlot};
194
+ // break;
195
+ // }
196
+ // }
197
+ setStartDate(event, code) {
198
+ const today = new Date();
199
+ let d;
200
+ switch (code) {
201
+ case 'today':
202
+ d = today;
203
+ break;
204
+ case 'tomorrow':
205
+ d = new Date();
206
+ d.setDate(today.getDate() + 1);
207
+ break;
208
+ }
209
+ if (d) {
210
+ const date = dateToIso(d);
211
+ this.startDate.setValue(date);
212
+ this.timing = {
213
+ ...this.timing,
214
+ start: { ...this.timing.start, date: date },
215
+ };
216
+ this.emitTimingChanged('setStartDate');
217
+ }
218
+ }
219
+ emitTimingChanged(_source) {
220
+ this.timingChange.emit(this.timing);
221
+ }
222
+ addSlot() {
223
+ if (this.mode === 'single' && !this.timing.start?.date) {
224
+ alert('Please select date');
225
+ return;
226
+ }
227
+ this.timingChange.emit(this.timing);
228
+ this.addClick.emit(this.timing);
229
+ }
230
+ onStartTimeBlur() {
231
+ // console.log('StartEndDatetimeFormComponent.onStartTimeBlur()');
232
+ const startTime = this.startTime.value || '';
233
+ if (startTime.match(/^\d{2}$/)) {
234
+ this.startTime.setValue(startTime + ':00');
235
+ }
236
+ }
237
+ onStartDateChanged() {
238
+ let startDate = this.startDate.value || '';
239
+ if (startDate.includes('T')) {
240
+ startDate = startDate.split('T')[0];
241
+ this.startDate.setValue(startDate);
242
+ }
243
+ const slot = this.timing;
244
+ this.timing = {
245
+ ...slot,
246
+ start: { ...slot.start, date: this.startDate.value || '' },
247
+ };
248
+ if ((!this.startTime.value ||
249
+ isValidaTimeString(this.startTime.value)) &&
250
+ (!this.endTime.value ||
251
+ isValidaTimeString(this.endTime.value)) &&
252
+ (!this.startDate.value ||
253
+ isValidDateString(this.startDate.value))) {
254
+ this.emitTimingChanged('onStartDateChanged');
255
+ }
256
+ }
257
+ onStartTimeChanged() {
258
+ const slot = this.timing;
259
+ this.timing = {
260
+ ...slot,
261
+ start: { ...slot.start, time: this.startTime.value || '' },
262
+ };
263
+ if (this.timing.start?.time &&
264
+ !this.timing.start?.date &&
265
+ this.startDate.value) {
266
+ this.timing = {
267
+ ...this.timing,
268
+ start: { ...this.timing.start, date: this.startDate.value },
269
+ };
270
+ }
271
+ if (isValidaTimeString(this.startTime.value) &&
272
+ this.duration.value) {
273
+ this.setEndTime();
274
+ }
275
+ }
276
+ onDurationChanged() {
277
+ // console.log('StartEndDatetimeFormComponent.onDurationChanged()');
278
+ if (isValidaTimeString(this.startTime.value)) {
279
+ this.setEndTime();
280
+ }
281
+ else {
282
+ this.emitTimingChanged('onDurationChanged');
283
+ }
284
+ }
285
+ setEndTime() {
286
+ const startTime = this.startTime.value;
287
+ const startHour = Number(startTime.substring(0, 2));
288
+ const startMin = Number(startTime.substring(3, 5));
289
+ const duration = Number(this.duration.value);
290
+ const durationHours = ~~(duration / 60);
291
+ const durationMin = duration % 60;
292
+ const toStr = (v) => {
293
+ const s = '00' + ('' + v).replace(/^0+/, '');
294
+ return s.substring(s.length - 2, s.length);
295
+ };
296
+ const endHour = toStr(startHour + durationHours);
297
+ const endMin = toStr(startMin + durationMin);
298
+ const endTime = `${endHour}:${endMin}`;
299
+ this.timing = { ...this.timing, end: { time: endTime } };
300
+ this.endTime.setValue(endTime);
301
+ this.emitTimingChanged('setEndTime');
302
+ }
303
+ onEndTimeChanged() {
304
+ const slot = this.timing;
305
+ this.timing = {
306
+ ...slot,
307
+ end: { ...slot.end, time: this.endTime.value || '' },
308
+ };
309
+ if (isValidaTimeString(this.startTime.value)) {
310
+ this.setDuration();
311
+ }
312
+ this.emitTimingChanged('onEndTimeChanged');
313
+ }
314
+ setDuration() {
315
+ const startTime = this.startTime.value;
316
+ const endTime = this.endTime.value;
317
+ if (!startTime || !endTime) {
318
+ return;
319
+ }
320
+ const startHour = Number(startTime.substring(0, 2));
321
+ const startMin = Number(startTime.substring(3, 5));
322
+ const startAt = startHour * 60 + startMin;
323
+ const endHour = Number(endTime.substring(0, 2));
324
+ const endMin = Number(endTime.substring(3, 5));
325
+ const endAt = endHour * 60 + endMin;
326
+ const durationMinutes = endAt - startAt;
327
+ this.duration.setValue(durationMinutes);
328
+ this.timing = { ...this.timing, durationMinutes };
329
+ }
330
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: StartEndDatetimeFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
331
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.0", type: StartEndDatetimeFormComponent, isStandalone: true, selector: "sneat-start-end-datetime-form", inputs: { addSlotLabel: "addSlotLabel", mode: "mode", date: "date", timing: "timing" }, outputs: { timingChange: "timingChange", addClick: "addClick" }, viewQueries: [{ propertyName: "durationInput", first: true, predicate: ["durationInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@switch (mode) {\n @case (\"recurring\") {\n <!-- TODO(help-wanted): use CSS class, preferably from Ionic -->\n <ion-grid class=\"ion-grid-layout\" style=\"border-top: 1px solid lightgray\">\n <ion-row>\n <ion-col size=\"12\" size-md=\"4\">\n <ion-item class=\"sneat-no-end-padding\" lines=\"none\">\n <ion-input\n type=\"time\"\n label=\"At\"\n #startTimeInput\n [formControl]=\"startTime\"\n (ionBlur)=\"onStartTimeBlur()\"\n (ionChange)=\"onStartTimeChanged()\"\n />\n @if (startTime.touched && !startTime.valid && !!startTime.errors) {\n <ion-label color=\"danger\" slot=\"end\"> Required field </ion-label>\n }\n <ion-buttons slot=\"end\" class=\"ion-no-margin ion-no-padding\">\n <ion-button id=\"quick-pick-start-time-recurring\" color=\"medium\">\n <!--\t\t\t<ion-label>Pick</ion-label>-->\n <ion-icon name=\"chevron-down-outline\" slot=\"end\" />\n </ion-button>\n <ion-modal trigger=\"quick-pick-start-time-recurring\">\n <ng-template>\n <sneat-time-selector (selected)=\"setStartTime($event)\" />\n </ng-template>\n </ion-modal>\n <!-- Commented out as does not fit into modal - we might want to show only on wide screens -->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\t*ngIf=\"startTime.value\"-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"addToStart({ hours: -1 })\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-icon name=\"chevron-back-outline\" slot=\"start\" />-->\n <!--\t\t\t\t\t\t<ion-label>-1h</ion-label>-->\n <!--\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\t*ngIf=\"startTime.value\"-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"addToStart({ hours: +1 })\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-label>+1h</ion-label>-->\n <!--\t\t\t\t\t\t<ion-icon name=\"chevron-forward-outline\" slot=\"end\" />-->\n <!--\t\t\t\t\t</ion-button>-->\n </ion-buttons>\n </ion-item>\n </ion-col>\n <ion-col size=\"12\" size-md=\"5\">\n <ion-item lines=\"none\">\n <ion-input\n #durationInput\n label=\"For\"\n [formControl]=\"duration\"\n (ionChange)=\"onDurationChanged()\"\n type=\"number\"\n style=\"text-align: right\"\n />\n <ion-select\n slot=\"end\"\n interface=\"popover\"\n [(ngModel)]=\"durationUnits\"\n >\n <ion-select-option value=\"minutes\">minutes</ion-select-option>\n <ion-select-option value=\"hours\">hours</ion-select-option>\n </ion-select>\n </ion-item>\n </ion-col>\n <ion-col size=\"12\" size-md=\"3\">\n <ion-item lines=\"none\">\n <ion-input\n type=\"time\"\n label=\"Ends at\"\n [formControl]=\"endTime\"\n (ionChange)=\"onEndTimeChanged()\"\n placeholder=\"HH:MM\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n </ion-grid>\n\n <!-- TODO(help-wanted): use CSS class, preferably from Ionic -->\n <ion-accordion-group\n style=\"\n border-top: 1px solid lightgray;\n border-bottom: 1px solid lightgray;\n \"\n >\n <ion-accordion value=\"dates\">\n <ion-item slot=\"header\" color=\"light\">\n <ion-label color=\"medium\">Dates (start & end)</ion-label>\n </ion-item>\n <sneat-start-end-dates-range-form\n slot=\"content\"\n [timing]=\"timing\"\n (timingChange)=\"onTimingChanged($event)\"\n />\n </ion-accordion>\n </ion-accordion-group>\n }\n @case (\"single\") {\n <ion-grid class=\"ion-grid-layout\">\n @if (!startDate.value || !startTime.value) {\n <ion-row>\n <ion-col size=\"12\" size-lg=\"5\">\n <ion-datetime\n [min]=\"today.toISOString().substring(0, 10)\"\n [max]=\"maxDate\"\n presentation=\"date\"\n [formControl]=\"startDate\"\n (ionChange)=\"onStartDateChanged()\"\n >\n <ion-buttons slot=\"buttons\">\n <ion-button\n color=\"medium\"\n (click)=\"setStartDate($event, 'today')\"\n >Today\n </ion-button>\n <ion-button\n color=\"medium\"\n (click)=\"setStartDate($event, 'tomorrow')\"\n >Tomorrow\n </ion-button>\n </ion-buttons>\n </ion-datetime>\n </ion-col>\n <ion-col size=\"12\" size-lg=\"7\">\n <sneat-time-selector\n [hideHeader]=\"true\"\n (selected)=\"startTime.setValue($event); onStartTimeChanged()\"\n />\n </ion-col>\n </ion-row>\n }\n @if (startDate.value && startTime.value) {\n <ion-row>\n <ion-col size=\"12\" size-sm=\"6\">\n <ion-item class=\"sneat-no-end-padding\">\n <ion-input\n label=\"On\"\n type=\"date\"\n [formControl]=\"startDate\"\n (ionChange)=\"onStartDateChanged()\"\n />\n <!--\t\t\t\t<ion-buttons-->\n <!--\t\t\t\t\tslot=\"end\"-->\n <!--\t\t\t\t\t*ngIf=\"!startDate?.value\"-->\n <!--\t\t\t\t\tclass=\"ion-no-margin ion-no-padding\"-->\n <!--\t\t\t\t>-->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"setStartDate($event, 'today')\"-->\n <!--\t\t\t\t\t\ttitle=\"Today\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-icon name=\"today-outline\" />-->\n <!--\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\tvalue=\"tomorrow\"-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"setStartDate($event, 'tomorrow')\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-label>+1D</ion-label>-->\n <!--\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t</ion-buttons>-->\n @if (startDate.value) {\n <ion-buttons slot=\"end\" class=\"ion-no-margin ion-no-padding\">\n <ion-button id=\"quick-pick-start-date\" color=\"medium\">\n <!--\t\t\t<ion-label>Pick</ion-label>-->\n <ion-icon name=\"chevron-down-outline\" slot=\"end\" />\n </ion-button>\n <ion-button color=\"medium\" (click)=\"addToStart({ days: -1 })\">\n <ion-icon name=\"chevron-back-outline\" slot=\"start\" />\n <ion-label>-1</ion-label>\n </ion-button>\n <ion-button color=\"medium\" (click)=\"addToStart({ days: +1 })\">\n <ion-label>+1</ion-label>\n <ion-icon name=\"chevron-forward-outline\" slot=\"end\" />\n </ion-button>\n <ion-popover\n trigger=\"quick-pick-start-date\"\n [dismissOnSelect]=\"true\"\n >\n <ng-template>\n <ion-item tappable (click)=\"setStartDate($event, 'today')\"\n >Today\n </ion-item>\n <ion-item\n tappable\n (click)=\"setStartDate($event, 'tomorrow')\"\n >Tomorrow\n </ion-item>\n <!--\t\t\t\t<ion-item-divider color=\"light\">Next week</ion-item-divider>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Monday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Tuesday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Wednesday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Thursday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Friday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Saturday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Sunday</ion-item>-->\n </ng-template>\n </ion-popover>\n </ion-buttons>\n }\n </ion-item>\n </ion-col>\n <ion-col size=\"12\" size-sm=\"6\">\n <ion-item class=\"sneat-no-end-padding\">\n <ion-input\n type=\"time\"\n label=\"At\"\n #startTimeInput\n [formControl]=\"startTime\"\n (ionBlur)=\"onStartTimeBlur()\"\n (ionChange)=\"onStartTimeChanged()\"\n />\n @if (\n startTime.touched && !startTime.valid && !!startTime.errors\n ) {\n <ion-label color=\"danger\" slot=\"end\">\n Required field\n </ion-label>\n }\n <ion-buttons slot=\"end\" class=\"ion-no-margin ion-no-padding\">\n <ion-button id=\"quick-pick-start-time-single\" color=\"medium\">\n <!--\t\t\t<ion-label>Pick</ion-label>-->\n <ion-icon name=\"chevron-down-outline\" slot=\"end\" />\n </ion-button>\n <ion-modal trigger=\"quick-pick-start-time-single\">\n <ng-template>\n <sneat-time-selector (selected)=\"setStartTime($event)\" />\n </ng-template>\n </ion-modal>\n @if (startTime.value) {\n <ion-button\n color=\"medium\"\n (click)=\"addToStart({ hours: -1 })\"\n >\n <ion-icon name=\"chevron-back-outline\" slot=\"start\" />\n <ion-label>-1h</ion-label>\n </ion-button>\n <ion-button\n color=\"medium\"\n (click)=\"addToStart({ hours: +1 })\"\n >\n <ion-label>+1h</ion-label>\n <ion-icon name=\"chevron-forward-outline\" slot=\"end\" />\n </ion-button>\n }\n </ion-buttons>\n </ion-item>\n </ion-col>\n </ion-row>\n }\n @if (startDate.value && startTime.value) {\n <ion-row>\n <ion-col size=\"12\" size-sm=\"6\">\n <ion-item lines=\"none\">\n <ion-input\n label=\"Duration\"\n sneatSelectAllOnFocus\n [formControl]=\"duration\"\n (ionChange)=\"onDurationChanged()\"\n type=\"number\"\n style=\"text-align: right\"\n />\n <ion-select\n slot=\"end\"\n interface=\"popover\"\n [(ngModel)]=\"durationUnits\"\n >\n <ion-select-option value=\"minutes\">minutes</ion-select-option>\n <ion-select-option value=\"hours\">hours</ion-select-option>\n </ion-select>\n </ion-item>\n </ion-col>\n <ion-col size=\"6\" size-sm=\"3\">\n <ion-item lines=\"none\">\n <ion-input\n type=\"time\"\n label=\"Ends at\"\n [formControl]=\"endTime\"\n (ionChange)=\"onEndTimeChanged()\"\n placeholder=\"HH:MM\"\n />\n </ion-item>\n </ion-col>\n <ion-col size=\"6\" size-sm=\"3\">\n <ion-button expand=\"full\" class=\"ion-margin\" (click)=\"addSlot()\"\n >{{ addSlotLabel }}\n </ion-button>\n </ion-col>\n </ion-row>\n }\n </ion-grid>\n }\n}\n", dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: TimeSelectorComponent, selector: "sneat-time-selector", inputs: ["hideHeader"], outputs: ["selected"] }, { kind: "component", type: StartEndDatesRangeFormComponent, selector: "sneat-start-end-dates-range-form", inputs: ["timing"], outputs: ["timingChange"] }, { kind: "directive", type: SneatSelectAllOnFocusDirective, selector: "[sneatSelectAllOnFocus]" }, { kind: "component", type: IonAccordion, selector: "ion-accordion", inputs: ["disabled", "mode", "readonly", "toggleIcon", "toggleIconSlot", "value"] }, { kind: "component", type: IonAccordionGroup, selector: "ion-accordion-group", inputs: ["animated", "disabled", "expand", "mode", "multiple", "readonly", "value"] }, { kind: "component", type: IonGrid, selector: "ion-grid", inputs: ["fixed"] }, { kind: "component", type: IonRow, selector: "ion-row" }, { kind: "component", type: IonCol, selector: "ion-col", inputs: ["offset", "offsetLg", "offsetMd", "offsetSm", "offsetXl", "offsetXs", "pull", "pullLg", "pullMd", "pullSm", "pullXl", "pullXs", "push", "pushLg", "pushMd", "pushSm", "pushXl", "pushXs", "size", "sizeLg", "sizeMd", "sizeSm", "sizeXl", "sizeXs"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "size", "spellcheck", "step", "type", "value"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: IonModal, selector: "ion-modal" }, { kind: "component", type: IonDatetime, selector: "ion-datetime", inputs: ["cancelText", "clearText", "color", "dayValues", "disabled", "doneText", "firstDayOfWeek", "formatOptions", "highlightedDates", "hourCycle", "hourValues", "isDateEnabled", "locale", "max", "min", "minuteValues", "mode", "monthValues", "multiple", "name", "preferWheel", "presentation", "readonly", "showAdjacentDays", "showClearButton", "showDefaultButtons", "showDefaultTimeLabel", "showDefaultTitle", "size", "titleSelectedDatesFormatter", "value", "yearValues"] }, { kind: "component", type: IonSelectOption, selector: "ion-select-option", inputs: ["disabled", "value"] }, { kind: "component", type: IonSelect, selector: "ion-select", inputs: ["cancelText", "color", "compareWith", "disabled", "errorText", "expandedIcon", "fill", "helperText", "interface", "interfaceOptions", "justify", "label", "labelPlacement", "mode", "multiple", "name", "okText", "placeholder", "selectedText", "shape", "toggleIcon", "value"] }, { kind: "component", type: IonPopover, selector: "ion-popover" }] }); }
332
+ }
333
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: StartEndDatetimeFormComponent, decorators: [{
334
+ type: Component,
335
+ args: [{ selector: 'sneat-start-end-datetime-form', imports: [
336
+ ReactiveFormsModule,
337
+ FormsModule,
338
+ TimeSelectorComponent,
339
+ StartEndDatesRangeFormComponent,
340
+ SneatSelectAllOnFocusDirective,
341
+ IonAccordion,
342
+ IonAccordionGroup,
343
+ IonGrid,
344
+ IonRow,
345
+ IonCol,
346
+ IonItem,
347
+ IonInput,
348
+ IonLabel,
349
+ IonButtons,
350
+ IonButton,
351
+ IonIcon,
352
+ IonModal,
353
+ IonDatetime,
354
+ IonSelectOption,
355
+ IonSelect,
356
+ IonPopover,
357
+ ], template: "@switch (mode) {\n @case (\"recurring\") {\n <!-- TODO(help-wanted): use CSS class, preferably from Ionic -->\n <ion-grid class=\"ion-grid-layout\" style=\"border-top: 1px solid lightgray\">\n <ion-row>\n <ion-col size=\"12\" size-md=\"4\">\n <ion-item class=\"sneat-no-end-padding\" lines=\"none\">\n <ion-input\n type=\"time\"\n label=\"At\"\n #startTimeInput\n [formControl]=\"startTime\"\n (ionBlur)=\"onStartTimeBlur()\"\n (ionChange)=\"onStartTimeChanged()\"\n />\n @if (startTime.touched && !startTime.valid && !!startTime.errors) {\n <ion-label color=\"danger\" slot=\"end\"> Required field </ion-label>\n }\n <ion-buttons slot=\"end\" class=\"ion-no-margin ion-no-padding\">\n <ion-button id=\"quick-pick-start-time-recurring\" color=\"medium\">\n <!--\t\t\t<ion-label>Pick</ion-label>-->\n <ion-icon name=\"chevron-down-outline\" slot=\"end\" />\n </ion-button>\n <ion-modal trigger=\"quick-pick-start-time-recurring\">\n <ng-template>\n <sneat-time-selector (selected)=\"setStartTime($event)\" />\n </ng-template>\n </ion-modal>\n <!-- Commented out as does not fit into modal - we might want to show only on wide screens -->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\t*ngIf=\"startTime.value\"-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"addToStart({ hours: -1 })\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-icon name=\"chevron-back-outline\" slot=\"start\" />-->\n <!--\t\t\t\t\t\t<ion-label>-1h</ion-label>-->\n <!--\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\t*ngIf=\"startTime.value\"-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"addToStart({ hours: +1 })\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-label>+1h</ion-label>-->\n <!--\t\t\t\t\t\t<ion-icon name=\"chevron-forward-outline\" slot=\"end\" />-->\n <!--\t\t\t\t\t</ion-button>-->\n </ion-buttons>\n </ion-item>\n </ion-col>\n <ion-col size=\"12\" size-md=\"5\">\n <ion-item lines=\"none\">\n <ion-input\n #durationInput\n label=\"For\"\n [formControl]=\"duration\"\n (ionChange)=\"onDurationChanged()\"\n type=\"number\"\n style=\"text-align: right\"\n />\n <ion-select\n slot=\"end\"\n interface=\"popover\"\n [(ngModel)]=\"durationUnits\"\n >\n <ion-select-option value=\"minutes\">minutes</ion-select-option>\n <ion-select-option value=\"hours\">hours</ion-select-option>\n </ion-select>\n </ion-item>\n </ion-col>\n <ion-col size=\"12\" size-md=\"3\">\n <ion-item lines=\"none\">\n <ion-input\n type=\"time\"\n label=\"Ends at\"\n [formControl]=\"endTime\"\n (ionChange)=\"onEndTimeChanged()\"\n placeholder=\"HH:MM\"\n />\n </ion-item>\n </ion-col>\n </ion-row>\n </ion-grid>\n\n <!-- TODO(help-wanted): use CSS class, preferably from Ionic -->\n <ion-accordion-group\n style=\"\n border-top: 1px solid lightgray;\n border-bottom: 1px solid lightgray;\n \"\n >\n <ion-accordion value=\"dates\">\n <ion-item slot=\"header\" color=\"light\">\n <ion-label color=\"medium\">Dates (start & end)</ion-label>\n </ion-item>\n <sneat-start-end-dates-range-form\n slot=\"content\"\n [timing]=\"timing\"\n (timingChange)=\"onTimingChanged($event)\"\n />\n </ion-accordion>\n </ion-accordion-group>\n }\n @case (\"single\") {\n <ion-grid class=\"ion-grid-layout\">\n @if (!startDate.value || !startTime.value) {\n <ion-row>\n <ion-col size=\"12\" size-lg=\"5\">\n <ion-datetime\n [min]=\"today.toISOString().substring(0, 10)\"\n [max]=\"maxDate\"\n presentation=\"date\"\n [formControl]=\"startDate\"\n (ionChange)=\"onStartDateChanged()\"\n >\n <ion-buttons slot=\"buttons\">\n <ion-button\n color=\"medium\"\n (click)=\"setStartDate($event, 'today')\"\n >Today\n </ion-button>\n <ion-button\n color=\"medium\"\n (click)=\"setStartDate($event, 'tomorrow')\"\n >Tomorrow\n </ion-button>\n </ion-buttons>\n </ion-datetime>\n </ion-col>\n <ion-col size=\"12\" size-lg=\"7\">\n <sneat-time-selector\n [hideHeader]=\"true\"\n (selected)=\"startTime.setValue($event); onStartTimeChanged()\"\n />\n </ion-col>\n </ion-row>\n }\n @if (startDate.value && startTime.value) {\n <ion-row>\n <ion-col size=\"12\" size-sm=\"6\">\n <ion-item class=\"sneat-no-end-padding\">\n <ion-input\n label=\"On\"\n type=\"date\"\n [formControl]=\"startDate\"\n (ionChange)=\"onStartDateChanged()\"\n />\n <!--\t\t\t\t<ion-buttons-->\n <!--\t\t\t\t\tslot=\"end\"-->\n <!--\t\t\t\t\t*ngIf=\"!startDate?.value\"-->\n <!--\t\t\t\t\tclass=\"ion-no-margin ion-no-padding\"-->\n <!--\t\t\t\t>-->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"setStartDate($event, 'today')\"-->\n <!--\t\t\t\t\t\ttitle=\"Today\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-icon name=\"today-outline\" />-->\n <!--\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t\t<ion-button-->\n <!--\t\t\t\t\t\tvalue=\"tomorrow\"-->\n <!--\t\t\t\t\t\tcolor=\"medium\"-->\n <!--\t\t\t\t\t\t(click)=\"setStartDate($event, 'tomorrow')\"-->\n <!--\t\t\t\t\t>-->\n <!--\t\t\t\t\t\t<ion-label>+1D</ion-label>-->\n <!--\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t</ion-buttons>-->\n @if (startDate.value) {\n <ion-buttons slot=\"end\" class=\"ion-no-margin ion-no-padding\">\n <ion-button id=\"quick-pick-start-date\" color=\"medium\">\n <!--\t\t\t<ion-label>Pick</ion-label>-->\n <ion-icon name=\"chevron-down-outline\" slot=\"end\" />\n </ion-button>\n <ion-button color=\"medium\" (click)=\"addToStart({ days: -1 })\">\n <ion-icon name=\"chevron-back-outline\" slot=\"start\" />\n <ion-label>-1</ion-label>\n </ion-button>\n <ion-button color=\"medium\" (click)=\"addToStart({ days: +1 })\">\n <ion-label>+1</ion-label>\n <ion-icon name=\"chevron-forward-outline\" slot=\"end\" />\n </ion-button>\n <ion-popover\n trigger=\"quick-pick-start-date\"\n [dismissOnSelect]=\"true\"\n >\n <ng-template>\n <ion-item tappable (click)=\"setStartDate($event, 'today')\"\n >Today\n </ion-item>\n <ion-item\n tappable\n (click)=\"setStartDate($event, 'tomorrow')\"\n >Tomorrow\n </ion-item>\n <!--\t\t\t\t<ion-item-divider color=\"light\">Next week</ion-item-divider>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Monday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Tuesday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Wednesday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Thursday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Friday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Saturday</ion-item>-->\n <!--\t\t\t\t<ion-item><ion-text color=\"medium\">Next week -</ion-text> Sunday</ion-item>-->\n </ng-template>\n </ion-popover>\n </ion-buttons>\n }\n </ion-item>\n </ion-col>\n <ion-col size=\"12\" size-sm=\"6\">\n <ion-item class=\"sneat-no-end-padding\">\n <ion-input\n type=\"time\"\n label=\"At\"\n #startTimeInput\n [formControl]=\"startTime\"\n (ionBlur)=\"onStartTimeBlur()\"\n (ionChange)=\"onStartTimeChanged()\"\n />\n @if (\n startTime.touched && !startTime.valid && !!startTime.errors\n ) {\n <ion-label color=\"danger\" slot=\"end\">\n Required field\n </ion-label>\n }\n <ion-buttons slot=\"end\" class=\"ion-no-margin ion-no-padding\">\n <ion-button id=\"quick-pick-start-time-single\" color=\"medium\">\n <!--\t\t\t<ion-label>Pick</ion-label>-->\n <ion-icon name=\"chevron-down-outline\" slot=\"end\" />\n </ion-button>\n <ion-modal trigger=\"quick-pick-start-time-single\">\n <ng-template>\n <sneat-time-selector (selected)=\"setStartTime($event)\" />\n </ng-template>\n </ion-modal>\n @if (startTime.value) {\n <ion-button\n color=\"medium\"\n (click)=\"addToStart({ hours: -1 })\"\n >\n <ion-icon name=\"chevron-back-outline\" slot=\"start\" />\n <ion-label>-1h</ion-label>\n </ion-button>\n <ion-button\n color=\"medium\"\n (click)=\"addToStart({ hours: +1 })\"\n >\n <ion-label>+1h</ion-label>\n <ion-icon name=\"chevron-forward-outline\" slot=\"end\" />\n </ion-button>\n }\n </ion-buttons>\n </ion-item>\n </ion-col>\n </ion-row>\n }\n @if (startDate.value && startTime.value) {\n <ion-row>\n <ion-col size=\"12\" size-sm=\"6\">\n <ion-item lines=\"none\">\n <ion-input\n label=\"Duration\"\n sneatSelectAllOnFocus\n [formControl]=\"duration\"\n (ionChange)=\"onDurationChanged()\"\n type=\"number\"\n style=\"text-align: right\"\n />\n <ion-select\n slot=\"end\"\n interface=\"popover\"\n [(ngModel)]=\"durationUnits\"\n >\n <ion-select-option value=\"minutes\">minutes</ion-select-option>\n <ion-select-option value=\"hours\">hours</ion-select-option>\n </ion-select>\n </ion-item>\n </ion-col>\n <ion-col size=\"6\" size-sm=\"3\">\n <ion-item lines=\"none\">\n <ion-input\n type=\"time\"\n label=\"Ends at\"\n [formControl]=\"endTime\"\n (ionChange)=\"onEndTimeChanged()\"\n placeholder=\"HH:MM\"\n />\n </ion-item>\n </ion-col>\n <ion-col size=\"6\" size-sm=\"3\">\n <ion-button expand=\"full\" class=\"ion-margin\" (click)=\"addSlot()\"\n >{{ addSlotLabel }}\n </ion-button>\n </ion-col>\n </ion-row>\n }\n </ion-grid>\n }\n}\n" }]
358
+ }], ctorParameters: () => [], propDecorators: { addSlotLabel: [{
359
+ type: Input
360
+ }], mode: [{
361
+ type: Input,
362
+ args: [{ required: true }]
363
+ }], date: [{
364
+ type: Input,
365
+ args: [{ required: true }]
366
+ }], timing: [{
367
+ type: Input,
368
+ args: [{ required: true }]
369
+ }], timingChange: [{
370
+ type: Output
371
+ }], addClick: [{
372
+ type: Output
373
+ }], durationInput: [{
374
+ type: ViewChild,
375
+ args: ['durationInput']
376
+ }] } });
377
+ //# sourceMappingURL=start-end-datetime-form.component.js.map