UNPKG

@universal-material/angular

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 16.1.0.

280 lines 37.1 kB
import { Directive, EventEmitter, Inject, Input, LOCALE_ID, Optional, Output } from '@angular/core'; import { getLocaleFirstDayOfWeek, WeekDay } from '@angular/common'; import { DATEPICKER_DEFAULT_OPTIONS, DefaultDatepickerConfig } from './datepicker-config.model'; import { DatepickerAdapter } from './datepicker-adapter'; import * as i0 from "@angular/core"; import * as i1 from "./default-datepicker-adapter"; import * as i2 from "./datepicker-adapter"; export class DatepickerBaseComponent { get min() { return this._min; } set min(value) { this._min = value; this._minYear = value && value.getUTCFullYear(); this._minMonth = value && value.getUTCMonth(); this._setYearsDisabled(); this._setMonthsDisabled(); this._setDaysDisabled(); } get max() { return this._max; } set max(value) { this._max = value; this._maxYear = value && value.getUTCFullYear(); this._maxMonth = value && value.getUTCMonth(); this._setYearsDisabled(); this._setMonthsDisabled(); this._setDaysDisabled(); } constructor(_locale, _defaultConfig, datepickerAdapter, defaultDatepickerAdapter) { this._locale = _locale; this._defaultConfig = _defaultConfig; this.datepickerAdapter = datepickerAdapter; this._totalDaysOfWeek = 7; this._yearsGroupsCount = 6; this._yearsPerGroup = 4; this.totalVisibleYears = this._yearsGroupsCount * this._yearsPerGroup; this.monthsPerGroup = 4; this._minYear = null; this._minMonth = null; this._maxYear = null; this._maxMonth = null; this.weeks = []; this.yearGroups = []; this.monthGroups = []; this.dayTemplate = null; this.datepickerTitle = 'Select date'; this.hideHeader = false; this.hideClear = false; this.clearLabel = null; this.currentMonthChange = new EventEmitter(); this._min = null; this._max = null; this.date = null; this.dateChange = new EventEmitter(); this.formattedDate = null; this._setInnerConfig(); this.datepickerAdapter = this.datepickerAdapter || defaultDatepickerAdapter; this.weekDayNames = this.datepickerAdapter.getWeekDaysNames(this.firstDayOfWeek); this._setDate(null); this.setYearGroups(this.currentMonth.utcYear - 2); this._setMonthGroups(); } setYearGroups(baseYear) { this.baseYear = baseYear; this.yearGroups.length = 0; for (let g = 0; g < this._yearsGroupsCount; g++) { const yearGroup = []; this.yearGroups.push(yearGroup); for (let y = 0; y < this._yearsPerGroup; y++) { yearGroup.push({ year: baseYear, disabled: this._isYearDisabled(baseYear) }); baseYear++; } } } _setInnerConfig() { const config = { ...DefaultDatepickerConfig, firstDayOfWeek: getLocaleFirstDayOfWeek(this._locale), ...this._defaultConfig }; this.clearLabel = config.clearLabel ?? null; this.hideClear = config.hideClear ?? false; this.firstDayOfWeek = config.firstDayOfWeek; } _setMonthGroups() { let m = 0; while (m < 12) { const monthGroup = []; this.monthGroups.push(monthGroup); for (let i = 0; i < this.monthsPerGroup; i++) { monthGroup.push(this.getMonth(new Date(this.baseYear, m))); m++; } } } setYear(year) { this._setCurrentMonth(new Date(year, this.currentMonth.utcMonth)); } setMonth(month) { this._setCurrentMonth(new Date(this.currentMonth.utcYear, month.utcMonth)); } _setDate(date) { this.date = date; this.formattedDate = this.datepickerAdapter.formatDate(date); date = date || new Date(); this._setCurrentMonth(new Date(date.getUTCFullYear(), date.getUTCMonth())); } getMonth(date) { const month = { date: date, utcYear: date.getUTCFullYear(), utcMonth: date.getUTCMonth(), name: this.datepickerAdapter.getMonthName(date), nameWithYear: this.datepickerAdapter.getMonthWithYear(date), formattedYear: this.datepickerAdapter.getYear(date), disabled: false }; month.disabled = this._isMonthDisabled(month); return month; } _addToCurrentMonth(value) { this._setCurrentMonth(new Date(this.currentMonth.utcYear, this.currentMonth.utcMonth + value)); } _getCurrentMonthInitialDate() { return new Date(this.currentMonth.utcYear, this.currentMonth.utcMonth); } _getInitialDateForCurrentMonth() { const currentMonthInitialDate = this._getCurrentMonthInitialDate(); if (currentMonthInitialDate.getDay() === this.firstDayOfWeek) { return currentMonthInitialDate; } if (currentMonthInitialDate.getDay() > this.firstDayOfWeek) { currentMonthInitialDate .setDate(currentMonthInitialDate.getDate() - (currentMonthInitialDate.getDay() - this.firstDayOfWeek)); } else { currentMonthInitialDate .setDate(currentMonthInitialDate.getDate() - (WeekDay.Saturday - (this.firstDayOfWeek - currentMonthInitialDate.getDay() - 1))); } return currentMonthInitialDate; } _setCurrentMonth(date) { const previousMonth = this.currentMonth; const newMonth = this.getMonth(date); if (previousMonth && previousMonth.date.getTime() === newMonth.date.getTime()) { return; } this.currentMonth = newMonth; this.currentMonthChange.emit(this.currentMonth); this.weeks.length = 0; const processDate = new Date(this._getInitialDateForCurrentMonth()); do { const currentWeek = { baseDate: new Date(processDate), days: [] }; this.weeks.push(currentWeek); for (let i = 0; i < this._totalDaysOfWeek; i++) { const dayDate = new Date(processDate); currentWeek.days.push({ date: dayDate, outsideMonth: processDate.getMonth() !== this.currentMonth.utcMonth, disabled: this._isDayDisabled(dayDate) }); processDate.setDate(processDate.getDate() + 1); } } while (processDate.getUTCMonth() === this.currentMonth.utcMonth); this._setMonthsDisabled(); } showNextMonth() { this._addToCurrentMonth(1); } showPreviousMonth() { this._addToCurrentMonth(-1); } _isDayDisabled(date) { return !!this.min && date < this.min || !!this.max && date > this.max; } _setDaysDisabled() { for (const week of this.weeks) { for (const day of week.days) { day.disabled = this._isDayDisabled(day.date); } } } _isMonthDisabled(month) { return this.currentMonth && (this._isYearDisabled(this.currentMonth.utcYear) || (this.currentMonth.utcYear === this._minYear && month.utcMonth < this._minMonth) || (this.currentMonth.utcYear === this._maxYear && month.utcMonth > this._maxMonth)); } _setMonthsDisabled() { for (const monthGroup of this.monthGroups) { for (const month of monthGroup) { month.disabled = this._isMonthDisabled(month); } } } _isYearDisabled(year) { return !!this._minYear && year < this._minYear || !!this._maxYear && year > this._maxYear; } _setYearsDisabled() { for (const yearGroup of this.yearGroups) { for (const year of yearGroup) { year.disabled = this._isYearDisabled(year.year); } } } selectDate(date) { this._setDate(date); this.dateChange.emit(date); } _datesAreEqual(dateA, dateB) { return dateA.getUTCMonth() === dateB.getUTCMonth() && dateA.getUTCFullYear() === dateB.getUTCFullYear() && dateA.getDate() === dateB.getDate(); } isEqualToSelectedDate(date) { return this.date && this._datesAreEqual(this.date, date); } isEqualToTodayDate(date) { return this._datesAreEqual(new Date(), date); } trackByWeek(index, week) { return week.baseDate.getTime(); } trackByDay(index, day) { return day.date.getTime(); } ngOnChanges(changes) { let dateChange = changes['date']; if (dateChange && dateChange.currentValue && dateChange.currentValue !== dateChange.previousValue) { this._setDate(dateChange.currentValue); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerBaseComponent, deps: [{ token: LOCALE_ID }, { token: DATEPICKER_DEFAULT_OPTIONS, optional: true }, { token: DatepickerAdapter, optional: true }, { token: i1.DefaultDatepickerAdapter }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: DatepickerBaseComponent, inputs: { dayTemplate: "dayTemplate", datepickerTitle: "datepickerTitle", hideHeader: "hideHeader", hideClear: "hideClear", clearLabel: "clearLabel", min: "min", max: "max", date: "date" }, outputs: { currentMonthChange: "currentMonthChange", dateChange: "dateChange" }, usesOnChanges: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerBaseComponent, decorators: [{ type: Directive }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [LOCALE_ID] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DATEPICKER_DEFAULT_OPTIONS] }] }, { type: i2.DatepickerAdapter, decorators: [{ type: Optional }, { type: Inject, args: [DatepickerAdapter] }] }, { type: i1.DefaultDatepickerAdapter }]; }, propDecorators: { dayTemplate: [{ type: Input }], datepickerTitle: [{ type: Input }], hideHeader: [{ type: Input }], hideClear: [{ type: Input }], clearLabel: [{ type: Input }], currentMonthChange: [{ type: Output }], min: [{ type: Input }], max: [{ type: Input }], date: [{ type: Input }], dateChange: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-base.component.js","sourceRoot":"","sources":["../../../../../src/datepicker/datepicker-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  LOCALE_ID,\r\n  Optional,\r\n  Output,\r\n  SimpleChanges,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { getLocaleFirstDayOfWeek, WeekDay } from '@angular/common';\r\n\r\nimport { Week } from './week.model';\r\nimport { DayOfWeek } from './day-of-week.model';\r\nimport { DATEPICKER_DEFAULT_OPTIONS, DatepickerConfig, DefaultDatepickerConfig } from './datepicker-config.model';\r\nimport { DatepickerAdapter } from './datepicker-adapter';\r\nimport { DefaultDatepickerAdapter } from './default-datepicker-adapter';\r\nimport { Month } from './month.model';\r\nimport { Year } from './year.model';\r\n\r\n@Directive()\r\nexport abstract class DatepickerBaseComponent {\r\n  private readonly _totalDaysOfWeek = 7;\r\n  private readonly _yearsGroupsCount = 6;\r\n  private readonly _yearsPerGroup = 4;\r\n\r\n  readonly weekDayNames: string[];\r\n  readonly totalVisibleYears = this._yearsGroupsCount * this._yearsPerGroup;\r\n\r\n  private readonly monthsPerGroup = 4;\r\n\r\n  private _minYear: number | null = null;\r\n  private _minMonth: number | null = null;\r\n  private _maxYear: number | null = null;\r\n  private _maxMonth: number | null = null;\r\n\r\n  weeks: Week[] = [];\r\n  yearGroups: Year[][] = [];\r\n  monthGroups: Month[][] = [];\r\n  currentMonth!: Month;\r\n  baseYear!: number;\r\n  firstDayOfWeek!: number;\r\n\r\n  @Input() dayTemplate: TemplateRef<DayOfWeek> | null = null;\r\n  @Input() datepickerTitle: string = 'Select date';\r\n  @Input() hideHeader: boolean = false;\r\n  @Input() hideClear: boolean = false;\r\n  @Input() clearLabel: string | null = null;\r\n\r\n  @Output() currentMonthChange = new EventEmitter<Month>();\r\n\r\n  _min: Date | null = null;\r\n  _max: Date | null = null;\r\n\r\n  @Input()\r\n  get min(): Date | null {\r\n    return this._min;\r\n  }\r\n  set min(value: Date | null) {\r\n    this._min = value;\r\n    this._minYear = value && value.getUTCFullYear();\r\n    this._minMonth = value && value.getUTCMonth();\r\n    this._setYearsDisabled();\r\n    this._setMonthsDisabled();\r\n    this._setDaysDisabled();\r\n  }\r\n\r\n  @Input()\r\n  get max(): Date | null {\r\n    return this._max;\r\n  }\r\n  set max(value: Date | null) {\r\n    this._max = value;\r\n    this._maxYear = value && value.getUTCFullYear();\r\n    this._maxMonth = value && value.getUTCMonth();\r\n    this._setYearsDisabled();\r\n    this._setMonthsDisabled();\r\n    this._setDaysDisabled();\r\n  }\r\n\r\n  @Input() date: Date | null = null;\r\n  @Output() dateChange = new EventEmitter();\r\n  formattedDate: string | null = null;\r\n\r\n  constructor(@Inject(LOCALE_ID) private readonly _locale: string,\r\n              @Optional() @Inject(DATEPICKER_DEFAULT_OPTIONS) private readonly _defaultConfig: DatepickerConfig,\r\n              @Optional() @Inject(DatepickerAdapter) private readonly datepickerAdapter: DatepickerAdapter,\r\n              defaultDatepickerAdapter: DefaultDatepickerAdapter) {\r\n    this._setInnerConfig();\r\n    this.datepickerAdapter = this.datepickerAdapter || defaultDatepickerAdapter;\r\n\r\n    this.weekDayNames = this.datepickerAdapter.getWeekDaysNames(this.firstDayOfWeek);\r\n\r\n    this._setDate(null);\r\n    this.setYearGroups(this.currentMonth.utcYear - 2);\r\n    this._setMonthGroups();\r\n  }\r\n\r\n  setYearGroups(baseYear: number) {\r\n    this.baseYear = baseYear;\r\n    this.yearGroups.length = 0;\r\n\r\n    for (let g = 0; g < this._yearsGroupsCount; g++) {\r\n      const yearGroup: Year[] = [];\r\n\r\n      this.yearGroups.push(yearGroup);\r\n      for (let y = 0; y < this._yearsPerGroup; y++) {\r\n        yearGroup.push({\r\n          year: baseYear,\r\n          disabled: this._isYearDisabled(baseYear)\r\n        });\r\n        baseYear++;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _setInnerConfig(): void {\r\n    const config: DatepickerConfig = {\r\n      ...DefaultDatepickerConfig,\r\n      firstDayOfWeek: getLocaleFirstDayOfWeek(this._locale),\r\n      ...this._defaultConfig\r\n    };\r\n\r\n    this.clearLabel = config.clearLabel ?? null;\r\n    this.hideClear = config.hideClear ?? false;\r\n    this.firstDayOfWeek = config.firstDayOfWeek!;\r\n  }\r\n\r\n  private _setMonthGroups() {\r\n    let m = 0;\r\n\r\n    while (m < 12) {\r\n      const monthGroup: Month[] = [];\r\n      this.monthGroups.push(monthGroup);\r\n\r\n      for (let i = 0; i < this.monthsPerGroup; i++) {\r\n        monthGroup.push(this.getMonth(new Date(this.baseYear, m)));\r\n        m++;\r\n      }\r\n    }\r\n  }\r\n\r\n  setYear(year: number) {\r\n    this._setCurrentMonth(new Date(year, this.currentMonth.utcMonth));\r\n  }\r\n\r\n  setMonth(month: Month) {\r\n    this._setCurrentMonth(new Date(this.currentMonth.utcYear, month.utcMonth));\r\n  }\r\n\r\n  protected _setDate(date: Date | null) {\r\n    this.date = date;\r\n    this.formattedDate = this.datepickerAdapter.formatDate(date);\r\n\r\n    date = date || new Date();\r\n    this._setCurrentMonth(new Date(date.getUTCFullYear(), date.getUTCMonth()));\r\n  }\r\n\r\n  private getMonth(date: Date): Month {\r\n    const month = {\r\n      date: date,\r\n      utcYear: date.getUTCFullYear(),\r\n      utcMonth: date.getUTCMonth(),\r\n      name: this.datepickerAdapter.getMonthName(date),\r\n      nameWithYear: this.datepickerAdapter.getMonthWithYear(date),\r\n      formattedYear: this.datepickerAdapter.getYear(date),\r\n      disabled: false\r\n    };\r\n\r\n    month.disabled = this._isMonthDisabled(month);\r\n\r\n    return month;\r\n  }\r\n\r\n  private _addToCurrentMonth(value: number) {\r\n    this._setCurrentMonth(new Date(this.currentMonth.utcYear, this.currentMonth.utcMonth + value));\r\n  }\r\n\r\n  private _getCurrentMonthInitialDate(): Date {\r\n    return new Date(this.currentMonth.utcYear, this.currentMonth.utcMonth);\r\n  }\r\n\r\n  private _getInitialDateForCurrentMonth(): Date {\r\n    const currentMonthInitialDate = this._getCurrentMonthInitialDate();\r\n\r\n    if (currentMonthInitialDate.getDay() === this.firstDayOfWeek) {\r\n      return currentMonthInitialDate;\r\n    }\r\n\r\n    if (currentMonthInitialDate.getDay() > this.firstDayOfWeek!) {\r\n      currentMonthInitialDate\r\n        .setDate(currentMonthInitialDate.getDate() - (currentMonthInitialDate.getDay() - this.firstDayOfWeek!));\r\n    } else {\r\n      currentMonthInitialDate\r\n        .setDate(currentMonthInitialDate.getDate() - (WeekDay.Saturday - (this.firstDayOfWeek! - currentMonthInitialDate.getDay() - 1)));\r\n    }\r\n\r\n    return currentMonthInitialDate;\r\n  }\r\n\r\n  private _setCurrentMonth(date: Date) {\r\n    const previousMonth = this.currentMonth;\r\n    const newMonth = this.getMonth(date);\r\n\r\n    if (previousMonth && previousMonth.date.getTime() === newMonth.date.getTime()) {\r\n      return;\r\n    }\r\n\r\n    this.currentMonth = newMonth;\r\n    this.currentMonthChange.emit(this.currentMonth);\r\n\r\n    this.weeks.length = 0;\r\n    const processDate = new Date(this._getInitialDateForCurrentMonth());\r\n\r\n    do {\r\n      const currentWeek: Week = {\r\n        baseDate: new Date(processDate),\r\n        days: []\r\n      };\r\n\r\n      this.weeks.push(currentWeek);\r\n\r\n      for (let i = 0; i < this._totalDaysOfWeek; i++) {\r\n        const dayDate = new Date(processDate);\r\n        currentWeek.days.push({\r\n          date: dayDate,\r\n          outsideMonth: processDate.getMonth() !== this.currentMonth.utcMonth,\r\n          disabled: this._isDayDisabled(dayDate)\r\n        });\r\n\r\n        processDate.setDate(processDate.getDate() + 1);\r\n      }\r\n    } while (processDate.getUTCMonth() === this.currentMonth.utcMonth);\r\n\r\n    this._setMonthsDisabled();\r\n  }\r\n\r\n  showNextMonth() {\r\n    this._addToCurrentMonth(1);\r\n  }\r\n\r\n  showPreviousMonth() {\r\n    this._addToCurrentMonth(-1);\r\n  }\r\n\r\n  private _isDayDisabled(date: Date): boolean {\r\n    return !!this.min && date < this.min || !!this.max && date > this.max;\r\n  }\r\n\r\n  private _setDaysDisabled(): void {\r\n    for (const week of this.weeks) {\r\n      for (const day of week.days) {\r\n        day.disabled = this._isDayDisabled(day.date);\r\n      }\r\n    }\r\n  }\r\n\r\n  private _isMonthDisabled(month: Month): boolean {\r\n    return this.currentMonth\r\n      && (this._isYearDisabled(this.currentMonth.utcYear)\r\n        || (this.currentMonth.utcYear === this._minYear && month.utcMonth < this._minMonth!)\r\n        || (this.currentMonth.utcYear === this._maxYear && month.utcMonth > this._maxMonth!));\r\n  }\r\n\r\n  private _setMonthsDisabled(): void {\r\n    for (const monthGroup of this.monthGroups) {\r\n      for (const month of monthGroup) {\r\n        month.disabled = this._isMonthDisabled(month);\r\n      }\r\n    }\r\n  }\r\n\r\n  private _isYearDisabled(year: number): boolean {\r\n    return !!this._minYear && year < this._minYear || !!this._maxYear && year > this._maxYear;\r\n  }\r\n\r\n  private _setYearsDisabled(): void {\r\n    for (const yearGroup of this.yearGroups) {\r\n      for (const year of yearGroup) {\r\n        year.disabled = this._isYearDisabled(year.year);\r\n      }\r\n    }\r\n  }\r\n\r\n  selectDate(date: Date | null): void {\r\n    this._setDate(date);\r\n    this.dateChange.emit(date);\r\n  }\r\n\r\n  private _datesAreEqual(dateA: Date, dateB: Date) {\r\n    return dateA.getUTCMonth() === dateB.getUTCMonth()\r\n      && dateA.getUTCFullYear() === dateB.getUTCFullYear()\r\n      && dateA.getDate() === dateB.getDate();\r\n  }\r\n\r\n  isEqualToSelectedDate(date: Date) {\r\n    return this.date && this._datesAreEqual(this.date, date);\r\n  }\r\n\r\n  isEqualToTodayDate(date: Date) {\r\n    return this._datesAreEqual(new Date(), date);\r\n  }\r\n\r\n  trackByWeek(index: number, week: Week) {\r\n    return week.baseDate.getTime();\r\n  }\r\n\r\n  trackByDay(index: number, day: DayOfWeek) {\r\n    return day.date.getTime();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    let dateChange = changes['date'];\r\n\r\n    if (dateChange && dateChange.currentValue && dateChange.currentValue !== dateChange.previousValue) {\r\n      this._setDate(dateChange.currentValue);\r\n    }\r\n  }\r\n}\r\n"]}