@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
306 lines • 41.1 kB
JavaScript
import * as tslib_1 from "tslib";
var CalendarComponent_1;
/**
* Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.
* @link https://truedirective.com/
* @license MIT
*/
import { Component, Output, EventEmitter, ChangeDetectorRef, ElementRef, ViewChild, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { Keys } from '@true-directive/base';
import { Dates } from '@true-directive/base';
import { InternationalizationService } from '../internationalization/internationalization.service';
/**
* Calendar component.
*/
let CalendarComponent = CalendarComponent_1 = class CalendarComponent {
constructor(intl, cd, el) {
this.intl = intl;
this.cd = cd;
this.el = el;
this.onChange = (_) => { };
this.onTouched = () => { };
this._value = null;
this.mode = 'days';
this.dateClick = new EventEmitter();
this.escape = new EventEmitter();
// Day names
this.dayNames = [];
// Month weeks
this.weeks = [];
// Year months
this.monthRows = [];
// Matrix of displayed years
this.yearRows = [];
this._minYear = 0;
this._maxYear = 0;
}
get value() {
return this._value;
}
set value(v) {
if (v !== this._value) {
this._value = v;
this.createWeeks(this._value);
this.onChange(v);
}
}
get valueTime() {
let vTime = 0;
if (this.value !== null && !isNaN(this.value.getTime())) {
vTime = this.value.getTime();
}
return vTime;
}
get monthYear() {
const m = this.calendarDateStart.getMonth();
const y = this.calendarDateStart.getFullYear();
if (this.mode === 'days') {
return this.intl.locale.longMonthNames[m] + ' ' + y;
}
if (this.mode === 'months') {
return y;
}
if (this.mode === 'years') {
return this._minYear + ' - ' + this._maxYear;
}
}
get today() {
return Dates.today();
}
registerOnChange(fn) { this.onChange = fn; }
registerOnTouched(fn) { this.onTouched = fn; }
blur() {
this.onTouched();
}
// Отображаем значение в компоненте. Formatter: Ctrl --> View
writeValue(value) {
if (this.value !== value) {
this.value = value;
}
}
setFocus() {
this.days.nativeElement.focus();
}
isCurrentMonth(d) {
return Dates.dateBetween(d, this.calendarDateStart, this.calendarDateEnd);
}
go(qty) {
if (this.mode === 'days') {
let newDate;
if (qty > 0) {
newDate = Dates.firstDateOfNextMonth(this.calendarDateStart);
}
else {
newDate = Dates.firstDateOfPrevMonth(this.calendarDateStart);
}
this.createWeeks(newDate);
}
if (this.mode === 'months') {
this.calendarDateStart = new Date(this.calendarDateStart.getFullYear() + qty, 0, 1);
this.createMonths();
}
if (this.mode === 'years') {
this.calendarDateStart = new Date(this.calendarDateStart.getFullYear() + 24 * qty, 0, 1);
this.createYears();
}
}
toggleMode() {
if (this.mode === 'years') {
this.mode = 'days';
this.createWeeks(this.calendarDateStart);
}
else {
if (this.mode === 'months') {
this.mode = 'years';
this.createYears();
}
else {
if (this.mode === 'days') {
this.mode = 'months';
this.createMonths();
}
}
}
this.setMode();
}
setMode() {
this.el.nativeElement.classList.remove('true-mode-days');
this.el.nativeElement.classList.remove('true-mode-months');
this.el.nativeElement.classList.remove('true-mode-years');
this.el.nativeElement.classList.add('true-mode-' + this.mode);
}
mousedown(e) {
e.stopPropagation();
}
calendarDateClick(e, d) {
if (this.mode === 'days') {
this.value = new Date(d);
this.dateClick.emit(d);
}
if (this.mode === 'months') {
this.mode = 'days';
this.createWeeks(new Date(d));
}
if (this.mode === 'years') {
this.calendarDateStart = new Date(d);
this.mode = 'months';
this.createMonths();
}
this.setMode();
e.preventDefault();
e.stopPropagation();
}
// List of dates in selected month
createDayNames() {
this.dayNames = [];
const weekStart = Dates.firstDateOfWeek(Dates.today(), this.intl.locale.firstDayOfWeek);
const weekEnd = Dates.lastDateOfWeek(weekStart, this.intl.locale.firstDayOfWeek);
for (let d = new Date(weekStart); d.getTime() <= weekEnd.getTime(); d = Dates.nextDate(d)) {
const wd = d.getDay();
const dayName = this.intl.locale.shortDayNames[wd];
this.dayNames.push(dayName);
}
}
// List of months to show in months-mode
createMonths() {
const yy = this.calendarDateStart.getFullYear();
const currentMonthStart = Dates.firstDateOfMonth(Dates.today());
let k = -3;
this.monthRows = [];
for (let i = 0; i < 6; i++) {
let monthRow = [];
for (let j = 0; j < 3; j++) {
// Month start
const dd = new Date(yy, k, 1);
monthRow.push({ name: this.intl.locale.shortMonthNames[dd.getMonth()] + ' ' + Dates.yearTwoDigits(dd),
date: dd,
selected: Dates.isSameMonth(dd, this.value),
today: dd.getTime() === currentMonthStart.getTime(),
current: Dates.isSameYear(dd, this.calendarDateStart) });
k++;
}
this.monthRows.push(monthRow);
}
}
// List of dates in selected month
createYears() {
const yy = this.calendarDateStart.getFullYear();
const currentYearStart = new Date(Dates.today().getFullYear(), 0, 1);
const calendarYearStart = new Date(this.calendarDateStart.getFullYear(), 0, 1);
this._minYear = yy - 11;
let k = this._minYear;
this.yearRows = [];
for (let i = 0; i < 6; i++) {
let yearRow = [];
for (let j = 0; j < 4; j++) {
const dd = new Date(k, 0, 1);
yearRow.push({ name: k + '',
date: dd,
selected: Dates.isSameYear(dd, this.value),
today: dd.getTime() === currentYearStart.getTime(),
current: true });
k++;
}
this.yearRows.push(yearRow);
}
this._maxYear = k - 1;
}
createWeeks(date) {
if (date === null || isNaN(date.getTime())) {
date = Dates.today();
}
const firstDayOfWeek = this.intl.locale.firstDayOfWeek;
const monthStart = Dates.firstDateOfMonth(date);
const monthEnd = Dates.lastDateOfMonth(date);
if (this.weeks.length > 0
&& this.calendarDateStart !== undefined && this.calendarDateStart.getTime() === monthStart.getTime()
&& this.calendarDateEnd !== undefined && this.calendarDateEnd.getTime() === monthEnd.getTime()) {
return;
}
this.weeks = [];
this.calendarDateStart = monthStart;
this.calendarDateEnd = monthEnd;
const calendarStart = Dates.firstDateOfWeek(monthStart, firstDayOfWeek);
// Iterating weeks of month
let weekStart = new Date(calendarStart);
let wCounter = 0;
while (wCounter < 6) {
let week = [];
let weekEnd = Dates.lastDateOfWeek(weekStart, firstDayOfWeek);
// Iterating days of week
for (let d = new Date(weekStart); d.getTime() <= weekEnd.getTime(); d = Dates.nextDate(d)) {
week.push(d);
}
this.weeks.push(week);
// Next week
weekStart = Dates.nextDate(weekEnd);
wCounter++;
}
}
daysKeyDown(e) {
let dd = 0;
if (e.keyCode === Keys.LEFT) {
dd = -1;
}
if (e.keyCode === Keys.UP) {
dd = -7;
}
if (e.keyCode === Keys.RIGHT) {
dd = 1;
}
if (e.keyCode === Keys.DOWN) {
dd = 7;
}
if (e.keyCode === Keys.ENTER) {
this.dateClick.emit(this.value);
e.stopPropagation();
}
if (e.keyCode === Keys.ESCAPE) {
this.escape.emit(this.value);
e.stopPropagation();
}
if (dd !== 0) {
this.value = Dates.addDays(this.value === null ? Dates.today() : this.value, dd);
e.stopPropagation();
}
}
ngOnInit() {
this.createDayNames();
this.createWeeks(Dates.today());
}
};
tslib_1.__decorate([
ViewChild('days', { static: true }),
tslib_1.__metadata("design:type", Object)
], CalendarComponent.prototype, "days", void 0);
tslib_1.__decorate([
Output('dateClick'),
tslib_1.__metadata("design:type", EventEmitter)
], CalendarComponent.prototype, "dateClick", void 0);
tslib_1.__decorate([
Output('escape'),
tslib_1.__metadata("design:type", EventEmitter)
], CalendarComponent.prototype, "escape", void 0);
CalendarComponent = CalendarComponent_1 = tslib_1.__decorate([
Component({
selector: 'true-calendar',
template: "<!-- Buttons -->\r\n<div class=\"true-calendar__controls\">\r\n <div>\r\n <button class=\"true-button\" (click)=\"toggleMode()\" ><b>{{monthYear}}</b></button>\r\n </div>\r\n <div>\r\n <button class=\"true-button prev\" (click)=\"go(-1)\"><span class=\"true-icon-left-open\"></span></button>\r\n <button class=\"true-button next\" (click)=\"go(1)\"><span class=\"true-icon-right-open\"></span></button>\r\n </div>\r\n</div>\r\n\r\n<!-- Day names in header -->\r\n<table class=\"true-day-names\">\r\n <colGroup>\r\n <col *ngFor=\"let d of dayNames\" />\r\n </colGroup>\r\n <thead>\r\n <tr>\r\n <td *ngFor=\"let d of dayNames\" [class.true-transparent]=\"mode!='days'\">{{d}}</td>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr><td colspan=\"7\"></td></tr>\r\n </tbody>\r\n</table>\r\n\r\n<!-- Month days -->\r\n<table #days class=\"true-days\" tabindex=\"1\" (keydown)=\"daysKeyDown($event)\">\r\n <colGroup>\r\n <col *ngFor=\"let d of dayNames\" />\r\n </colGroup>\r\n <tbody>\r\n <tr *ngFor=\"let w of weeks\">\r\n <td *ngFor=\"let d of w\"\r\n (click)=\"calendarDateClick($event, d)\"\r\n [class.true-selected]=\"d.getTime() === valueTime\"\r\n [class.true-today]=\"d.getTime() === today.getTime()\"\r\n [class.true-current]=\"isCurrentMonth(d)\">{{d.getDate()}}</td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n<!-- Months -->\r\n<table class=\"true-months\">\r\n <colGroup>\r\n <col *ngFor=\"let r of monthRows[0]\" />\r\n </colGroup>\r\n <tbody>\r\n <tr *ngFor=\"let r of monthRows\">\r\n <td *ngFor=\"let m of r\"\r\n (click)=\"calendarDateClick($event, m.date)\"\r\n [class.true-transparent]=\"m.hide\"\r\n [class.true-selected]=\"m.selected\"\r\n [class.true-today]=\"m.today\"\r\n [class.true-current]=\"m.current\">{{m.name}}</td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n<!-- Years -->\r\n<table class=\"true-years\">\r\n <colGroup>\r\n <col *ngFor=\"let r of yearRows[0]\" />\r\n </colGroup>\r\n <tbody>\r\n <tr *ngFor=\"let r of yearRows\">\r\n <td *ngFor=\"let y of r\"\r\n (click)=\"calendarDateClick($event, y.date)\"\r\n [class.true-selected]=\"y.selected\"\r\n [class.true-today]=\"y.today\"\r\n [class.true-current]=\"1==1\">{{y.name}}</td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n",
host: {
'class': 'true-calendar true-mode-days',
'(mousedown)': 'mousedown($event)',
'(touchend)': '$event.stopPropagation()'
},
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => CalendarComponent_1),
multi: true
}],
styles: [":host>table{table-layout:fixed;border-collapse:separate}:host>table:focus{outline:0}:host table.true-days,:host table.true-months,:host table.true-years{display:none}:host.true-mode-days table.true-days,:host.true-mode-months table.true-months,:host.true-mode-years table.true-years{display:table}.true-calendar__controls{display:-webkit-box;display:flex;flex-wrap:nowrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row;-webkit-box-pack:justify;justify-content:space-between}.true-calendar__controls div:last-child{display:-webkit-box;display:flex;flex-wrap:nowrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row}"]
}),
tslib_1.__metadata("design:paramtypes", [InternationalizationService,
ChangeDetectorRef,
ElementRef])
], CalendarComponent);
export { CalendarComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/controls/calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Component, Input, Output, HostBinding, EventEmitter, ChangeDetectorRef,\r\n         ElementRef, HostListener, ViewChild,\r\n         ChangeDetectionStrategy, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nimport { Keys } from '@true-directive/base';\r\nimport { Dates } from '@true-directive/base';\r\nimport { InternationalizationService } from '../internationalization/internationalization.service';\r\n\r\n/**\r\n * Calendar component.\r\n */\r\n@Component({\r\n  selector: 'true-calendar',\r\n  templateUrl: './calendar.component.html',\r\n  styleUrls: ['./calendar.component.scss'],\r\n  host: {\r\n    'class': 'true-calendar true-mode-days',\r\n    '(mousedown)': 'mousedown($event)',\r\n    '(touchend)': '$event.stopPropagation()'\r\n  },\r\n  providers: [{\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => CalendarComponent),\r\n      multi: true\r\n    }]\r\n  })\r\nexport class CalendarComponent implements ControlValueAccessor {\r\n\r\n  private onChange = (_: any) => {};\r\n  private onTouched = () => {};\r\n\r\n  private _value: any = null;\r\n\r\n  public mode: 'days' | 'months' | 'years' = 'days';\r\n\r\n  @ViewChild('days', {static: true})\r\n  days: any;\r\n\r\n  @Output('dateClick')\r\n  dateClick: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output('escape')\r\n  escape: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  private calendarDateStart: any;\r\n  private calendarDateEnd: any;\r\n\r\n\r\n  get value(): any {\r\n    return this._value;\r\n  }\r\n\r\n  set value(v: any) {\r\n    if (v !== this._value) {\r\n      this._value = v;\r\n      this.createWeeks(this._value);\r\n      this.onChange(v);\r\n    }\r\n  }\r\n\r\n  get valueTime(): number {\r\n    let vTime = 0;\r\n    if (this.value !== null && !isNaN(this.value.getTime())) {\r\n      vTime = this.value.getTime();\r\n    }\r\n    return vTime;\r\n  }\r\n\r\n  get monthYear() {\r\n\r\n    const m = this.calendarDateStart.getMonth();\r\n    const y = this.calendarDateStart.getFullYear();\r\n\r\n    if (this.mode === 'days') {\r\n      return this.intl.locale.longMonthNames[m] + ' ' + y;\r\n    }\r\n\r\n    if (this.mode === 'months') {\r\n      return y;\r\n    }\r\n\r\n    if (this. mode === 'years') {\r\n      return this._minYear + ' - ' + this._maxYear;\r\n    }\r\n  }\r\n\r\n  get today() {\r\n    return Dates.today();\r\n  }\r\n\r\n  registerOnChange(fn: (_: any) => void): void { this.onChange = fn; }\r\n  registerOnTouched(fn: () => void): void { this.onTouched = fn; }\r\n\r\n  blur() {\r\n    this.onTouched();\r\n  }\r\n\r\n  // Отображаем значение в компоненте. Formatter: Ctrl --> View\r\n  writeValue(value: any): void {\r\n    if (this.value !== value) {\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  setFocus() {\r\n    this.days.nativeElement.focus();\r\n  }\r\n\r\n  isCurrentMonth(d: any) {\r\n    return Dates.dateBetween(d, this.calendarDateStart, this.calendarDateEnd);\r\n  }\r\n\r\n  go(qty: number) {\r\n    if (this.mode === 'days') {\r\n      let newDate;\r\n      if (qty > 0 ) {\r\n        newDate = Dates.firstDateOfNextMonth(this.calendarDateStart);\r\n      } else {\r\n        newDate = Dates.firstDateOfPrevMonth(this.calendarDateStart);\r\n      }\r\n\r\n      this.createWeeks(newDate);\r\n    }\r\n\r\n    if (this.mode === 'months') {\r\n      this.calendarDateStart = new Date(this.calendarDateStart.getFullYear() + qty, 0, 1);\r\n      this.createMonths();\r\n    }\r\n\r\n    if (this.mode === 'years') {\r\n      this.calendarDateStart = new Date(this.calendarDateStart.getFullYear() + 24 * qty, 0, 1);\r\n      this.createYears();\r\n    }\r\n  }\r\n\r\n  toggleMode() {\r\n\r\n    if (this.mode === 'years') {\r\n      this.mode = 'days';\r\n      this.createWeeks(this.calendarDateStart);\r\n    } else {\r\n      if (this.mode === 'months') {\r\n        this.mode = 'years';\r\n        this.createYears();\r\n      } else {\r\n        if (this.mode === 'days') {\r\n          this.mode = 'months';\r\n          this.createMonths();\r\n        }\r\n      }\r\n    }\r\n\r\n    this.setMode();\r\n  }\r\n\r\n  setMode() {\r\n    this.el.nativeElement.classList.remove('true-mode-days');\r\n    this.el.nativeElement.classList.remove('true-mode-months');\r\n    this.el.nativeElement.classList.remove('true-mode-years');\r\n    this.el.nativeElement.classList.add('true-mode-' + this.mode);\r\n  }\r\n\r\n  mousedown(e: any) {\r\n    e.stopPropagation();\r\n  }\r\n\r\n  calendarDateClick(e: any, d: any) {\r\n    if (this.mode === 'days') {\r\n      this.value = new Date(d);\r\n      this.dateClick.emit(d);\r\n    }\r\n\r\n    if (this.mode === 'months') {\r\n      this.mode = 'days';\r\n      this.createWeeks(new Date(d));\r\n    }\r\n\r\n    if (this.mode === 'years') {\r\n      this.calendarDateStart = new Date(d);\r\n      this.mode = 'months';\r\n      this.createMonths();\r\n    }\r\n\r\n    this.setMode();\r\n\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n  }\r\n\r\n  // Day names\r\n  dayNames: Array<string> = [];\r\n\r\n  // Month weeks\r\n  weeks: Array<any> = [];\r\n\r\n  // Year months\r\n  monthRows: Array<any> = [];\r\n\r\n  // Matrix of displayed years\r\n  yearRows: Array<any> = [];\r\n\r\n  // List of dates in selected month\r\n  private createDayNames() {\r\n    this.dayNames = [];\r\n    const weekStart = Dates.firstDateOfWeek(Dates.today(), this.intl.locale.firstDayOfWeek);\r\n    const weekEnd = Dates.lastDateOfWeek(weekStart, this.intl.locale.firstDayOfWeek);\r\n\r\n    for (let d = new Date(weekStart); d.getTime() <= weekEnd.getTime(); d = Dates.nextDate(d)) {\r\n      const wd = d.getDay();\r\n      const dayName = this.intl.locale.shortDayNames[wd];\r\n      this.dayNames.push(dayName);\r\n    }\r\n  }\r\n\r\n  // List of months to show in months-mode\r\n  private createMonths() {\r\n\r\n    const yy = this.calendarDateStart.getFullYear();\r\n    const currentMonthStart = Dates.firstDateOfMonth(Dates.today());\r\n\r\n    let k = -3;\r\n    this.monthRows = [];\r\n    for (let i = 0; i < 6; i++) {\r\n      let monthRow = [];\r\n      for (let j = 0; j < 3; j++) {\r\n\r\n        // Month start\r\n        const dd = new Date(yy, k, 1);\r\n\r\n        monthRow.push(\r\n          { name: this.intl.locale.shortMonthNames[dd.getMonth()] + ' ' + Dates.yearTwoDigits(dd),\r\n            date: dd,\r\n            selected: Dates.isSameMonth(dd, this.value),\r\n            today: dd.getTime() === currentMonthStart.getTime(),\r\n            current: Dates.isSameYear(dd, this.calendarDateStart) }\r\n        );\r\n        k++;\r\n      }\r\n      this.monthRows.push(monthRow);\r\n    }\r\n  }\r\n\r\n  private _minYear = 0;\r\n  private _maxYear = 0;\r\n\r\n  // List of dates in selected month\r\n  private createYears() {\r\n\r\n    const yy = this.calendarDateStart.getFullYear();\r\n    const currentYearStart = new Date(Dates.today().getFullYear(), 0, 1);\r\n    const calendarYearStart = new Date(this.calendarDateStart.getFullYear(), 0, 1);\r\n\r\n    this._minYear = yy - 11;\r\n    let k = this._minYear;\r\n\r\n    this.yearRows = [];\r\n    for (let i = 0; i < 6; i++) {\r\n      let yearRow = [];\r\n      for (let j = 0; j < 4; j++) {\r\n\r\n        const dd = new Date(k, 0, 1);\r\n        yearRow.push(\r\n          { name: k + '',\r\n            date: dd,\r\n            selected: Dates.isSameYear(dd, this.value),\r\n            today: dd.getTime() === currentYearStart.getTime(),\r\n            current: true }\r\n        );\r\n\r\n        k++;\r\n      }\r\n      this.yearRows.push(yearRow);\r\n    }\r\n\r\n    this._maxYear = k - 1;\r\n  }\r\n\r\n  private createWeeks(date: any) {\r\n\r\n    if (date === null || isNaN(date.getTime())) {\r\n      date = Dates.today();\r\n    }\r\n\r\n    const firstDayOfWeek = this.intl.locale.firstDayOfWeek;\r\n\r\n    const monthStart = Dates.firstDateOfMonth(date);\r\n    const monthEnd = Dates.lastDateOfMonth(date);\r\n\r\n    if (this.weeks.length > 0\r\n      && this.calendarDateStart !== undefined && this.calendarDateStart.getTime() === monthStart.getTime()\r\n      && this.calendarDateEnd !== undefined && this.calendarDateEnd.getTime() === monthEnd.getTime()\r\n    ) {\r\n      return;\r\n    }\r\n\r\n    this.weeks = [];\r\n    this.calendarDateStart = monthStart;\r\n    this.calendarDateEnd = monthEnd;\r\n\r\n    const calendarStart = Dates.firstDateOfWeek(monthStart, firstDayOfWeek);\r\n\r\n    // Iterating weeks of month\r\n    let weekStart = new Date(calendarStart);\r\n    let wCounter = 0;\r\n    while (wCounter < 6) {\r\n\r\n      let week: Array<any> = [];\r\n      let weekEnd = Dates.lastDateOfWeek(weekStart, firstDayOfWeek);\r\n\r\n      // Iterating days of week\r\n      for (let d = new Date(weekStart); d.getTime() <= weekEnd.getTime(); d = Dates.nextDate(d)) {\r\n        week.push(d);\r\n      }\r\n\r\n      this.weeks.push(week);\r\n      // Next week\r\n      weekStart = Dates.nextDate(weekEnd);\r\n      wCounter++;\r\n    }\r\n  }\r\n\r\n  daysKeyDown(e: any) {\r\n\r\n    let dd = 0;\r\n\r\n    if (e.keyCode === Keys.LEFT) {\r\n      dd = -1;\r\n    }\r\n\r\n    if (e.keyCode === Keys.UP) {\r\n      dd = -7;\r\n    }\r\n\r\n    if (e.keyCode === Keys.RIGHT) {\r\n      dd = 1;\r\n    }\r\n\r\n    if (e.keyCode === Keys.DOWN) {\r\n      dd = 7;\r\n    }\r\n\r\n    if (e.keyCode === Keys.ENTER) {\r\n      this.dateClick.emit(this.value);\r\n      e.stopPropagation();\r\n    }\r\n\r\n    if (e.keyCode === Keys.ESCAPE) {\r\n      this.escape.emit(this.value);\r\n      e.stopPropagation();\r\n    }\r\n\r\n    if (dd !== 0) {\r\n      this.value = Dates.addDays(this.value === null ? Dates.today() : this.value, dd);\r\n      e.stopPropagation();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.createDayNames();\r\n    this.createWeeks(Dates.today());\r\n  }\r\n\r\n  constructor(\r\n    private intl: InternationalizationService,\r\n    private cd: ChangeDetectorRef,\r\n    private el: ElementRef\r\n  ) { }\r\n}\r\n"]}