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