materialize-angular
Version:
Material UI Angular library
387 lines • 34.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: app/completed-components/calendar/calendar.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @license
* Copyright Workylab. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE
*/
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { config } from '../../config';
import { days } from '../../fixtures/calendar-week-days';
import { months } from '../../fixtures/calendar-months';
export class CalendarComponent {
constructor() {
this.className = CalendarComponent.defaultProps.className;
this.date = CalendarComponent.defaultProps.date;
this.displayOtherMonthDays = CalendarComponent.defaultProps.displayOtherMonthDays;
this.prefix = config.components.prefix;
this.selectYearAnimationDuration = 150;
this.scrollToActiveYear = this.scrollToActiveYear.bind(this);
this.onSelectDayEmitter = new EventEmitter();
this.dayLabels = this.getDayLabels(days);
this.monthLabels = this.getMonthLabels(months);
}
/**
* @return {?}
*/
ngOnInit() {
this.init();
}
/**
* @return {?}
*/
ngOnChanges() {
this.init();
}
/**
* @return {?}
*/
init() {
/** @type {?} */
const dateExists = (typeof this.date !== 'undefined' && this.date !== null);
/** @type {?} */
const openDate = dateExists ? this.date : new Date();
/** @type {?} */
const isToday = this.isTodayDate(openDate);
/** @type {?} */
const month = openDate.getMonth();
/** @type {?} */
const year = openDate.getFullYear();
this.weeks = this.fillWeeks(month, year);
this.years = this.fillYears(year);
this.selectedDate = this.createDateModel(openDate, false, isToday, dateExists);
}
/**
* @param {?} dayLabels
* @return {?}
*/
getDayLabels(dayLabels) {
return [
dayLabels.sunday,
dayLabels.monday,
dayLabels.tuesday,
dayLabels.wednesday,
dayLabels.thursday,
dayLabels.friday,
dayLabels.saturday
];
}
/**
* @param {?} monthLabels
* @return {?}
*/
getMonthLabels(monthLabels) {
return [
monthLabels.january,
monthLabels.february,
monthLabels.march,
monthLabels.april,
monthLabels.may,
monthLabels.june,
monthLabels.july,
monthLabels.august,
monthLabels.september,
monthLabels.october,
monthLabels.november,
monthLabels.december
];
}
/**
* @param {?} date
* @param {?} isOutOfMonth
* @param {?} isToday
* @param {?} showSelected
* @return {?}
*/
createDateModel(date, isOutOfMonth, isToday, showSelected) {
/** @type {?} */
const weekDay = date.getDay();
/** @type {?} */
const month = date.getMonth();
/** @type {?} */
const dateModel = {
ISODate: this.generateISODate(date),
date: date,
dayLabel: this.dayLabels[weekDay],
isOutOfMonth: isOutOfMonth,
isToday: isToday,
monthLabel: this.monthLabels[month],
showSelected: showSelected
};
return dateModel;
}
/**
* @param {?} day
* @param {?} month
* @param {?} year
* @return {?}
*/
createDateObject(day, month, year) {
/** @type {?} */
const date = new Date();
date.setDate(day);
date.setMonth(month);
date.setFullYear(year);
return date;
}
/**
* @param {?} currentYear
* @return {?}
*/
fillYears(currentYear) {
/** @type {?} */
const firstYear = currentYear - 100;
/** @type {?} */
const lastYear = currentYear + 100;
/** @type {?} */
const years = [];
for (let i = firstYear; i <= lastYear; i++) {
years.push(i);
}
return years;
}
/**
* @param {?} month
* @param {?} year
* @return {?}
*/
fillWeeks(month, year) {
this.selectedMonth = {
label: this.monthLabels[month],
number: month,
year: year
};
/** @type {?} */
const finalMonthDay = this.createDateObject(0, month, year);
/** @type {?} */
const weeks = [];
/** @type {?} */
let initMonthDate = new Date(year, month, 1);
/** @type {?} */
let day = 0 - initMonthDate.getDay();
/** @type {?} */
let daysInWeek = [];
while (initMonthDate.getDay() !== 0 || finalMonthDay >= initMonthDate) {
++day;
initMonthDate = new Date(year, month, day);
daysInWeek.push(this.createDayDate(initMonthDate, day, finalMonthDay));
if (daysInWeek.length === 7) {
weeks.push(daysInWeek);
daysInWeek = [];
}
}
return weeks;
}
/**
* @param {?} date
* @return {?}
*/
isTodayDate(date) {
/** @type {?} */
const ISOCurrentDate = this.generateISODate(new Date());
/** @type {?} */
const ISODate = this.generateISODate(date);
/** @type {?} */
const isToday = (ISODate === ISOCurrentDate);
return isToday;
}
/**
* @param {?} date
* @param {?} dayNumber
* @param {?} finalMonthDay
* @return {?}
*/
createDayDate(date, dayNumber, finalMonthDay) {
/** @type {?} */
const isToday = this.isTodayDate(date);
/** @type {?} */
const isOutOfMonth = (dayNumber <= 0 || date > finalMonthDay);
return this.createDateModel(date, isOutOfMonth, isToday, true);
}
/**
* @return {?}
*/
showPrevMonth() {
/** @type {?} */
const month = this.selectedMonth.number;
/** @type {?} */
const year = this.selectedMonth.year;
/** @type {?} */
const prevMonth = month >= 1
? month - 1
: 11;
/** @type {?} */
const prevYear = month < 1
? year - 1
: year;
this.weeks = this.fillWeeks(prevMonth, prevYear);
}
/**
* @return {?}
*/
showNextMonth() {
/** @type {?} */
const month = this.selectedMonth.number;
/** @type {?} */
const year = this.selectedMonth.year;
/** @type {?} */
const nextMonth = month < 11
? month + 1
: 0;
/** @type {?} */
const nextYear = month >= 11
? year + 1
: year;
this.weeks = this.fillWeeks(nextMonth, nextYear);
}
/**
* @param {?} date
* @return {?}
*/
generateISODate(date) {
/** @type {?} */
const day = date.getDate();
/** @type {?} */
const month = date.getMonth() + 1;
/** @type {?} */
const year = date.getFullYear();
/** @type {?} */
const dayString = day > 9
? day
: `0${day}`;
/** @type {?} */
const monthString = month > 9
? month
: `0${month}`;
return `${year}-${monthString}-${dayString}`;
}
/**
* @param {?} date
* @return {?}
*/
onSelectDay(date) {
if (date.isOutOfMonth) {
return;
}
this.selectedDate = date;
this.onSelectDayEmitter.emit(this.selectedDate);
}
/**
* @param {?} year
* @return {?}
*/
onSelectYear(year) {
setTimeout((/**
* @return {?}
*/
() => {
/** @type {?} */
const day = this.selectedDate.date.getDate();
/** @type {?} */
const month = this.selectedDate.date.getMonth();
this.date = this.createDateObject(day, month, year);
this.showYears = false;
this.selectedDate = this.createDateModel(this.date, false, true, true);
this.weeks = this.fillWeeks(month, year);
}), this.selectYearAnimationDuration);
}
/**
* @return {?}
*/
displayYears() {
this.showYears = true;
setTimeout(this.scrollToActiveYear, 0);
}
/**
* @return {?}
*/
scrollToActiveYear() {
const { nativeElement } = this.yearsContainerRef;
/** @type {?} */
const activeYear = nativeElement.querySelector('.selected');
if (activeYear) {
/** @type {?} */
const top = this.getScrollCenter(nativeElement, activeYear);
nativeElement.scrollTop = top;
}
}
/**
* @param {?} container
* @param {?} internalElement
* @return {?}
*/
getScrollCenter(container, internalElement) {
/** @type {?} */
const yearTop = internalElement.offsetTop;
/** @type {?} */
const yearMiddleHeight = internalElement.offsetHeight / 2;
/** @type {?} */
const containerTop = container.offsetTop;
/** @type {?} */
const containerMiddleHeight = container.offsetHeight / 2;
/** @type {?} */
const elementRelativeTop = (yearTop - containerTop) - (containerMiddleHeight - yearMiddleHeight);
if (elementRelativeTop < 0) {
return 0;
}
return elementRelativeTop;
}
}
CalendarComponent.defaultProps = {
className: '',
date: new Date(),
displayOtherMonthDays: true
};
CalendarComponent.decorators = [
{ type: Component, args: [{
selector: `${config.components.prefix}-calendar }`,
template: "<div [ngClass]=\"[prefix + '-calendar', className]\">\n <div [ngClass]=\"prefix + '-calendar-header'\">\n <div [ngClass]=\"prefix + '-calendar-year'\">\n <materialize-button (onClick)=\"displayYears()\">{{ selectedMonth.year }}</materialize-button>\n </div>\n <div [ngClass]=\"prefix + '-calendar-date'\">\n <materialize-button (onClick)=\"showYears = false\">\n {{ selectedDate.dayLabel.shortName }}, {{ selectedDate.monthLabel.shortName }} {{ selectedDate.date.getDate() }}\n </materialize-button>\n </div>\n </div>\n\n <div [ngClass]=\"prefix + '-calendar-body'\">\n <ng-container *ngIf=\"!showYears\">\n <div [ngClass]=\"prefix + '-calendar-controls'\">\n <div [ngClass]=\"prefix + '-calendar-control'\" materializeRipple (click)=\"showPrevMonth()\">\n <materialize-icon>chevron_left</materialize-icon>\n </div>\n <div [ngClass]=\"prefix + '-calendar-month'\">\n {{ selectedMonth.label.shortName }} {{ selectedMonth.year }}\n </div>\n <div [ngClass]=\"prefix + '-calendar-control'\" materializeRipple (click)=\"showNextMonth()\">\n <materialize-icon>chevron_right</materialize-icon>\n </div>\n </div>\n \n <table [ngClass]=\"prefix + '-calendar-table'\">\n <thead>\n <tr>\n <td [ngClass]=\"prefix + '-calendar-day-name'\" *ngFor=\"let day of dayLabels\">{{ day.shortestName }}</td>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let week of weeks\">\n <td *ngFor=\"let day of week\">\n <div [ngClass]=\"prefix + '-calendar-day'\"\n (click)=\"onSelectDay(day)\"\n *ngIf=\"!day.isOutOfMonth || displayOtherMonthDays\"\n \n [class.current]=\"day.isToday\"\n [class.selected]=\"selectedDate.showSelected && selectedDate.ISODate === day.ISODate\"\n [class.disabled]=\"day.isOutOfMonth\"\n \n materializeRipple\n [rippleDuration]=\"800\"\n >\n {{ day.date.getDate() }}\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n </ng-container>\n \n <div [ngClass]=\"prefix + '-calendar-years'\" #yearsContainer>\n <ng-container *ngIf=\"showYears\">\n <div [ngClass]=\"prefix + '-calendar-year-option'\"\n *ngFor=\"let year of years\"\n\n (click)=\"onSelectYear(year)\"\n [class.selected]=\"year === selectedMonth.year\"\n\n materializeRipple\n [rippleDuration]=\"selectYearAnimationDuration\"\n >\n {{ year }}\n </div>\n </ng-container>\n </div>\n </div>\n</div>\n"
}] }
];
/** @nocollapse */
CalendarComponent.ctorParameters = () => [];
CalendarComponent.propDecorators = {
yearsContainerRef: [{ type: ViewChild, args: ['yearsContainer', { static: false },] }],
onSelectDayEmitter: [{ type: Output, args: ['onSelectDay',] }],
className: [{ type: Input }],
date: [{ type: Input }],
displayOtherMonthDays: [{ type: Input }]
};
if (false) {
/** @type {?} */
CalendarComponent.defaultProps;
/** @type {?} */
CalendarComponent.prototype.yearsContainerRef;
/** @type {?} */
CalendarComponent.prototype.onSelectDayEmitter;
/** @type {?} */
CalendarComponent.prototype.className;
/** @type {?} */
CalendarComponent.prototype.date;
/** @type {?} */
CalendarComponent.prototype.displayOtherMonthDays;
/** @type {?} */
CalendarComponent.prototype.prefix;
/** @type {?} */
CalendarComponent.prototype.dayLabels;
/** @type {?} */
CalendarComponent.prototype.monthLabels;
/** @type {?} */
CalendarComponent.prototype.selectedDate;
/** @type {?} */
CalendarComponent.prototype.selectedMonth;
/** @type {?} */
CalendarComponent.prototype.showYears;
/** @type {?} */
CalendarComponent.prototype.weeks;
/** @type {?} */
CalendarComponent.prototype.years;
/** @type {?} */
CalendarComponent.prototype.selectYearAnimationDuration;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"ng://materialize-angular/","sources":["app/completed-components/calendar/calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Workylab. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE\n */\n\nimport { CalendarModel, DateLabel, DateModel, DayLabels, MonthLabels, MonthModel } from './calendar.model';\nimport { Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, ViewChild } from '@angular/core';\nimport { config } from '../../config';\nimport { days } from '../../fixtures/calendar-week-days';\nimport { months } from '../../fixtures/calendar-months';\n\n@Component({\n  selector: `${ config.components.prefix }-calendar }`,\n  templateUrl: './calendar.component.html'\n})\nexport class CalendarComponent implements OnInit, OnChanges {\n  static readonly defaultProps: CalendarModel = {\n    className: '',\n    date: new Date(),\n    displayOtherMonthDays: true\n  };\n\n  @ViewChild('yearsContainer', { static: false }) yearsContainerRef: ElementRef;\n\n  @Output('onSelectDay') onSelectDayEmitter: EventEmitter<DateModel>;\n\n  @Input() className: string = CalendarComponent.defaultProps.className;\n  @Input() date: Date = CalendarComponent.defaultProps.date;\n  @Input() displayOtherMonthDays: boolean = CalendarComponent.defaultProps.displayOtherMonthDays;\n\n  public prefix = config.components.prefix;\n\n  public dayLabels: Array<DateLabel>;\n  public monthLabels: Array<DateLabel>;\n  public selectedDate: DateModel;\n  public selectedMonth: MonthModel;\n  public showYears: boolean;\n  public weeks: Array<Array<DateModel>>;\n  public years: Array<number>;\n\n  public selectYearAnimationDuration = 150;\n\n  constructor() {\n    this.scrollToActiveYear = this.scrollToActiveYear.bind(this);\n\n    this.onSelectDayEmitter = new EventEmitter<DateModel>();\n\n    this.dayLabels = this.getDayLabels(days);\n    this.monthLabels = this.getMonthLabels(months);\n  }\n\n  ngOnInit() {\n    this.init();\n  }\n\n  ngOnChanges() {\n    this.init();\n  }\n\n  init() {\n    const dateExists = (typeof this.date !== 'undefined' && this.date !== null);\n    const openDate = dateExists ? this.date : new Date();\n    const isToday = this.isTodayDate(openDate);\n    const month = openDate.getMonth();\n    const year = openDate.getFullYear();\n\n    this.weeks = this.fillWeeks(month, year);\n    this.years = this.fillYears(year);\n\n    this.selectedDate = this.createDateModel(openDate, false, isToday, dateExists);\n  }\n\n  getDayLabels(dayLabels: DayLabels): Array<DateLabel> {\n    return [\n      dayLabels.sunday,\n      dayLabels.monday,\n      dayLabels.tuesday,\n      dayLabels.wednesday,\n      dayLabels.thursday,\n      dayLabels.friday,\n      dayLabels.saturday\n    ];\n  }\n\n  getMonthLabels(monthLabels: MonthLabels): Array<DateLabel> {\n    return [\n      monthLabels.january,\n      monthLabels.february,\n      monthLabels.march,\n      monthLabels.april,\n      monthLabels.may,\n      monthLabels.june,\n      monthLabels.july,\n      monthLabels.august,\n      monthLabels.september,\n      monthLabels.october,\n      monthLabels.november,\n      monthLabels.december\n    ];\n  }\n\n  createDateModel(date: Date, isOutOfMonth: boolean, isToday: boolean, showSelected: boolean): DateModel {\n    const weekDay = date.getDay();\n    const month = date.getMonth();\n\n    const dateModel: DateModel = {\n      ISODate: this.generateISODate(date),\n      date: date,\n      dayLabel: this.dayLabels[weekDay],\n      isOutOfMonth: isOutOfMonth,\n      isToday: isToday,\n      monthLabel: this.monthLabels[month],\n      showSelected: showSelected\n    };\n\n    return dateModel;\n  }\n\n  createDateObject(day: number, month: number, year: number): Date {\n    const date = new Date();\n\n    date.setDate(day);\n    date.setMonth(month);\n    date.setFullYear(year);\n\n    return date;\n  }\n\n  fillYears(currentYear: number): Array<number> {\n    const firstYear = currentYear - 100;\n    const lastYear = currentYear + 100;\n    const years = [];\n\n    for (let i = firstYear; i <= lastYear; i++) {\n      years.push(i);\n    }\n\n    return years;\n  }\n\n  fillWeeks(month: number, year: number) {\n    this.selectedMonth = {\n      label: this.monthLabels[month],\n      number: month,\n      year: year\n    };\n\n    const finalMonthDay = this.createDateObject(0, month, year);\n    const weeks = [];\n\n    let initMonthDate = new Date(year, month, 1);\n    let day = 0 - initMonthDate.getDay();\n    let daysInWeek = [];\n\n    while (initMonthDate.getDay() !== 0 || finalMonthDay >= initMonthDate) {\n      ++day;\n\n      initMonthDate = new Date(year, month, day);\n\n      daysInWeek.push(this.createDayDate(initMonthDate, day, finalMonthDay));\n\n      if (daysInWeek.length === 7) {\n        weeks.push(daysInWeek);\n        daysInWeek = [];\n      }\n    }\n\n    return weeks;\n  }\n\n  isTodayDate(date: Date) {\n    const ISOCurrentDate = this.generateISODate(new Date());\n    const ISODate = this.generateISODate(date);\n    const isToday = (ISODate === ISOCurrentDate);\n\n    return isToday;\n  }\n\n  createDayDate(date: Date, dayNumber: number, finalMonthDay: Date): DateModel {\n    const isToday = this.isTodayDate(date);\n    const isOutOfMonth = (dayNumber <= 0 || date > finalMonthDay);\n\n    return this.createDateModel(date, isOutOfMonth, isToday, true);\n  }\n\n  showPrevMonth() {\n    const month = this.selectedMonth.number;\n    const year = this.selectedMonth.year;\n\n    const prevMonth = month >= 1\n      ? month - 1\n      : 11;\n\n    const prevYear = month < 1\n      ? year - 1\n      : year;\n\n    this.weeks = this.fillWeeks(prevMonth, prevYear);\n  }\n\n  showNextMonth() {\n    const month = this.selectedMonth.number;\n    const year = this.selectedMonth.year;\n\n    const nextMonth = month < 11\n      ? month + 1\n      : 0;\n\n    const nextYear = month >= 11\n      ? year + 1\n      : year;\n\n    this.weeks = this.fillWeeks(nextMonth, nextYear);\n  }\n\n  generateISODate(date: Date) {\n    const day = date.getDate();\n    const month = date.getMonth() + 1;\n    const year = date.getFullYear();\n\n    const dayString = day > 9\n      ? day\n      : `0${ day }`;\n\n    const monthString = month > 9\n      ? month\n      : `0${ month }`;\n\n    return `${ year }-${ monthString }-${ dayString }`;\n  }\n\n  onSelectDay(date: DateModel) {\n    if (date.isOutOfMonth) {\n      return;\n    }\n\n    this.selectedDate = date;\n    this.onSelectDayEmitter.emit(this.selectedDate);\n  }\n\n  onSelectYear(year: number) {\n    setTimeout(() => {\n      const day = this.selectedDate.date.getDate();\n      const month = this.selectedDate.date.getMonth();\n\n      this.date = this.createDateObject(day, month, year);\n      this.showYears = false;\n      this.selectedDate = this.createDateModel(this.date, false, true, true);\n\n      this.weeks = this.fillWeeks(month, year);\n    }, this.selectYearAnimationDuration);\n  }\n\n  displayYears() {\n    this.showYears = true;\n\n    setTimeout(this.scrollToActiveYear, 0);\n  }\n\n  scrollToActiveYear() {\n    const { nativeElement } = this.yearsContainerRef;\n    const activeYear: HTMLElement = nativeElement.querySelector('.selected');\n\n    if (activeYear) {\n      const top = this.getScrollCenter(nativeElement, activeYear);\n\n      nativeElement.scrollTop = top;\n    }\n  }\n\n  getScrollCenter(container: HTMLElement, internalElement: HTMLElement): number {\n    const yearTop = internalElement.offsetTop;\n    const yearMiddleHeight = internalElement.offsetHeight / 2;\n\n    const containerTop = container.offsetTop;\n    const containerMiddleHeight = container.offsetHeight / 2;\n\n    const elementRelativeTop = (yearTop - containerTop) - (containerMiddleHeight - yearMiddleHeight);\n\n    if (elementRelativeTop < 0) {\n      return 0;\n    }\n\n    return elementRelativeTop;\n  }\n}\n"]}