@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
JavaScript
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"]}