@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.
- package/esm2022/index.js +2 -0
- package/esm2022/index.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-base.component.js +83 -0
- package/esm2022/lib/components/calendar/calendar-base.component.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-brief.component.js +57 -0
- package/esm2022/lib/components/calendar/calendar-brief.component.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-component-types.js +2 -0
- package/esm2022/lib/components/calendar/calendar-component-types.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar-state.service.js +90 -0
- package/esm2022/lib/components/calendar/calendar-state.service.js.map +1 -0
- package/esm2022/lib/components/calendar/calendar.component.js +284 -0
- package/esm2022/lib/components/calendar/calendar.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-add-buttons/calendar-add-buttons.component.js +45 -0
- package/esm2022/lib/components/calendar/components/calendar-add-buttons/calendar-add-buttons.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-base.component.js +26 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-base.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-card.component.js +67 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-card.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-tab.component.js +74 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-tab.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-title.component.js +27 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day-title.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day.component.js +129 -0
- package/esm2022/lib/components/calendar/components/calendar-day/calendar-day.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.component.js +162 -0
- package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.js +17 -0
- package/esm2022/lib/components/calendar/components/calendar-filter/calendar-filter.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-filter/contacts-filter.component.js +95 -0
- package/esm2022/lib/components/calendar/components/calendar-filter/contacts-filter.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-card.component.js +50 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-card.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-tab.component.js +18 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-tab.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-title.component.js +15 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week-title.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week.component.js +78 -0
- package/esm2022/lib/components/calendar/components/calendar-week/calendar-week.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/calendar-weekday/calendar-weekday.component.js +66 -0
- package/esm2022/lib/components/calendar/components/calendar-weekday/calendar-weekday.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/day-slot-item/day-slot-item.component.js +93 -0
- package/esm2022/lib/components/calendar/components/day-slot-item/day-slot-item.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/day-slot-item/slot-context-menu.component.js +324 -0
- package/esm2022/lib/components/calendar/components/day-slot-item/slot-context-menu.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/recurrings-tab/recurrings-tab.component.js +36 -0
- package/esm2022/lib/components/calendar/components/recurrings-tab/recurrings-tab.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/singles-tab/single-happenings-list.component.js +65 -0
- package/esm2022/lib/components/calendar/components/singles-tab/single-happenings-list.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/singles-tab/singles-tab.component.js +106 -0
- package/esm2022/lib/components/calendar/components/singles-tab/singles-tab.component.js.map +1 -0
- package/esm2022/lib/components/calendar/components/timing-badge/timing-badge.component.js +25 -0
- package/esm2022/lib/components/calendar/components/timing-badge/timing-badge.component.js.map +1 -0
- package/esm2022/lib/components/calendar/weekday.js +2 -0
- package/esm2022/lib/components/calendar/weekday.js.map +1 -0
- package/esm2022/lib/components/calendar-core.js +64 -0
- package/esm2022/lib/components/calendar-core.js.map +1 -0
- package/esm2022/lib/components/calendar-filter.service.js +28 -0
- package/esm2022/lib/components/calendar-filter.service.js.map +1 -0
- package/esm2022/lib/components/calendar-slots.js +30 -0
- package/esm2022/lib/components/calendar-slots.js.map +1 -0
- package/esm2022/lib/components/happening-base.component.js +188 -0
- package/esm2022/lib/components/happening-base.component.js.map +1 -0
- package/esm2022/lib/components/happening-card/happening-card.component.js +69 -0
- package/esm2022/lib/components/happening-card/happening-card.component.js.map +1 -0
- package/esm2022/lib/components/happening-component-base-params.js +37 -0
- package/esm2022/lib/components/happening-component-base-params.js.map +1 -0
- package/esm2022/lib/components/happening-form/happening-form.component.js +348 -0
- package/esm2022/lib/components/happening-form/happening-form.component.js.map +1 -0
- package/esm2022/lib/components/happening-form/happening-price-form/happening-price-modal.component.js +161 -0
- package/esm2022/lib/components/happening-form/happening-price-form/happening-price-modal.component.js.map +1 -0
- package/esm2022/lib/components/happening-form/happening-prices/happening-prices.component.js +142 -0
- package/esm2022/lib/components/happening-form/happening-prices/happening-prices.component.js.map +1 -0
- package/esm2022/lib/components/happening-participants/happening-participants.component.js +195 -0
- package/esm2022/lib/components/happening-participants/happening-participants.component.js.map +1 -0
- package/esm2022/lib/components/happening-slot-form/happening-slot-form.component.js +505 -0
- package/esm2022/lib/components/happening-slot-form/happening-slot-form.component.js.map +1 -0
- package/esm2022/lib/components/happening-slot-form/happening-slot-modal.component.js +140 -0
- package/esm2022/lib/components/happening-slot-form/happening-slot-modal.component.js.map +1 -0
- package/esm2022/lib/components/happening-slot-form/happening-slot-modal.service.js +47 -0
- package/esm2022/lib/components/happening-slot-form/happening-slot-modal.service.js.map +1 -0
- package/esm2022/lib/components/happening-slot-participants/happening-slot-participants.component.js +74 -0
- package/esm2022/lib/components/happening-slot-participants/happening-slot-participants.component.js.map +1 -0
- package/esm2022/lib/components/happening-slots/happening-slots.component.js +130 -0
- package/esm2022/lib/components/happening-slots/happening-slots.component.js.map +1 -0
- package/esm2022/lib/components/index.js +20 -0
- package/esm2022/lib/components/index.js.map +1 -0
- package/esm2022/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.js +68 -0
- package/esm2022/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.js.map +1 -0
- package/esm2022/lib/components/start-end-datetime-form/start-end-datetime-form.component.js +377 -0
- package/esm2022/lib/components/start-end-datetime-form/start-end-datetime-form.component.js.map +1 -0
- package/esm2022/lib/components/start-end-datetime-form/time-selector.component.js +92 -0
- package/esm2022/lib/components/start-end-datetime-form/time-selector.component.js.map +1 -0
- package/esm2022/lib/components/swipeable-base.component.js +112 -0
- package/esm2022/lib/components/swipeable-base.component.js.map +1 -0
- package/esm2022/lib/components/swipeable-ui.js +64 -0
- package/esm2022/lib/components/swipeable-ui.js.map +1 -0
- package/esm2022/lib/components/week.js +2 -0
- package/esm2022/lib/components/week.js.map +1 -0
- package/esm2022/lib/components/weekday-functions.js +13 -0
- package/esm2022/lib/components/weekday-functions.js.map +1 -0
- package/esm2022/lib/components/weekdays/weekdays-form-base.js +72 -0
- package/esm2022/lib/components/weekdays/weekdays-form-base.js.map +1 -0
- package/esm2022/lib/index.js +3 -0
- package/esm2022/lib/index.js.map +1 -0
- package/esm2022/lib/modals/happening-title-modal/happening-title-modal.component.js +87 -0
- package/esm2022/lib/modals/happening-title-modal/happening-title-modal.component.js.map +1 -0
- package/esm2022/lib/services/calendar-data-provider.js +271 -0
- package/esm2022/lib/services/calendar-data-provider.js.map +1 -0
- package/esm2022/lib/services/calendar-day.js +179 -0
- package/esm2022/lib/services/calendar-day.js.map +1 -0
- package/esm2022/lib/services/calendar-day.service.js +37 -0
- package/esm2022/lib/services/calendar-day.service.js.map +1 -0
- package/esm2022/lib/services/calendar-nav.service.js +36 -0
- package/esm2022/lib/services/calendar-nav.service.js.map +1 -0
- package/esm2022/lib/services/calendar-space.js +152 -0
- package/esm2022/lib/services/calendar-space.js.map +1 -0
- package/esm2022/lib/services/calendar-types.js +52 -0
- package/esm2022/lib/services/calendar-types.js.map +1 -0
- package/esm2022/lib/services/calendarium-services.module.js +16 -0
- package/esm2022/lib/services/calendarium-services.module.js.map +1 -0
- package/esm2022/lib/services/calendarium-space.service.js +16 -0
- package/esm2022/lib/services/calendarium-space.service.js.map +1 -0
- package/esm2022/lib/services/happening.service.js +225 -0
- package/esm2022/lib/services/happening.service.js.map +1 -0
- package/esm2022/lib/services/index.js +6 -0
- package/esm2022/lib/services/index.js.map +1 -0
- package/esm2022/sneat-extensions-schedulus-shared.js +5 -0
- package/esm2022/sneat-extensions-schedulus-shared.js.map +1 -0
- package/index.d.ts +1 -0
- package/lib/components/calendar/calendar-base.component.d.ts +23 -0
- package/lib/components/calendar/calendar-brief.component.d.ts +11 -0
- package/lib/components/calendar/calendar-component-types.d.ts +1 -0
- package/lib/components/calendar/calendar-state.service.d.ts +15 -0
- package/lib/components/calendar/calendar.component.d.ts +32 -0
- package/lib/components/calendar/components/calendar-add-buttons/calendar-add-buttons.component.d.ts +13 -0
- package/lib/components/calendar/components/calendar-day/calendar-day-base.component.d.ts +10 -0
- package/lib/components/calendar/components/calendar-day/calendar-day-card.component.d.ts +17 -0
- package/lib/components/calendar/components/calendar-day/calendar-day-tab.component.d.ts +19 -0
- package/lib/components/calendar/components/calendar-day/calendar-day-title.component.d.ts +10 -0
- package/lib/components/calendar/components/calendar-day/calendar-day.component.d.ts +30 -0
- package/lib/components/calendar/components/calendar-filter/calendar-filter.component.d.ts +39 -0
- package/lib/components/calendar/components/calendar-filter/calendar-filter.d.ts +10 -0
- package/lib/components/calendar/components/calendar-filter/contacts-filter.component.d.ts +20 -0
- package/lib/components/calendar/components/calendar-week/calendar-week-card.component.d.ts +15 -0
- package/lib/components/calendar/components/calendar-week/calendar-week-tab.component.d.ts +9 -0
- package/lib/components/calendar/components/calendar-week/calendar-week-title.component.d.ts +7 -0
- package/lib/components/calendar/components/calendar-week/calendar-week.component.d.ts +20 -0
- package/lib/components/calendar/components/calendar-weekday/calendar-weekday.component.d.ts +23 -0
- package/lib/components/calendar/components/day-slot-item/day-slot-item.component.d.ts +19 -0
- package/lib/components/calendar/components/day-slot-item/slot-context-menu.component.d.ts +40 -0
- package/lib/components/calendar/components/recurrings-tab/recurrings-tab.component.d.ts +15 -0
- package/lib/components/calendar/components/singles-tab/single-happenings-list.component.d.ts +22 -0
- package/lib/components/calendar/components/singles-tab/singles-tab.component.d.ts +29 -0
- package/lib/components/calendar/components/timing-badge/timing-badge.component.d.ts +17 -0
- package/lib/components/calendar/weekday.d.ts +7 -0
- package/lib/components/calendar-core.d.ts +10 -0
- package/lib/components/calendar-filter.service.d.ts +8 -0
- package/lib/components/calendar-slots.d.ts +5 -0
- package/lib/components/happening-base.component.d.ts +46 -0
- package/lib/components/happening-card/happening-card.component.d.ts +11 -0
- package/lib/components/happening-component-base-params.d.ts +16 -0
- package/lib/components/happening-form/happening-form.component.d.ts +52 -0
- package/lib/components/happening-form/happening-price-form/happening-price-modal.component.d.ts +29 -0
- package/lib/components/happening-form/happening-prices/happening-prices.component.d.ts +16 -0
- package/lib/components/happening-participants/happening-participants.component.d.ts +24 -0
- package/lib/components/happening-slot-form/happening-slot-form.component.d.ts +76 -0
- package/lib/components/happening-slot-form/happening-slot-modal.component.d.ts +26 -0
- package/lib/components/happening-slot-form/happening-slot-modal.service.d.ts +18 -0
- package/lib/components/happening-slot-participants/happening-slot-participants.component.d.ts +19 -0
- package/lib/components/happening-slots/happening-slots.component.d.ts +28 -0
- package/lib/components/index.d.ts +5 -0
- package/lib/components/start-end-dates-range-form/start-end-dates-range-form.component.d.ts +16 -0
- package/lib/components/start-end-datetime-form/start-end-datetime-form.component.d.ts +53 -0
- package/lib/components/start-end-datetime-form/time-selector.component.d.ts +15 -0
- package/lib/components/swipeable-base.component.d.ts +25 -0
- package/lib/components/swipeable-ui.d.ts +24 -0
- package/lib/components/week.d.ts +4 -0
- package/lib/components/weekday-functions.d.ts +3 -0
- package/lib/components/weekdays/weekdays-form-base.d.ts +31 -0
- package/lib/index.d.ts +2 -0
- package/lib/modals/happening-title-modal/happening-title-modal.component.d.ts +24 -0
- package/lib/services/calendar-data-provider.d.ts +33 -0
- package/lib/services/calendar-day.d.ts +45 -0
- package/lib/services/calendar-day.service.d.ts +18 -0
- package/lib/services/calendar-nav.service.d.ts +14 -0
- package/lib/services/calendar-space.d.ts +23 -0
- package/lib/services/calendar-types.d.ts +10 -0
- package/lib/services/calendarium-services.module.d.ts +6 -0
- package/lib/services/calendarium-space.service.d.ts +8 -0
- package/lib/services/happening.service.d.ts +99 -0
- package/lib/services/index.d.ts +5 -0
- package/package.json +26 -0
- package/sneat-extensions-schedulus-shared.d.ts +5 -0
- 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
|