UNPKG

@bimeister/pupakit.calendar

Version:
110 lines 20.4 kB
import { animate, style, transition, trigger } from '@angular/animations'; import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core'; import '@bimeister/pupakit.common'; import { isNil } from '@bimeister/utilities'; import { Subscription } from 'rxjs'; import { CalendarQuickSelectMode } from '../../declarations/enums/calendar-quick-select-mode.enum'; import { isDate } from '../../declarations/functions/is-date.function'; import '../../declarations/interfaces/calendar-month.interface'; import { CalendarConfigService } from '../../services/calendar-config.service'; import { CalendarManipulatorService } from '../../services/calendar-manipulator.service'; import { CalendarStateService } from '../../services/calendar-state.service'; import { CalendarTranslationService } from '../../services/calendar-translation.service'; import * as i0 from "@angular/core"; import * as i1 from "../../services/calendar-state.service"; import * as i2 from "../../services/calendar-manipulator.service"; import * as i3 from "@angular/common"; import * as i4 from "../calendar-scroller/calendar-scroller.component"; import * as i5 from "../calendar-week-panel/calendar-week-panel.component"; import * as i6 from "../calendar-header/calendar-header.component"; import * as i7 from "../calendar-control-panel/calendar-control-panel.component"; import * as i8 from "../calendar-year-selector/calendar-year-selector.component"; import * as i9 from "../calendar-month-selector/calendar-month-selector.component"; const ANIMATION_DURATION_MS = 200; export class CalendarComponent { constructor(calendarStateService, calendarManipulatorService) { this.calendarStateService = calendarStateService; this.calendarManipulatorService = calendarManipulatorService; this.isRange = false; this.selected = []; this.select = new EventEmitter(); this.quickSelectMode = CalendarQuickSelectMode; this.quickSelectMode$ = this.calendarStateService.quickSelectMode$; this.subscription = new Subscription(); this.subscription.add(this.emitSelectDatesWhenSelectionChanged()); } ngOnChanges(changes) { if (changes.hasOwnProperty('isRange')) { this.processIsRangeChange(changes.isRange); } if (changes.hasOwnProperty('selected')) { this.processSelectedChange(changes.selected); } } ngOnDestroy() { this.subscription.unsubscribe(); } handleYearSelect(year) { this.calendarStateService.resetQuickSelectMode(); this.calendarManipulatorService.scrollToYear(year, 'auto'); } handleMonthSelect(month) { this.calendarStateService.resetQuickSelectMode(); this.calendarManipulatorService.scrollToMonth(month, 'auto'); } processIsRangeChange(change) { if (isNil(change.currentValue)) { return; } this.calendarStateService.setIsRange(change.currentValue); } processSelectedChange(change) { const value = change.currentValue; if (isNil(value)) { return; } const dates = Array.isArray(value) ? value : [value]; if (!dates.every(isDate)) { return; } this.calendarStateService.setSelectedDates(dates); } emitSelectDatesWhenSelectionChanged() { return this.calendarStateService.selectedDates$.subscribe((selectedDates) => this.select.emit(selectedDates)); } } CalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CalendarComponent, deps: [{ token: i1.CalendarStateService }, { token: i2.CalendarManipulatorService }], target: i0.ɵɵFactoryTarget.Component }); CalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CalendarComponent, selector: "pupa-calendar", inputs: { isRange: "isRange", selected: "selected" }, outputs: { select: "select" }, providers: [CalendarConfigService, CalendarTranslationService, CalendarManipulatorService, CalendarStateService], usesOnChanges: true, ngImport: i0, template: "<pupa-calendar-header>\n <pupa-calendar-control-panel></pupa-calendar-control-panel>\n <pupa-calendar-week-panel></pupa-calendar-week-panel>\n</pupa-calendar-header>\n\n<pupa-calendar-scroller></pupa-calendar-scroller>\n\n<ng-container [ngSwitch]=\"quickSelectMode$ | async\">\n <pupa-calendar-month-selector\n (select)=\"handleMonthSelect($event)\"\n *ngSwitchCase=\"quickSelectMode.Month\"\n [@quickSelectorAnimation]\n ></pupa-calendar-month-selector>\n\n <pupa-calendar-year-selector\n (select)=\"handleYearSelect($event)\"\n *ngSwitchCase=\"quickSelectMode.Year\"\n [@quickSelectorAnimation]\n ></pupa-calendar-year-selector>\n</ng-container>\n", styles: [":host{display:flex;flex-direction:column;position:relative;box-sizing:border-box;overflow:hidden;height:100%;width:100%;background:rgba(var(--semantic-color_surface-primary),var(--semantic-color-alpha_surface-primary))}\n"], dependencies: [{ kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i4.CalendarScrollerComponent, selector: "pupa-calendar-scroller" }, { kind: "component", type: i5.CalendarWeekPanelComponent, selector: "pupa-calendar-week-panel" }, { kind: "component", type: i6.CalendarHeaderComponent, selector: "pupa-calendar-header" }, { kind: "component", type: i7.CalendarControlPanelComponent, selector: "pupa-calendar-control-panel" }, { kind: "component", type: i8.CalendarYearSelectorComponent, selector: "pupa-calendar-year-selector", outputs: ["select"] }, { kind: "component", type: i9.CalendarMonthSelectorComponent, selector: "pupa-calendar-month-selector", outputs: ["select"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], animations: [ trigger('quickSelectorAnimation', [ transition(':enter', [ style({ opacity: 0, top: '-100%' }), animate(`${ANIMATION_DURATION_MS}ms ease-out`, style({ opacity: 1, top: 0 })), ]), transition(':leave', [ style({ opacity: 1, top: 0 }), animate(`${ANIMATION_DURATION_MS}ms ease-in`, style({ opacity: 0, top: '-100%' })), ]), ]), ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CalendarComponent, decorators: [{ type: Component, args: [{ selector: 'pupa-calendar', encapsulation: ViewEncapsulation.Emulated, changeDetection: ChangeDetectionStrategy.OnPush, providers: [CalendarConfigService, CalendarTranslationService, CalendarManipulatorService, CalendarStateService], animations: [ trigger('quickSelectorAnimation', [ transition(':enter', [ style({ opacity: 0, top: '-100%' }), animate(`${ANIMATION_DURATION_MS}ms ease-out`, style({ opacity: 1, top: 0 })), ]), transition(':leave', [ style({ opacity: 1, top: 0 }), animate(`${ANIMATION_DURATION_MS}ms ease-in`, style({ opacity: 0, top: '-100%' })), ]), ]), ], template: "<pupa-calendar-header>\n <pupa-calendar-control-panel></pupa-calendar-control-panel>\n <pupa-calendar-week-panel></pupa-calendar-week-panel>\n</pupa-calendar-header>\n\n<pupa-calendar-scroller></pupa-calendar-scroller>\n\n<ng-container [ngSwitch]=\"quickSelectMode$ | async\">\n <pupa-calendar-month-selector\n (select)=\"handleMonthSelect($event)\"\n *ngSwitchCase=\"quickSelectMode.Month\"\n [@quickSelectorAnimation]\n ></pupa-calendar-month-selector>\n\n <pupa-calendar-year-selector\n (select)=\"handleYearSelect($event)\"\n *ngSwitchCase=\"quickSelectMode.Year\"\n [@quickSelectorAnimation]\n ></pupa-calendar-year-selector>\n</ng-container>\n", styles: [":host{display:flex;flex-direction:column;position:relative;box-sizing:border-box;overflow:hidden;height:100%;width:100%;background:rgba(var(--semantic-color_surface-primary),var(--semantic-color-alpha_surface-primary))}\n"] }] }], ctorParameters: function () { return [{ type: i1.CalendarStateService }, { type: i2.CalendarManipulatorService }]; }, propDecorators: { isRange: [{ type: Input }], selected: [{ type: Input }], select: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../src/components/calendar/calendar.component.ts","../../../../src/components/calendar/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ComponentChange, ComponentChanges } from '@bimeister/pupakit.common';\nimport { isNil } from '@bimeister/utilities';\nimport { Observable, Subscription } from 'rxjs';\nimport { CalendarQuickSelectMode } from '../../declarations/enums/calendar-quick-select-mode.enum';\nimport { isDate } from '../../declarations/functions/is-date.function';\nimport { CalendarMonth } from '../../declarations/interfaces/calendar-month.interface';\nimport { CalendarConfigService } from '../../services/calendar-config.service';\nimport { CalendarManipulatorService } from '../../services/calendar-manipulator.service';\nimport { CalendarStateService } from '../../services/calendar-state.service';\nimport { CalendarTranslationService } from '../../services/calendar-translation.service';\n\nconst ANIMATION_DURATION_MS: number = 200;\n\n@Component({\n  selector: 'pupa-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  encapsulation: ViewEncapsulation.Emulated,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [CalendarConfigService, CalendarTranslationService, CalendarManipulatorService, CalendarStateService],\n  animations: [\n    trigger('quickSelectorAnimation', [\n      transition(':enter', [\n        style({ opacity: 0, top: '-100%' }),\n        animate(`${ANIMATION_DURATION_MS}ms ease-out`, style({ opacity: 1, top: 0 })),\n      ]),\n      transition(':leave', [\n        style({ opacity: 1, top: 0 }),\n        animate(`${ANIMATION_DURATION_MS}ms ease-in`, style({ opacity: 0, top: '-100%' })),\n      ]),\n    ]),\n  ],\n})\nexport class CalendarComponent implements OnChanges, OnDestroy {\n  @Input()\n  public isRange: boolean = false;\n\n  @Input()\n  public selected: Date[] | Date = [];\n\n  @Output()\n  public readonly select: EventEmitter<Date[]> = new EventEmitter<Date[]>();\n\n  public readonly quickSelectMode: typeof CalendarQuickSelectMode = CalendarQuickSelectMode;\n\n  public readonly quickSelectMode$: Observable<CalendarQuickSelectMode> = this.calendarStateService.quickSelectMode$;\n\n  private readonly subscription: Subscription = new Subscription();\n\n  constructor(\n    private readonly calendarStateService: CalendarStateService,\n    private readonly calendarManipulatorService: CalendarManipulatorService\n  ) {\n    this.subscription.add(this.emitSelectDatesWhenSelectionChanged());\n  }\n\n  public ngOnChanges(changes: ComponentChanges<this>): void {\n    if (changes.hasOwnProperty('isRange')) {\n      this.processIsRangeChange(changes.isRange);\n    }\n    if (changes.hasOwnProperty('selected')) {\n      this.processSelectedChange(changes.selected);\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  public handleYearSelect(year: number): void {\n    this.calendarStateService.resetQuickSelectMode();\n    this.calendarManipulatorService.scrollToYear(year, 'auto');\n  }\n\n  public handleMonthSelect(month: CalendarMonth): void {\n    this.calendarStateService.resetQuickSelectMode();\n    this.calendarManipulatorService.scrollToMonth(month, 'auto');\n  }\n\n  private processIsRangeChange(change: ComponentChange<this, boolean>): void {\n    if (isNil(change.currentValue)) {\n      return;\n    }\n\n    this.calendarStateService.setIsRange(change.currentValue);\n  }\n\n  private processSelectedChange(change: ComponentChange<this, Date[] | Date>): void {\n    const value: Date[] | Date | undefined = change.currentValue;\n\n    if (isNil(value)) {\n      return;\n    }\n\n    const dates: Date[] = Array.isArray(value) ? value : [value];\n\n    if (!dates.every(isDate)) {\n      return;\n    }\n\n    this.calendarStateService.setSelectedDates(dates);\n  }\n\n  private emitSelectDatesWhenSelectionChanged(): Subscription {\n    return this.calendarStateService.selectedDates$.subscribe((selectedDates: Date[]) =>\n      this.select.emit(selectedDates)\n    );\n  }\n}\n","<pupa-calendar-header>\n  <pupa-calendar-control-panel></pupa-calendar-control-panel>\n  <pupa-calendar-week-panel></pupa-calendar-week-panel>\n</pupa-calendar-header>\n\n<pupa-calendar-scroller></pupa-calendar-scroller>\n\n<ng-container [ngSwitch]=\"quickSelectMode$ | async\">\n  <pupa-calendar-month-selector\n    (select)=\"handleMonthSelect($event)\"\n    *ngSwitchCase=\"quickSelectMode.Month\"\n    [@quickSelectorAnimation]\n  ></pupa-calendar-month-selector>\n\n  <pupa-calendar-year-selector\n    (select)=\"handleYearSelect($event)\"\n    *ngSwitchCase=\"quickSelectMode.Year\"\n    [@quickSelectorAnimation]\n  ></pupa-calendar-year-selector>\n</ng-container>\n"]}