@bimeister/pupakit.calendar
Version:
PupaKit Calendar
77 lines • 18.3 kB
JavaScript
import { CdkVirtualScrollViewport, VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';
import { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation } from '@angular/core';
import 'rxjs';
import { map } from 'rxjs/operators';
import { CalendarVirtualScrollStrategy } from '../../declarations/classes/calendar-virtual-scroll-strategy.class';
import { MONTHS_IN_YEAR } from '../../declarations/constants/months-in-year.const';
import '../../declarations/enums/day-of-week.enum';
import '../../declarations/enums/month-index.enum';
import '../../declarations/interfaces/calendar-month.interface';
import '../../declarations/interfaces/calendar-translation.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-config.service";
import * as i2 from "../../services/calendar-translation.service";
import * as i3 from "../../services/calendar-manipulator.service";
import * as i4 from "../../services/calendar-state.service";
import * as i5 from "@angular/common";
import * as i6 from "@bimeister/pupakit.kit";
import * as i7 from "@bimeister/pupakit.common";
import * as i8 from "@angular/cdk/scrolling";
import * as i9 from "../calendar-label/calendar-label.component";
import * as i10 from "../calendar-month/calendar-month.component";
import * as i11 from "../../pipes/is-current-calendar-month.pipe";
import * as i12 from "../../pipes/next-calendar-month.pipe";
export function calendarVirtualScrollStrategyFactory({ virtualScrollConfig, }) {
return new CalendarVirtualScrollStrategy(virtualScrollConfig);
}
export class CalendarScrollerComponent {
constructor(calendarConfigService, calendarTranslationService, calendarManipulatorService, calendarStateService) {
this.calendarConfigService = calendarConfigService;
this.calendarTranslationService = calendarTranslationService;
this.calendarManipulatorService = calendarManipulatorService;
this.calendarStateService = calendarStateService;
this.calendarMonths = Array.from({ length: this.calendarConfigService.yearsRange * MONTHS_IN_YEAR }, (_, monthGlobalIndex) => this.getCalendarMonthByMonthGlobalIndex(monthGlobalIndex));
this.monthNameByIndex$ = this.calendarTranslationService.translation$.pipe(map((translation) => translation.months));
this.selectedDates$ = this.calendarStateService.selectedDates$;
this.startWeekday = this.calendarConfigService.startWeekday;
}
ngAfterViewInit() {
this.calendarManipulatorService.setVirtualScrollViewport(this.virtualScrollViewport);
this.calendarManipulatorService.resetScroll('auto');
}
addSelectedDate(date) {
this.calendarStateService.addSelectedDate(date);
}
getCalendarMonthByMonthGlobalIndex(index) {
return {
year: Math.floor(index / MONTHS_IN_YEAR) + this.calendarConfigService.startYear,
month: index % MONTHS_IN_YEAR,
};
}
}
CalendarScrollerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CalendarScrollerComponent, deps: [{ token: i1.CalendarConfigService }, { token: i2.CalendarTranslationService }, { token: i3.CalendarManipulatorService }, { token: i4.CalendarStateService }], target: i0.ɵɵFactoryTarget.Component });
CalendarScrollerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CalendarScrollerComponent, selector: "pupa-calendar-scroller", providers: [
{
provide: VIRTUAL_SCROLL_STRATEGY,
useFactory: calendarVirtualScrollStrategyFactory,
deps: [CalendarConfigService],
},
], viewQueries: [{ propertyName: "virtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }], ngImport: i0, template: "<cdk-virtual-scroll-viewport\n pupaScrollableContent\n class=\"scroller\"\n *pupaLet=\"\n {\n monthNameByIndex: monthNameByIndex$ | async,\n selectedDates: selectedDates$ | async\n };\n let monthNameByIndex = monthNameByIndex;\n let selectedDates = selectedDates\n \"\n>\n <div class=\"scroller__item\" *cdkVirtualFor=\"let month of calendarMonths; templateCacheSize: 10; let isLast = last\">\n <pupa-calendar-month\n [calendarMonth]=\"month\"\n [isCurrent]=\"month | isCurrentCalendarMonth\"\n (selectDate)=\"addSelectedDate($event)\"\n [selectedDates]=\"selectedDates\"\n ></pupa-calendar-month>\n\n <ng-container *ngIf=\"!isLast\">\n <div class=\"scroller__divider\"></div>\n\n <pupa-calendar-label *pupaLet=\"month | nextCalendarMonth as nextMonth\">\n {{ nextMonth.year }} {{ monthNameByIndex[nextMonth.month] }}\n </pupa-calendar-label>\n\n <div class=\"scroller__divider\"></div>\n </ng-container>\n </div>\n</cdk-virtual-scroll-viewport>\n", styles: [":host{display:block;height:100%;width:100%;box-sizing:border-box;padding:4rem 0 0}.scroller{height:100%;width:100%;display:block;box-sizing:border-box}.scroller__item{display:block;box-sizing:border-box;width:100%;padding:0 4rem}.scroller__divider{display:block;width:100%;height:3rem}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.ScrollableContentDirective, selector: "[pupaScrollableContent]" }, { kind: "directive", type: i7.LetDirective, selector: "[pupaLet]", inputs: ["pupaLet"] }, { kind: "directive", type: i8.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i8.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "component", type: i9.CalendarLabelComponent, selector: "pupa-calendar-label" }, { kind: "component", type: i10.CalendarMonthComponent, selector: "pupa-calendar-month", inputs: ["calendarMonth", "isCurrent", "selectedDates"], outputs: ["selectDate"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i11.IsCurrentCalendarMonthPipe, name: "isCurrentCalendarMonth" }, { kind: "pipe", type: i12.NextCalendarMonthPipe, name: "nextCalendarMonth" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CalendarScrollerComponent, decorators: [{
type: Component,
args: [{ selector: 'pupa-calendar-scroller', encapsulation: ViewEncapsulation.Emulated, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
{
provide: VIRTUAL_SCROLL_STRATEGY,
useFactory: calendarVirtualScrollStrategyFactory,
deps: [CalendarConfigService],
},
], template: "<cdk-virtual-scroll-viewport\n pupaScrollableContent\n class=\"scroller\"\n *pupaLet=\"\n {\n monthNameByIndex: monthNameByIndex$ | async,\n selectedDates: selectedDates$ | async\n };\n let monthNameByIndex = monthNameByIndex;\n let selectedDates = selectedDates\n \"\n>\n <div class=\"scroller__item\" *cdkVirtualFor=\"let month of calendarMonths; templateCacheSize: 10; let isLast = last\">\n <pupa-calendar-month\n [calendarMonth]=\"month\"\n [isCurrent]=\"month | isCurrentCalendarMonth\"\n (selectDate)=\"addSelectedDate($event)\"\n [selectedDates]=\"selectedDates\"\n ></pupa-calendar-month>\n\n <ng-container *ngIf=\"!isLast\">\n <div class=\"scroller__divider\"></div>\n\n <pupa-calendar-label *pupaLet=\"month | nextCalendarMonth as nextMonth\">\n {{ nextMonth.year }} {{ monthNameByIndex[nextMonth.month] }}\n </pupa-calendar-label>\n\n <div class=\"scroller__divider\"></div>\n </ng-container>\n </div>\n</cdk-virtual-scroll-viewport>\n", styles: [":host{display:block;height:100%;width:100%;box-sizing:border-box;padding:4rem 0 0}.scroller{height:100%;width:100%;display:block;box-sizing:border-box}.scroller__item{display:block;box-sizing:border-box;width:100%;padding:0 4rem}.scroller__divider{display:block;width:100%;height:3rem}\n"] }]
}], ctorParameters: function () { return [{ type: i1.CalendarConfigService }, { type: i2.CalendarTranslationService }, { type: i3.CalendarManipulatorService }, { type: i4.CalendarStateService }]; }, propDecorators: { virtualScrollViewport: [{
type: ViewChild,
args: [CdkVirtualScrollViewport]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-scroller.component.js","sourceRoot":"","sources":["../../../../src/components/calendar-scroller/calendar-scroller.component.ts","../../../../src/components/calendar-scroller/calendar-scroller.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport, VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { CalendarVirtualScrollStrategy } from '../../declarations/classes/calendar-virtual-scroll-strategy.class';\nimport { MONTHS_IN_YEAR } from '../../declarations/constants/months-in-year.const';\nimport { DayOfWeek } from '../../declarations/enums/day-of-week.enum';\nimport { MonthIndex } from '../../declarations/enums/month-index.enum';\nimport { CalendarMonth } from '../../declarations/interfaces/calendar-month.interface';\nimport { CalendarTranslation } from '../../declarations/interfaces/calendar-translation.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\nexport function calendarVirtualScrollStrategyFactory({\n  virtualScrollConfig,\n}: CalendarConfigService): CalendarVirtualScrollStrategy {\n  return new CalendarVirtualScrollStrategy(virtualScrollConfig);\n}\n\n@Component({\n  selector: 'pupa-calendar-scroller',\n  templateUrl: './calendar-scroller.component.html',\n  styleUrls: ['./calendar-scroller.component.scss'],\n  encapsulation: ViewEncapsulation.Emulated,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: VIRTUAL_SCROLL_STRATEGY,\n      useFactory: calendarVirtualScrollStrategyFactory,\n      deps: [CalendarConfigService],\n    },\n  ],\n})\nexport class CalendarScrollerComponent implements AfterViewInit {\n  @ViewChild(CdkVirtualScrollViewport)\n  private readonly virtualScrollViewport: CdkVirtualScrollViewport;\n\n  public readonly calendarMonths: CalendarMonth[] = Array.from(\n    { length: this.calendarConfigService.yearsRange * MONTHS_IN_YEAR },\n    (_: unknown, monthGlobalIndex: number) => this.getCalendarMonthByMonthGlobalIndex(monthGlobalIndex)\n  );\n\n  public readonly monthNameByIndex$: Observable<Record<MonthIndex, string>> =\n    this.calendarTranslationService.translation$.pipe(map((translation: CalendarTranslation) => translation.months));\n\n  public readonly selectedDates$: Observable<Date[]> = this.calendarStateService.selectedDates$;\n\n  public readonly startWeekday: DayOfWeek = this.calendarConfigService.startWeekday;\n\n  constructor(\n    private readonly calendarConfigService: CalendarConfigService,\n    private readonly calendarTranslationService: CalendarTranslationService,\n    private readonly calendarManipulatorService: CalendarManipulatorService,\n    private readonly calendarStateService: CalendarStateService\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this.calendarManipulatorService.setVirtualScrollViewport(this.virtualScrollViewport);\n    this.calendarManipulatorService.resetScroll('auto');\n  }\n\n  public addSelectedDate(date: Date): void {\n    this.calendarStateService.addSelectedDate(date);\n  }\n\n  private getCalendarMonthByMonthGlobalIndex(index: number): CalendarMonth {\n    return {\n      year: Math.floor(index / MONTHS_IN_YEAR) + this.calendarConfigService.startYear,\n      month: index % MONTHS_IN_YEAR,\n    };\n  }\n}\n","<cdk-virtual-scroll-viewport\n  pupaScrollableContent\n  class=\"scroller\"\n  *pupaLet=\"\n    {\n      monthNameByIndex: monthNameByIndex$ | async,\n      selectedDates: selectedDates$ | async\n    };\n    let monthNameByIndex = monthNameByIndex;\n    let selectedDates = selectedDates\n  \"\n>\n  <div class=\"scroller__item\" *cdkVirtualFor=\"let month of calendarMonths; templateCacheSize: 10; let isLast = last\">\n    <pupa-calendar-month\n      [calendarMonth]=\"month\"\n      [isCurrent]=\"month | isCurrentCalendarMonth\"\n      (selectDate)=\"addSelectedDate($event)\"\n      [selectedDates]=\"selectedDates\"\n    ></pupa-calendar-month>\n\n    <ng-container *ngIf=\"!isLast\">\n      <div class=\"scroller__divider\"></div>\n\n      <pupa-calendar-label *pupaLet=\"month | nextCalendarMonth as nextMonth\">\n        {{ nextMonth.year }} {{ monthNameByIndex[nextMonth.month] }}\n      </pupa-calendar-label>\n\n      <div class=\"scroller__divider\"></div>\n    </ng-container>\n  </div>\n</cdk-virtual-scroll-viewport>\n"]}