UNPKG

materialize-angular

Version:
468 lines 36.9 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'; var CalendarComponent = /** @class */ (function () { function CalendarComponent() { 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 {?} */ CalendarComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.init(); }; /** * @return {?} */ CalendarComponent.prototype.ngOnChanges = /** * @return {?} */ function () { this.init(); }; /** * @return {?} */ CalendarComponent.prototype.init = /** * @return {?} */ function () { /** @type {?} */ var dateExists = (typeof this.date !== 'undefined' && this.date !== null); /** @type {?} */ var openDate = dateExists ? this.date : new Date(); /** @type {?} */ var isToday = this.isTodayDate(openDate); /** @type {?} */ var month = openDate.getMonth(); /** @type {?} */ var 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 {?} */ CalendarComponent.prototype.getDayLabels = /** * @param {?} dayLabels * @return {?} */ function (dayLabels) { return [ dayLabels.sunday, dayLabels.monday, dayLabels.tuesday, dayLabels.wednesday, dayLabels.thursday, dayLabels.friday, dayLabels.saturday ]; }; /** * @param {?} monthLabels * @return {?} */ CalendarComponent.prototype.getMonthLabels = /** * @param {?} monthLabels * @return {?} */ function (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 {?} */ CalendarComponent.prototype.createDateModel = /** * @param {?} date * @param {?} isOutOfMonth * @param {?} isToday * @param {?} showSelected * @return {?} */ function (date, isOutOfMonth, isToday, showSelected) { /** @type {?} */ var weekDay = date.getDay(); /** @type {?} */ var month = date.getMonth(); /** @type {?} */ var 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 {?} */ CalendarComponent.prototype.createDateObject = /** * @param {?} day * @param {?} month * @param {?} year * @return {?} */ function (day, month, year) { /** @type {?} */ var date = new Date(); date.setDate(day); date.setMonth(month); date.setFullYear(year); return date; }; /** * @param {?} currentYear * @return {?} */ CalendarComponent.prototype.fillYears = /** * @param {?} currentYear * @return {?} */ function (currentYear) { /** @type {?} */ var firstYear = currentYear - 100; /** @type {?} */ var lastYear = currentYear + 100; /** @type {?} */ var years = []; for (var i = firstYear; i <= lastYear; i++) { years.push(i); } return years; }; /** * @param {?} month * @param {?} year * @return {?} */ CalendarComponent.prototype.fillWeeks = /** * @param {?} month * @param {?} year * @return {?} */ function (month, year) { this.selectedMonth = { label: this.monthLabels[month], number: month, year: year }; /** @type {?} */ var finalMonthDay = this.createDateObject(0, month, year); /** @type {?} */ var weeks = []; /** @type {?} */ var initMonthDate = new Date(year, month, 1); /** @type {?} */ var day = 0 - initMonthDate.getDay(); /** @type {?} */ var 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 {?} */ CalendarComponent.prototype.isTodayDate = /** * @param {?} date * @return {?} */ function (date) { /** @type {?} */ var ISOCurrentDate = this.generateISODate(new Date()); /** @type {?} */ var ISODate = this.generateISODate(date); /** @type {?} */ var isToday = (ISODate === ISOCurrentDate); return isToday; }; /** * @param {?} date * @param {?} dayNumber * @param {?} finalMonthDay * @return {?} */ CalendarComponent.prototype.createDayDate = /** * @param {?} date * @param {?} dayNumber * @param {?} finalMonthDay * @return {?} */ function (date, dayNumber, finalMonthDay) { /** @type {?} */ var isToday = this.isTodayDate(date); /** @type {?} */ var isOutOfMonth = (dayNumber <= 0 || date > finalMonthDay); return this.createDateModel(date, isOutOfMonth, isToday, true); }; /** * @return {?} */ CalendarComponent.prototype.showPrevMonth = /** * @return {?} */ function () { /** @type {?} */ var month = this.selectedMonth.number; /** @type {?} */ var year = this.selectedMonth.year; /** @type {?} */ var prevMonth = month >= 1 ? month - 1 : 11; /** @type {?} */ var prevYear = month < 1 ? year - 1 : year; this.weeks = this.fillWeeks(prevMonth, prevYear); }; /** * @return {?} */ CalendarComponent.prototype.showNextMonth = /** * @return {?} */ function () { /** @type {?} */ var month = this.selectedMonth.number; /** @type {?} */ var year = this.selectedMonth.year; /** @type {?} */ var nextMonth = month < 11 ? month + 1 : 0; /** @type {?} */ var nextYear = month >= 11 ? year + 1 : year; this.weeks = this.fillWeeks(nextMonth, nextYear); }; /** * @param {?} date * @return {?} */ CalendarComponent.prototype.generateISODate = /** * @param {?} date * @return {?} */ function (date) { /** @type {?} */ var day = date.getDate(); /** @type {?} */ var month = date.getMonth() + 1; /** @type {?} */ var year = date.getFullYear(); /** @type {?} */ var dayString = day > 9 ? day : "0" + day; /** @type {?} */ var monthString = month > 9 ? month : "0" + month; return year + "-" + monthString + "-" + dayString; }; /** * @param {?} date * @return {?} */ CalendarComponent.prototype.onSelectDay = /** * @param {?} date * @return {?} */ function (date) { if (date.isOutOfMonth) { return; } this.selectedDate = date; this.onSelectDayEmitter.emit(this.selectedDate); }; /** * @param {?} year * @return {?} */ CalendarComponent.prototype.onSelectYear = /** * @param {?} year * @return {?} */ function (year) { var _this = this; setTimeout((/** * @return {?} */ function () { /** @type {?} */ var day = _this.selectedDate.date.getDate(); /** @type {?} */ var 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 {?} */ CalendarComponent.prototype.displayYears = /** * @return {?} */ function () { this.showYears = true; setTimeout(this.scrollToActiveYear, 0); }; /** * @return {?} */ CalendarComponent.prototype.scrollToActiveYear = /** * @return {?} */ function () { var nativeElement = this.yearsContainerRef.nativeElement; /** @type {?} */ var activeYear = nativeElement.querySelector('.selected'); if (activeYear) { /** @type {?} */ var top_1 = this.getScrollCenter(nativeElement, activeYear); nativeElement.scrollTop = top_1; } }; /** * @param {?} container * @param {?} internalElement * @return {?} */ CalendarComponent.prototype.getScrollCenter = /** * @param {?} container * @param {?} internalElement * @return {?} */ function (container, internalElement) { /** @type {?} */ var yearTop = internalElement.offsetTop; /** @type {?} */ var yearMiddleHeight = internalElement.offsetHeight / 2; /** @type {?} */ var containerTop = container.offsetTop; /** @type {?} */ var containerMiddleHeight = container.offsetHeight / 2; /** @type {?} */ var 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 = function () { return []; }; CalendarComponent.propDecorators = { yearsContainerRef: [{ type: ViewChild, args: ['yearsContainer', { static: false },] }], onSelectDayEmitter: [{ type: Output, args: ['onSelectDay',] }], className: [{ type: Input }], date: [{ type: Input }], displayOtherMonthDays: [{ type: Input }] }; return CalendarComponent; }()); export { CalendarComponent }; 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"]}