@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,505 @@
1
+ import { Component, computed, EventEmitter, input, Input, Output, signal, ViewChild, inject, } from '@angular/core';
2
+ import { FormControl, FormsModule, ReactiveFormsModule, UntypedFormGroup, } from '@angular/forms';
3
+ import { IonButton, IonCheckbox, IonCol, IonGrid, IonIcon, IonItem, IonItemDivider, IonLabel, IonList, IonRow, IonSelect, IonSelectOption, IonSpinner, ModalController, } from '@ionic/angular/standalone';
4
+ import { ClassName, SelectFromListComponent } from '@sneat/ui';
5
+ import { emptyTiming, } from '@sneat/mod-schedulus-core';
6
+ import { newRandomId } from '@sneat/random';
7
+ import { StartEndDatetimeFormComponent } from '../start-end-datetime-form/start-end-datetime-form.component';
8
+ import { WeekdaysFormBase } from '../weekdays/weekdays-form-base';
9
+ import { HappeningService } from '../../services/happening.service';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@angular/forms";
12
+ /*
13
+ INTENTIONALLY not decoupling weekdays form (WeekdaysFormBase) into a separate component
14
+ as markup of the form is tightly coupled with the weekdays form
15
+ as weekend & weekdays checkboxes are in the header of the form
16
+ */
17
+ export class HappeningSlotFormComponent extends WeekdaysFormBase {
18
+ onMonthlyModeChanged(s) {
19
+ this.monthlyMode.set(s);
20
+ }
21
+ constructor() {
22
+ super(true);
23
+ this.modalCtrl = inject(ModalController);
24
+ this.happeningService = inject(HappeningService);
25
+ this.$happening = input.required(...(ngDevMode ? [{ debugName: "$happening" }] : []));
26
+ this.$happeningID = computed(() => this.$happening().id, ...(ngDevMode ? [{ debugName: "$happeningID" }] : []));
27
+ this.$happeningType = computed(() => this.$happening().brief?.type, ...(ngDevMode ? [{ debugName: "$happeningType" }] : []));
28
+ this.isToDo = false;
29
+ this.slotAdded = new EventEmitter();
30
+ this.happeningChange = new EventEmitter();
31
+ this.eventTimesChanged = new EventEmitter();
32
+ this.timing = emptyTiming;
33
+ this.error = signal('', ...(ngDevMode ? [{ debugName: "error" }] : []));
34
+ this.tab = 'when';
35
+ // minDate = '2000';
36
+ // maxDate = '' + (new Date().getFullYear() + 5);
37
+ this.repeatsOptions = [
38
+ // { id: 'daily', title: 'Daily' }, // Daily does not make much sense, weekly covers it
39
+ { id: 'weekly', title: 'Weekly' },
40
+ { id: 'monthly', title: 'Monthly' },
41
+ { id: 'yearly', title: 'Yearly' },
42
+ ];
43
+ this.monthlyMode = signal('', ...(ngDevMode ? [{ debugName: "monthlyMode" }] : []));
44
+ this.monthlyDate = signal(0, ...(ngDevMode ? [{ debugName: "monthlyDate" }] : []));
45
+ this.numberOfDaysInMonth = 28;
46
+ this.isUpdating = signal(false, ...(ngDevMode ? [{ debugName: "isUpdating" }] : []));
47
+ this.monthlyModes = [
48
+ { id: 'monthly-day', title: 'Specific day' },
49
+ { id: 'monthly-week-1', title: 'First week' },
50
+ { id: 'monthly-week-2', title: 'Second week' },
51
+ { id: 'monthly-week-3', title: 'Third week' },
52
+ { id: 'monthly-week-4', title: 'Fourth week' },
53
+ { id: 'monthly-week-last', title: 'Last week' },
54
+ ];
55
+ this.slotForm = new UntypedFormGroup({
56
+ locationTitle: new FormControl(''),
57
+ locationAddress: new FormControl(''),
58
+ });
59
+ this.repeats = signal(undefined, ...(ngDevMode ? [{ debugName: "repeats" }] : []));
60
+ this.showWeekdays = computed(() =>
61
+ // this.happens() === 'daily' ||
62
+ this.repeats() === 'weekly' ||
63
+ (this.repeats() === 'monthly' &&
64
+ this.monthlyMode()?.startsWith('monthly-week')), ...(ngDevMode ? [{ debugName: "showWeekdays" }] : []));
65
+ this.showTimeForm = computed(() => {
66
+ const happens = this.repeats();
67
+ const monthlyMode = this.monthlyMode();
68
+ const monthlyDate = this.monthlyDate();
69
+ const hasWeekdaySelected = this.hasWeekdaySelected();
70
+ return (this.$happeningType() === 'single' ||
71
+ // happens === 'daily' ||
72
+ (happens === 'weekly' && hasWeekdaySelected) ||
73
+ (happens === 'monthly' &&
74
+ ((monthlyMode === 'monthly-day' && !!monthlyDate) ||
75
+ (monthlyMode.includes('week') && hasWeekdaySelected))));
76
+ }, ...(ngDevMode ? [{ debugName: "showTimeForm" }] : []));
77
+ this.showAddSlotButton = computed(() => {
78
+ const happens = this.repeats();
79
+ const monthlyMode = this.monthlyMode();
80
+ const monthlyDate = this.monthlyDate();
81
+ return (
82
+ // happens === 'daily' ||
83
+ (happens === 'weekly' && this.hasWeekdaySelected()) ||
84
+ (happens === 'monthly' && monthlyMode === 'monthly-day' && !!monthlyDate));
85
+ }, ...(ngDevMode ? [{ debugName: "showAddSlotButton" }] : []));
86
+ this.yearlyMonth = new FormControl(undefined);
87
+ this.monthDays = [
88
+ [1, 2, 3, 4, 5],
89
+ [6, 7, 8, 9, 10],
90
+ [11, 12, 13, 14, 15],
91
+ [16, 17, 18, 19, 20],
92
+ [21, 22, 23, 24, 25],
93
+ [26, 27, 28, 29, 30, 31],
94
+ ];
95
+ this.months = [
96
+ 'January',
97
+ 'February',
98
+ 'March',
99
+ 'April',
100
+ 'May',
101
+ 'June',
102
+ 'July',
103
+ 'August',
104
+ 'September',
105
+ 'October',
106
+ 'November',
107
+ 'December',
108
+ ];
109
+ // const now = new Date();
110
+ const preselectedWd = window.history.state?.wd;
111
+ if (preselectedWd) {
112
+ this.weekdayById[preselectedWd].set(true);
113
+ }
114
+ // this.weekdaysForm.valueChanges.pipe(takeUntil(this.destroyed$)).subscribe({
115
+ // next: () => (this.error = undefined),
116
+ // });
117
+ }
118
+ // ngOnChanges(changes: SimpleChanges): void {
119
+ // if (this.wd) {
120
+ // this.weekdayById[this.wd]?.setValue(true);
121
+ // }
122
+ // }
123
+ // dismissModal(): void {
124
+ // this.modalCtrl
125
+ // .dismiss()
126
+ // .catch(this.errorLogger.logErrorHandler('failed to dismiss modal'));
127
+ // }
128
+ onRepeatsChanged(value) {
129
+ this.repeats.set(value);
130
+ }
131
+ addOnceSlot(timing) {
132
+ this.slotForm.markAsTouched();
133
+ const slot = this.initiateSlot(timing);
134
+ return slot;
135
+ }
136
+ addWeeklySlot(timing) {
137
+ // this.weekdaysForm.markAsTouched({ onlySelf: true });
138
+ this.slotForm.markAsTouched();
139
+ if (this.$happeningType() === 'recurring' && !this.hasWeekdaySelected()) {
140
+ this.error.set('At least 1 weekday should be selected');
141
+ }
142
+ if (!this.startEndDatetimeForm?.isValid) {
143
+ return undefined;
144
+ }
145
+ // if (!this.weekdaysForm.valid) {
146
+ // this.showWeekday = false;
147
+ //
148
+ // this.alertCtrl.create({
149
+ // header: 'Please select day(s)',
150
+ // inputs: wd2.map(wd => {
151
+ // // tslint:disable-next-line:no-any
152
+ // const result: { type: 'checkbox'; name: WeekdayCode2; value: WeekdayCode2; label: string; handler: (input: any) => void } = {
153
+ // type: 'checkbox',
154
+ // name: wd,
155
+ // value: wd,
156
+ // label: wdCodeToWeekdayLongName(wd),
157
+ // handler: input => {
158
+ // const v = this.weekdaysForm.get(wd);
159
+ // if (v) {
160
+ // v.setValue(input.checked);
161
+ // } else {
162
+ // console.error('!v', v);
163
+ // }
164
+ // console.log(input);
165
+ // },
166
+ // };
167
+ // return result;
168
+ // }),
169
+ // buttons: [
170
+ // {
171
+ // text: 'OK',
172
+ // handler: () => {
173
+ // this.showWeekday = true;
174
+ // if (this.weekdaysForm.valid) {
175
+ // this.addSlot();
176
+ // }
177
+ // },
178
+ // },
179
+ // {
180
+ // text: 'Cancel',
181
+ // handler: () => {
182
+ // this.showWeekday = true;
183
+ // },
184
+ // }],
185
+ // })
186
+ // .then(alert => {
187
+ // alert.present()
188
+ // .catch(this.errorLogger.logErrorHandler('failed to present alert'));
189
+ // })
190
+ // .then(value => {
191
+ // console.log('Alert value:', value);
192
+ // })
193
+ // .catch(this.errorLogger.logErrorHandler('failed to create an alert'));
194
+ // return;
195
+ // }
196
+ if (!this.slotForm.valid) {
197
+ return undefined;
198
+ }
199
+ const formValue = this.slotForm.value;
200
+ if (!this.timing) {
201
+ throw new Error('!this.timing');
202
+ }
203
+ let slot = this.initiateSlot(timing);
204
+ if (this.$happeningType() === 'recurring') {
205
+ slot = {
206
+ ...slot,
207
+ weekdays: this.selectedWeekdayCodes(),
208
+ };
209
+ }
210
+ if (formValue.locationTitle || formValue.locationAddress) {
211
+ let l = {};
212
+ slot = { ...slot, location: l };
213
+ if (formValue.locationTitle) {
214
+ l = { ...l, title: formValue.locationTitle };
215
+ }
216
+ if (formValue.locationAddress) {
217
+ l = { ...l, address: formValue.locationAddress };
218
+ }
219
+ slot = { ...slot, location: l };
220
+ }
221
+ return slot;
222
+ }
223
+ initiateSlot(timing) {
224
+ const repeats = this.$happeningType() === 'single' ? 'once' : this.repeats();
225
+ if (!repeats) {
226
+ throw new Error('!repeats');
227
+ }
228
+ return {
229
+ ...(timing || this.timing),
230
+ repeats,
231
+ };
232
+ }
233
+ setYearlyMonth(month) {
234
+ this.yearlyMonth.setValue(month);
235
+ switch (this.yearlyMonth.value) {
236
+ case 'February':
237
+ this.numberOfDaysInMonth = 28;
238
+ break;
239
+ case 'January':
240
+ case 'March':
241
+ case 'May':
242
+ case 'July':
243
+ case 'August':
244
+ case 'October':
245
+ case 'December':
246
+ this.numberOfDaysInMonth = 31;
247
+ break;
248
+ case 'April':
249
+ case 'June':
250
+ case 'September':
251
+ case 'November':
252
+ this.numberOfDaysInMonth = 30;
253
+ break;
254
+ }
255
+ }
256
+ setMonthlyDay(day) {
257
+ this.monthlyDate.set(day);
258
+ }
259
+ addDaySlot() {
260
+ const day = this.monthlyDate();
261
+ let slot = {
262
+ repeats: 'monthly',
263
+ };
264
+ switch (this.repeats()) {
265
+ case 'monthly':
266
+ slot = { ...slot, day };
267
+ break;
268
+ case 'yearly':
269
+ if (!this.yearlyMonth.value) {
270
+ return;
271
+ }
272
+ slot = { ...slot, day, month: this.yearlyMonth.value };
273
+ break;
274
+ }
275
+ return slot;
276
+ }
277
+ addSlotToHappening(timing) {
278
+ if (!this.$happening().brief) {
279
+ throw new Error('!this.happening?.brief');
280
+ }
281
+ const slot = this.getSlot(timing);
282
+ if (!slot) {
283
+ return;
284
+ }
285
+ const slotID = this.generateSlotID();
286
+ let happening = this.$happening();
287
+ if (!happening.brief) {
288
+ return;
289
+ }
290
+ happening = {
291
+ ...happening,
292
+ brief: {
293
+ ...happening.brief,
294
+ slots: { ...happening.brief?.slots, [slotID]: slot },
295
+ },
296
+ };
297
+ this.slotAdded.emit(slot);
298
+ this.happeningChange.emit(happening);
299
+ }
300
+ addYearlySlot() {
301
+ return {
302
+ repeats: 'yearly',
303
+ // day: ['may-21'],
304
+ };
305
+ }
306
+ addMonthlySlot(_timing) {
307
+ if (this.monthlyMode() === 'monthly-day') {
308
+ return this.addDaySlot();
309
+ }
310
+ return undefined;
311
+ }
312
+ saveChanges() {
313
+ const slot = this.getSlot();
314
+ const happening = this.$happening();
315
+ const spaceID = happening.space.id;
316
+ const happeningID = happening.id;
317
+ if (!spaceID || !happeningID || !slot) {
318
+ return;
319
+ }
320
+ let id = this.slot?.id;
321
+ const isNewSlot = !id;
322
+ const putSlot = isNewSlot
323
+ ? this.happeningService.addSlot
324
+ : this.date
325
+ ? (spaceID, happeningID, slot) => this.happeningService.adjustSlot(spaceID, happeningID, slot, this.date || '')
326
+ : this.happeningService.updateSlot;
327
+ if (!id) {
328
+ id = this.generateSlotID();
329
+ }
330
+ this.isUpdating.set(true);
331
+ putSlot(spaceID, happeningID, { ...slot, id }).subscribe({
332
+ next: () => {
333
+ this.modalCtrl
334
+ .dismiss()
335
+ .catch(this.errorLogger.logErrorHandler('failed to dismiss modal'));
336
+ },
337
+ error: (err) => {
338
+ this.errorLogger.logError(err, 'failed to update happening slot');
339
+ this.isUpdating.set(false);
340
+ },
341
+ });
342
+ }
343
+ applyChanges() {
344
+ if (this.slot) {
345
+ this.saveChanges();
346
+ }
347
+ else {
348
+ this.addSlot();
349
+ }
350
+ }
351
+ addSlot(_timing) {
352
+ if (this.$happeningID()) {
353
+ this.saveChanges();
354
+ }
355
+ else {
356
+ this.addSlotToHappening();
357
+ }
358
+ }
359
+ generateSlotID() {
360
+ for (let i = 0; i < 10; i++) {
361
+ const slotID = newRandomId({ len: 4 });
362
+ if (!this.$happening().brief?.slots?.[slotID]) {
363
+ return slotID;
364
+ }
365
+ }
366
+ throw new Error('failed to generate unique slot ID');
367
+ }
368
+ getSlot(timing) {
369
+ switch (this.$happeningType()) {
370
+ case 'single':
371
+ return this.addOnceSlot(timing);
372
+ case 'recurring': {
373
+ const repeats = this.repeats();
374
+ switch (repeats) {
375
+ case 'weekly':
376
+ return this.addWeeklySlot(timing);
377
+ case 'monthly':
378
+ return this.addMonthlySlot(timing);
379
+ case 'yearly':
380
+ return this.addYearlySlot();
381
+ case undefined:
382
+ default:
383
+ throw new Error(`unknown repeats=[${repeats}]`);
384
+ }
385
+ }
386
+ case undefined:
387
+ throw new Error('happeningType is undefined');
388
+ }
389
+ }
390
+ // onTimeStartsChanged(event: Event): void {
391
+ // const { detail } = (event as CustomEvent);
392
+ // const startInMinutes = ionTimeToMinutes(detail.value);
393
+ // const durationInMinutes = ionTimeToMinutes(this.timeDuration.value);
394
+ // const endInISO = minutesToIonTime(startInMinutes + durationInMinutes);
395
+ // // console.log(startInMinutes, durationInMinutes, endInISO, 'timeEnds.value:', timeEnds.value);
396
+ // if (this.timeEnds.value !== endInISO) {
397
+ // this.timeEnds.setValue(endInISO);
398
+ // this.onEventTimesChanged();
399
+ // }
400
+ // }
401
+ //
402
+ // onTimeDurationChanged(): void {
403
+ // const startInMinutes = ionTimeToMinutes(this.timeStarts.value);
404
+ // const durationInMinutes = ionTimeToMinutes(this.timeDuration.value);
405
+ // const endInISO = minutesToIonTime(startInMinutes + durationInMinutes);
406
+ // // console.log(startInMinutes, durationInMinutes, endInISO, 'timeEnds.value:', timeEnds.value);
407
+ // if (this.timeEnds.value !== endInISO) {
408
+ // this.timeEnds.setValue(endInISO);
409
+ // this.onEventTimesChanged();
410
+ // }
411
+ // }
412
+ //
413
+ // onTimeEndsChanged(/*event: CustomEvent*/): void {
414
+ // const startInMinutes = ionTimeToMinutes(this.timeStarts.value);
415
+ // const endInMinutes = ionTimeToMinutes(this.timeEnds.value);
416
+ // const durationInISO = minutesToIonTime(endInMinutes - startInMinutes);
417
+ // // console.log(startInMinutes, durationInISO, endInMinutes, 'timeDuration.value:', timeDuration.value);
418
+ // if (this.timeDuration.value !== durationInISO) {
419
+ // this.timeDuration.setValue(durationInISO);
420
+ // }
421
+ // this.onEventTimesChanged();
422
+ // }
423
+ onEventTimesChanged() {
424
+ if (!this.date) {
425
+ return;
426
+ }
427
+ // const timestamp = (c: FormControl): number => isoStringsToDate(this.date, c.value)
428
+ // .getTime();
429
+ this.eventTimesChanged.emit(this.timing);
430
+ }
431
+ onTimingChanged(timing) {
432
+ this.timing = timing;
433
+ }
434
+ ngOnChanges(changes) {
435
+ if (changes['wd']) {
436
+ const wd = this.wd;
437
+ if (wd) {
438
+ this.weekdayById[wd].set(true);
439
+ }
440
+ }
441
+ if (changes['slot']) {
442
+ const slot = this.slot;
443
+ if (slot) {
444
+ if (slot.repeats !== 'once' && slot.repeats !== 'UNKNOWN') {
445
+ this.repeats.set(slot?.repeats);
446
+ }
447
+ slot.weekdays?.forEach((wd) => {
448
+ this.weekdayById[wd].set(true);
449
+ });
450
+ this.timing = slot;
451
+ }
452
+ }
453
+ }
454
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: HappeningSlotFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
455
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.0", type: HappeningSlotFormComponent, isStandalone: true, selector: "sneat-happening-slot-form", inputs: { $happening: { classPropertyName: "$happening", publicName: "$happening", isSignal: true, isRequired: true, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: false, isRequired: true, transformFunction: null }, slot: { classPropertyName: "slot", publicName: "slot", isSignal: false, isRequired: false, transformFunction: null }, wd: { classPropertyName: "wd", publicName: "wd", isSignal: false, isRequired: false, transformFunction: null }, date: { classPropertyName: "date", publicName: "date", isSignal: false, isRequired: false, transformFunction: null }, isToDo: { classPropertyName: "isToDo", publicName: "isToDo", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { slotAdded: "slotAdded", happeningChange: "happeningChange", eventTimesChanged: "eventTimesChanged" }, providers: [
456
+ { provide: ClassName, useValue: 'RecurringSlotFormComponent' },
457
+ HappeningService,
458
+ ], viewQueries: [{ propertyName: "startEndDatetimeForm", first: true, predicate: ["startEndDatetimeForm"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!--wd: {{ wd }}; date: {{date}}-->\n<!--<ion-item-divider color=\"primary\" class=\"sneat-no-end-padding\" *ngIf=\"mode === 'modal'\">-->\n<!--\t<ion-label style=\"font-weight: bold\">New slot</ion-label>-->\n<!--\t<ion-buttons slot=\"end\" class=\"sneat-no-end-margin\">-->\n<!--\t\t<ion-button title=\"Cancel\" (click)=\"dismissModal()\">-->\n<!--\t\t\t<ion-label color=\"light\">Cancel</ion-label>-->\n<!--\t\t\t<ion-icon name=\"close-outline\" slot=\"end\" />-->\n<!--\t\t</ion-button>-->\n<!--\t</ion-buttons>-->\n<!--</ion-item-divider>-->\n<!--<ion-item *ngIf=\"happeningType === 'single'\">-->\n<!--\t<ion-label *ngIf=\"isToDo && !date\">Due</ion-label>-->\n<!--\t<ion-label *ngIf=\"isToDo && date\">Due on</ion-label>-->\n<!--\t<ion-label *ngIf=\"!isToDo\">Takes place on</ion-label>-->\n<!--\t<ion-datetime [min]=\"minDate\" [max]=\"maxDate\" [(ngModel)]=\"date\"-->\n<!--\t\t\t\t\t\t\t\t(ionChange)=\"onEventTimesChanged()\"></ion-datetime>-->\n<!--</ion-item>-->\n\n<!--<ion-item-divider color=\"light\">-->\n<!--\t<ion-segment [(ngModel)]=\"tab\" color=\"dark\">-->\n<!--\t\t<ion-segment-button value=\"when\">-->\n<!--\t\t\t<ion-label>When</ion-label>-->\n<!--\t\t</ion-segment-button>-->\n<!--\t\t<ion-segment-button value=\"where\">-->\n<!--\t\t\t<ion-label>Where</ion-label>-->\n<!--\t\t</ion-segment-button>-->\n<!--\t</ion-segment>-->\n<!--</ion-item-divider>-->\n\n@if ($happeningType() === \"recurring\") {\n @if (repeats()) {\n <ion-grid class=\"ion-grid-layout\">\n <ion-row>\n <ion-col>\n <ion-item color=\"light\" lines=\"full\">\n <ion-select\n label=\"Repeats\"\n interface=\"popover\"\n [value]=\"repeats()\"\n (ionChange)=\"onRepeatsChanged($event.detail.value)\"\n >\n @for (repeatOption of repeatsOptions; track repeatOption.id) {\n <ion-select-option [value]=\"repeatOption.id\">\n {{ repeatOption.title }}\n </ion-select-option>\n }\n </ion-select>\n </ion-item>\n </ion-col>\n @if (showWeekdays()) {\n <ion-col>\n <ion-item color=\"light\" lines=\"full\">\n <ion-checkbox\n color=\"medium\"\n labelPlacement=\"end\"\n slot=\"end\"\n [checked]=\"weekdaysCheckbox()\"\n (ionChange)=\"onWeekdaysCheckboxChange($event.detail.checked)\"\n >\n <ion-label color=\"medium\">W-days</ion-label>\n </ion-checkbox>\n <ion-checkbox\n color=\"medium\"\n labelPlacement=\"end\"\n slot=\"end\"\n [checked]=\"weekendCheckbox()\"\n (ionChange)=\"onWeekendCheckboxChange($event.detail.checked)\"\n >\n <ion-label color=\"medium\">W-end</ion-label>\n </ion-checkbox>\n </ion-item>\n </ion-col>\n }\n </ion-row>\n </ion-grid>\n } @else {\n <sneat-select-from-list\n label=\"Repeats\"\n listLabelColor=\"light\"\n [value]=\"repeats() || ''\"\n [items]=\"repeatsOptions\"\n [isReadonly]=\"!!date\"\n (valueChange)=\"onRepeatsChanged($event)\"\n labelPlacement=\"end\"\n listLabel=\"divider\"\n justify=\"start\"\n />\n }\n\n @if (repeats() === \"monthly\") {\n <!--\t\t<ion-item-divider>-->\n <!--\t\t\t<ion-label>On</ion-label>-->\n <!--\t\t</ion-item-divider>-->\n <sneat-select-from-list\n label=\"On\"\n [value]=\"monthlyMode()\"\n [items]=\"monthlyModes\"\n [isReadonly]=\"!!date\"\n (valueChange)=\"onMonthlyModeChanged($event)\"\n labelPlacement=\"end\"\n listLabel=\"divider\"\n justify=\"start\"\n />\n }\n\n @if (showWeekdays()) {\n @if (!hasWeekdaySelected()) {\n <ion-item-divider> Choose day of the week </ion-item-divider>\n }\n <form>\n <ion-grid class=\"ion-grid-layout\">\n <ion-row>\n <ion-col size=\"4\">\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"mo\"\n [checked]=\"weekdayMo()\"\n (ionChange)=\"onWeekdayChanged('mo', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Monday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"tu\"\n [checked]=\"weekdayTu()\"\n (ionChange)=\"onWeekdayChanged('tu', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Tuesday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"we\"\n [checked]=\"weekdayWe()\"\n (ionChange)=\"onWeekdayChanged('we', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Wednesday\n </ion-checkbox>\n </ion-item>\n </ion-col>\n <ion-col size=\"4\">\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"th\"\n [checked]=\"weekdayTh()\"\n (ionChange)=\"onWeekdayChanged('th', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Thursday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"fr\"\n [checked]=\"weekdayFr()\"\n (ionChange)=\"onWeekdayChanged('fr', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Friday\n </ion-checkbox>\n </ion-item>\n </ion-col>\n <ion-col size=\"4\">\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"sa\"\n [checked]=\"weekdaySa()\"\n (ionChange)=\"onWeekdayChanged('sa', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Saturday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"su\"\n [checked]=\"weekdaySu()\"\n (ionChange)=\"onWeekdayChanged('su', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Sunday\n </ion-checkbox>\n </ion-item>\n </ion-col>\n </ion-row>\n </ion-grid>\n </form>\n }\n @if (repeats() === \"yearly\") {\n @if (yearlyMonth) {\n <ion-item>\n <ion-select\n label=\"Month\"\n interface=\"popover\"\n [formControl]=\"yearlyMonth\"\n (ionChange)=\"setYearlyMonth($event.detail.value)\"\n >\n @for (month of months; track month) {\n <ion-select-option [value]=\"month\">{{ month }}</ion-select-option>\n }\n </ion-select>\n </ion-item>\n } @else {\n <ion-item-divider>Select month</ion-item-divider>\n <ion-item>\n @for (month of months; track month) {\n <ion-button\n class=\"ion-margin-end\"\n color=\"light\"\n (click)=\"setYearlyMonth(month)\"\n >{{ month }}\n </ion-button>\n }\n </ion-item>\n }\n }\n\n @if (\n (repeats() === \"monthly\" && monthlyMode() === \"monthly-day\") ||\n (repeats() === \"yearly\" && yearlyMonth.value)\n ) {\n <ion-item-divider>Choose date</ion-item-divider>\n <ion-grid>\n @for (daysRow of monthDays; let rowIndex = $index; track rowIndex) {\n <ion-row>\n @for (day of daysRow; track day) {\n <ion-col size=\"2\">\n <ion-button color=\"light\" (click)=\"setMonthlyDay(day)\"\n >{{ day }}\n </ion-button>\n </ion-col>\n }\n </ion-row>\n }\n <!--\t\t\t<ion-row>-->\n <!--\t\t\t\t@for (i of [].constructor(numberOfDaysInMonth - 25); track i) {-->\n <!--\t\t\t\t\t<ion-col size=\"2\">-->\n <!--\t\t\t\t\t\t<ion-button color=\"light\" (click)=\"setMonthlyDay($index + 25 + 1)\"-->\n <!--\t\t\t\t\t\t\t>{{ $index + 25 + 1 }}-->\n <!--\t\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t\t</ion-col>-->\n <!--\t\t\t\t}-->\n <!--\t\t\t</ion-row>-->\n </ion-grid>\n }\n}\n\n@if (showTimeForm()) {\n <!--\t<ion-item-divider color=\"light\">-->\n <!--\t\t<ion-label>When</ion-label>-->\n <!--\t</ion-item-divider>-->\n <!--\t\t<ion-item-divider color=\"light\">When</ion-item-divider>-->\n <sneat-start-end-datetime-form\n #startEndDatetimeForm\n [date]=\"date\"\n [mode]=\"$happeningType()\"\n [timing]=\"timing\"\n addSlotLabel=\"Add slot\"\n (timingChange)=\"onTimingChanged($event)\"\n (addClick)=\"addSlot($event)\"\n />\n}\n\n<!--\t\t\t<ion-item-divider color=\"light\">Where</ion-item-divider>-->\n<!--\t\t\t<ion-item class=\"ion-padding-start\">-->\n<!--\t\t\t\t<ion-textarea label=\"Address / room / directions\" labelPlacement=\"stacked\"></ion-textarea>-->\n<!--\t\t\t</ion-item>-->\n\n<!-- @if (\"tab === 'where'\") { -->\n<!--\t<ion-item-divider color=\"light\">Where</ion-item-divider>-->\n<!--\t<ion-item>-->\n<!--\t\t<ion-label position=\"floating\">Address / room / directions</ion-label>-->\n<!--\t\t<ion-textarea></ion-textarea>-->\n<!--\t</ion-item>-->\n<!-- }-->\n\n<!--<ng-container *ngIf=\"tab === 'when'\">-->\n\n<!--</ng-container>-->\n\n<!--happeningType: {{happeningType}}, happens: {{happens}};-->\n\n@if (error() || showAddSlotButton()) {\n <ion-list lines=\"none\">\n @if (error()) {\n <ion-item>\n <ion-label color=\"danger\">{{ error() }}</ion-label>\n </ion-item>\n }\n\n @if (showAddSlotButton()) {\n <ion-item>\n <ion-button\n slot=\"end\"\n color=\"primary\"\n [disabled]=\"isUpdating()\"\n (click)=\"applyChanges()\"\n size=\"medium\"\n >\n @if (slot) {\n <ion-icon name=\"save-outline\" slot=\"start\" />\n <ion-label>Update slot</ion-label>\n } @else {\n <ion-icon name=\"add-outline\" slot=\"start\" />\n <ion-label>Add slot</ion-label>\n }\n @if (isUpdating()) {\n <ion-spinner name=\"lines-small\" slot=\"end\"></ion-spinner>\n }\n </ion-button>\n </ion-item>\n }\n </ion-list>\n}\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],[formArray],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]):not([formArray]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: SelectFromListComponent, selector: "sneat-select-from-list", inputs: ["value", "filterLabel", "label", "listLabel", "listLabelColor", "isFilterable", "isLoading", "items", "items$", "lastItemLines", "labelPlacement", "justify", "other", "canAdd", "filterItem", "selectMode", "isReadonly", "$isProcessing", "sortBy"], outputs: ["valueChange", "filterChanged"] }, { kind: "component", type: StartEndDatetimeFormComponent, selector: "sneat-start-end-datetime-form", inputs: ["addSlotLabel", "mode", "date", "timing"], outputs: ["timingChange", "addClick"] }, { 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: 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: IonSelectOption, selector: "ion-select-option", inputs: ["disabled", "value"] }, { kind: "component", type: IonCheckbox, selector: "ion-checkbox", inputs: ["checked", "color", "disabled", "errorText", "helperText", "indeterminate", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: IonItemDivider, selector: "ion-item-divider", inputs: ["color", "mode", "sticky"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { 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: IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
459
+ }
460
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.0", ngImport: i0, type: HappeningSlotFormComponent, decorators: [{
461
+ type: Component,
462
+ args: [{ imports: [
463
+ FormsModule,
464
+ ReactiveFormsModule,
465
+ SelectFromListComponent,
466
+ StartEndDatetimeFormComponent,
467
+ IonGrid,
468
+ IonRow,
469
+ IonCol,
470
+ IonItem,
471
+ IonSelect,
472
+ IonSelectOption,
473
+ IonCheckbox,
474
+ IonItemDivider,
475
+ IonList,
476
+ IonLabel,
477
+ IonButton,
478
+ IonSpinner,
479
+ IonIcon,
480
+ ], providers: [
481
+ { provide: ClassName, useValue: 'RecurringSlotFormComponent' },
482
+ HappeningService,
483
+ ], selector: 'sneat-happening-slot-form', template: "<!--wd: {{ wd }}; date: {{date}}-->\n<!--<ion-item-divider color=\"primary\" class=\"sneat-no-end-padding\" *ngIf=\"mode === 'modal'\">-->\n<!--\t<ion-label style=\"font-weight: bold\">New slot</ion-label>-->\n<!--\t<ion-buttons slot=\"end\" class=\"sneat-no-end-margin\">-->\n<!--\t\t<ion-button title=\"Cancel\" (click)=\"dismissModal()\">-->\n<!--\t\t\t<ion-label color=\"light\">Cancel</ion-label>-->\n<!--\t\t\t<ion-icon name=\"close-outline\" slot=\"end\" />-->\n<!--\t\t</ion-button>-->\n<!--\t</ion-buttons>-->\n<!--</ion-item-divider>-->\n<!--<ion-item *ngIf=\"happeningType === 'single'\">-->\n<!--\t<ion-label *ngIf=\"isToDo && !date\">Due</ion-label>-->\n<!--\t<ion-label *ngIf=\"isToDo && date\">Due on</ion-label>-->\n<!--\t<ion-label *ngIf=\"!isToDo\">Takes place on</ion-label>-->\n<!--\t<ion-datetime [min]=\"minDate\" [max]=\"maxDate\" [(ngModel)]=\"date\"-->\n<!--\t\t\t\t\t\t\t\t(ionChange)=\"onEventTimesChanged()\"></ion-datetime>-->\n<!--</ion-item>-->\n\n<!--<ion-item-divider color=\"light\">-->\n<!--\t<ion-segment [(ngModel)]=\"tab\" color=\"dark\">-->\n<!--\t\t<ion-segment-button value=\"when\">-->\n<!--\t\t\t<ion-label>When</ion-label>-->\n<!--\t\t</ion-segment-button>-->\n<!--\t\t<ion-segment-button value=\"where\">-->\n<!--\t\t\t<ion-label>Where</ion-label>-->\n<!--\t\t</ion-segment-button>-->\n<!--\t</ion-segment>-->\n<!--</ion-item-divider>-->\n\n@if ($happeningType() === \"recurring\") {\n @if (repeats()) {\n <ion-grid class=\"ion-grid-layout\">\n <ion-row>\n <ion-col>\n <ion-item color=\"light\" lines=\"full\">\n <ion-select\n label=\"Repeats\"\n interface=\"popover\"\n [value]=\"repeats()\"\n (ionChange)=\"onRepeatsChanged($event.detail.value)\"\n >\n @for (repeatOption of repeatsOptions; track repeatOption.id) {\n <ion-select-option [value]=\"repeatOption.id\">\n {{ repeatOption.title }}\n </ion-select-option>\n }\n </ion-select>\n </ion-item>\n </ion-col>\n @if (showWeekdays()) {\n <ion-col>\n <ion-item color=\"light\" lines=\"full\">\n <ion-checkbox\n color=\"medium\"\n labelPlacement=\"end\"\n slot=\"end\"\n [checked]=\"weekdaysCheckbox()\"\n (ionChange)=\"onWeekdaysCheckboxChange($event.detail.checked)\"\n >\n <ion-label color=\"medium\">W-days</ion-label>\n </ion-checkbox>\n <ion-checkbox\n color=\"medium\"\n labelPlacement=\"end\"\n slot=\"end\"\n [checked]=\"weekendCheckbox()\"\n (ionChange)=\"onWeekendCheckboxChange($event.detail.checked)\"\n >\n <ion-label color=\"medium\">W-end</ion-label>\n </ion-checkbox>\n </ion-item>\n </ion-col>\n }\n </ion-row>\n </ion-grid>\n } @else {\n <sneat-select-from-list\n label=\"Repeats\"\n listLabelColor=\"light\"\n [value]=\"repeats() || ''\"\n [items]=\"repeatsOptions\"\n [isReadonly]=\"!!date\"\n (valueChange)=\"onRepeatsChanged($event)\"\n labelPlacement=\"end\"\n listLabel=\"divider\"\n justify=\"start\"\n />\n }\n\n @if (repeats() === \"monthly\") {\n <!--\t\t<ion-item-divider>-->\n <!--\t\t\t<ion-label>On</ion-label>-->\n <!--\t\t</ion-item-divider>-->\n <sneat-select-from-list\n label=\"On\"\n [value]=\"monthlyMode()\"\n [items]=\"monthlyModes\"\n [isReadonly]=\"!!date\"\n (valueChange)=\"onMonthlyModeChanged($event)\"\n labelPlacement=\"end\"\n listLabel=\"divider\"\n justify=\"start\"\n />\n }\n\n @if (showWeekdays()) {\n @if (!hasWeekdaySelected()) {\n <ion-item-divider> Choose day of the week </ion-item-divider>\n }\n <form>\n <ion-grid class=\"ion-grid-layout\">\n <ion-row>\n <ion-col size=\"4\">\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"mo\"\n [checked]=\"weekdayMo()\"\n (ionChange)=\"onWeekdayChanged('mo', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Monday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"tu\"\n [checked]=\"weekdayTu()\"\n (ionChange)=\"onWeekdayChanged('tu', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Tuesday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"we\"\n [checked]=\"weekdayWe()\"\n (ionChange)=\"onWeekdayChanged('we', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Wednesday\n </ion-checkbox>\n </ion-item>\n </ion-col>\n <ion-col size=\"4\">\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"th\"\n [checked]=\"weekdayTh()\"\n (ionChange)=\"onWeekdayChanged('th', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Thursday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"fr\"\n [checked]=\"weekdayFr()\"\n (ionChange)=\"onWeekdayChanged('fr', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Friday\n </ion-checkbox>\n </ion-item>\n </ion-col>\n <ion-col size=\"4\">\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"sa\"\n [checked]=\"weekdaySa()\"\n (ionChange)=\"onWeekdayChanged('sa', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Saturday\n </ion-checkbox>\n </ion-item>\n <ion-item lines=\"none\">\n <ion-checkbox\n slot=\"start\"\n value=\"su\"\n [checked]=\"weekdaySu()\"\n (ionChange)=\"onWeekdayChanged('su', $event.detail.checked)\"\n labelPlacement=\"end\"\n >Sunday\n </ion-checkbox>\n </ion-item>\n </ion-col>\n </ion-row>\n </ion-grid>\n </form>\n }\n @if (repeats() === \"yearly\") {\n @if (yearlyMonth) {\n <ion-item>\n <ion-select\n label=\"Month\"\n interface=\"popover\"\n [formControl]=\"yearlyMonth\"\n (ionChange)=\"setYearlyMonth($event.detail.value)\"\n >\n @for (month of months; track month) {\n <ion-select-option [value]=\"month\">{{ month }}</ion-select-option>\n }\n </ion-select>\n </ion-item>\n } @else {\n <ion-item-divider>Select month</ion-item-divider>\n <ion-item>\n @for (month of months; track month) {\n <ion-button\n class=\"ion-margin-end\"\n color=\"light\"\n (click)=\"setYearlyMonth(month)\"\n >{{ month }}\n </ion-button>\n }\n </ion-item>\n }\n }\n\n @if (\n (repeats() === \"monthly\" && monthlyMode() === \"monthly-day\") ||\n (repeats() === \"yearly\" && yearlyMonth.value)\n ) {\n <ion-item-divider>Choose date</ion-item-divider>\n <ion-grid>\n @for (daysRow of monthDays; let rowIndex = $index; track rowIndex) {\n <ion-row>\n @for (day of daysRow; track day) {\n <ion-col size=\"2\">\n <ion-button color=\"light\" (click)=\"setMonthlyDay(day)\"\n >{{ day }}\n </ion-button>\n </ion-col>\n }\n </ion-row>\n }\n <!--\t\t\t<ion-row>-->\n <!--\t\t\t\t@for (i of [].constructor(numberOfDaysInMonth - 25); track i) {-->\n <!--\t\t\t\t\t<ion-col size=\"2\">-->\n <!--\t\t\t\t\t\t<ion-button color=\"light\" (click)=\"setMonthlyDay($index + 25 + 1)\"-->\n <!--\t\t\t\t\t\t\t>{{ $index + 25 + 1 }}-->\n <!--\t\t\t\t\t\t</ion-button>-->\n <!--\t\t\t\t\t</ion-col>-->\n <!--\t\t\t\t}-->\n <!--\t\t\t</ion-row>-->\n </ion-grid>\n }\n}\n\n@if (showTimeForm()) {\n <!--\t<ion-item-divider color=\"light\">-->\n <!--\t\t<ion-label>When</ion-label>-->\n <!--\t</ion-item-divider>-->\n <!--\t\t<ion-item-divider color=\"light\">When</ion-item-divider>-->\n <sneat-start-end-datetime-form\n #startEndDatetimeForm\n [date]=\"date\"\n [mode]=\"$happeningType()\"\n [timing]=\"timing\"\n addSlotLabel=\"Add slot\"\n (timingChange)=\"onTimingChanged($event)\"\n (addClick)=\"addSlot($event)\"\n />\n}\n\n<!--\t\t\t<ion-item-divider color=\"light\">Where</ion-item-divider>-->\n<!--\t\t\t<ion-item class=\"ion-padding-start\">-->\n<!--\t\t\t\t<ion-textarea label=\"Address / room / directions\" labelPlacement=\"stacked\"></ion-textarea>-->\n<!--\t\t\t</ion-item>-->\n\n<!-- @if (\"tab === 'where'\") { -->\n<!--\t<ion-item-divider color=\"light\">Where</ion-item-divider>-->\n<!--\t<ion-item>-->\n<!--\t\t<ion-label position=\"floating\">Address / room / directions</ion-label>-->\n<!--\t\t<ion-textarea></ion-textarea>-->\n<!--\t</ion-item>-->\n<!-- }-->\n\n<!--<ng-container *ngIf=\"tab === 'when'\">-->\n\n<!--</ng-container>-->\n\n<!--happeningType: {{happeningType}}, happens: {{happens}};-->\n\n@if (error() || showAddSlotButton()) {\n <ion-list lines=\"none\">\n @if (error()) {\n <ion-item>\n <ion-label color=\"danger\">{{ error() }}</ion-label>\n </ion-item>\n }\n\n @if (showAddSlotButton()) {\n <ion-item>\n <ion-button\n slot=\"end\"\n color=\"primary\"\n [disabled]=\"isUpdating()\"\n (click)=\"applyChanges()\"\n size=\"medium\"\n >\n @if (slot) {\n <ion-icon name=\"save-outline\" slot=\"start\" />\n <ion-label>Update slot</ion-label>\n } @else {\n <ion-icon name=\"add-outline\" slot=\"start\" />\n <ion-label>Add slot</ion-label>\n }\n @if (isUpdating()) {\n <ion-spinner name=\"lines-small\" slot=\"end\"></ion-spinner>\n }\n </ion-button>\n </ion-item>\n }\n </ion-list>\n}\n" }]
484
+ }], ctorParameters: () => [], propDecorators: { $happening: [{ type: i0.Input, args: [{ isSignal: true, alias: "$happening", required: true }] }], mode: [{
485
+ type: Input,
486
+ args: [{ required: true }]
487
+ }], slot: [{
488
+ type: Input
489
+ }], wd: [{
490
+ type: Input
491
+ }], date: [{
492
+ type: Input
493
+ }], isToDo: [{
494
+ type: Input
495
+ }], slotAdded: [{
496
+ type: Output
497
+ }], happeningChange: [{
498
+ type: Output
499
+ }], eventTimesChanged: [{
500
+ type: Output
501
+ }], startEndDatetimeForm: [{
502
+ type: ViewChild,
503
+ args: ['startEndDatetimeForm']
504
+ }] } });
505
+ //# sourceMappingURL=happening-slot-form.component.js.map