UNPKG

materialize-angular

Version:
387 lines 34.5 kB
/** * @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"]}