@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
271 lines • 29.1 kB
JavaScript
import { __decorate, __extends, __metadata } from "tslib";
import { Component, HostListener, ViewChild, HostBinding, Input } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { trigger, transition, useAnimation } from '@angular/animations';
import { fadeIn, scaleInCenter, slideInLeft, slideInRight } from '../../animations/main';
import { IgxMonthsViewComponent } from '../months-view/months-view.component';
import { IgxMonthPickerBaseDirective, CalendarView } from '../month-picker-base';
import { IgxYearsViewComponent } from '../years-view/years-view.component';
import { IgxDaysViewComponent } from '../days-view/days-view.component';
var NEXT_ID = 0;
var IgxMonthPickerComponent = /** @class */ (function (_super) {
__extends(IgxMonthPickerComponent, _super);
function IgxMonthPickerComponent() {
var _this = _super !== null && _super.apply(this, arguments) || this;
/**
* Sets/gets the `id` of the month picker.
* If not set, the `id` will have value `"igx-month-picker-0"`.
*/
_this.id = "igx-month-picker-" + NEXT_ID++;
/**
* The default css class applied to the component.
*
* @hidden
*/
_this.styleClass = true;
/**
* @hidden
*/
_this.yearAction = '';
return _this;
}
IgxMonthPickerComponent_1 = IgxMonthPickerComponent;
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.animationDone = function () {
this.yearAction = '';
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.activeViewDecadeKB = function (event) {
var _this = this;
_super.prototype.activeViewDecadeKB.call(this, event);
if (event.key === "ArrowRight" /* RIGHT_ARROW */ || event.key === "Right" /* RIGHT_ARROW_IE */) {
event.preventDefault();
this.nextYear();
}
if (event.key === "ArrowLeft" /* LEFT_ARROW */ || event.key === "Left" /* LEFT_ARROW_IE */) {
event.preventDefault();
this.previousYear();
}
requestAnimationFrame(function () {
if (_this.dacadeView) {
_this.dacadeView.el.nativeElement.focus();
}
});
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.activeViewDecade = function () {
var _this = this;
_super.prototype.activeViewDecade.call(this);
requestAnimationFrame(function () {
_this.dacadeView.el.nativeElement.focus();
});
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.nextYear = function () {
this.yearAction = 'next';
this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', 1);
this.selectDate(this.viewDate);
this.onSelection.emit(this.selectedDates);
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.nextYearKB = function (event) {
if (event.key === " " /* SPACE */ || event.key === "Spacebar" /* SPACE_IE */ || event.key === "Enter" /* ENTER */) {
event.preventDefault();
event.stopPropagation();
this.nextYear();
}
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.previousYear = function () {
this.yearAction = 'prev';
this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', -1);
this.selectDate(this.viewDate);
this.onSelection.emit(this.selectedDates);
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.previousYearKB = function (event) {
if (event.key === " " /* SPACE */ || event.key === "Spacebar" /* SPACE_IE */ || event.key === "Enter" /* ENTER */) {
event.preventDefault();
event.stopPropagation();
this.previousYear();
}
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.selectYear = function (event) {
var _this = this;
this.viewDate = new Date(event.getFullYear(), event.getMonth(), event.getDate());
this.activeView = CalendarView.DEFAULT;
this.selectDate(event);
this.onSelection.emit(this.selectedDates);
requestAnimationFrame(function () {
if (_this.yearsBtn) {
_this.yearsBtn.nativeElement.focus();
}
});
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.selectMonth = function (event) {
this.selectDate(event);
this.onSelection.emit(this.selectedDates);
};
/**
* Selects a date.
*```typescript
* this.monPicker.selectDate(new Date(`2018-06-12`));
*```
*/
IgxMonthPickerComponent.prototype.selectDate = function (value) {
if (!value) {
return new Date();
}
// TO DO: to be refactored after discussion on the desired behavior
_super.prototype.selectDate.call(this, value);
this.viewDate = value;
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.writeValue = function (value) {
// TO DO: to be refactored after discussion on the desired behavior
if (value) {
this.viewDate = this.selectedDates = value;
}
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.onKeydownPageUp = function (event) {
event.preventDefault();
this.yearAction = 'prev';
this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', -1);
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.onKeydownPageDown = function (event) {
event.preventDefault();
this.yearAction = 'next';
this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', 1);
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.onKeydownHome = function (event) {
if (this.monthsView) {
this.monthsView.el.nativeElement.focus();
this.monthsView.onKeydownHome(event);
}
};
/**
* @hidden
*/
IgxMonthPickerComponent.prototype.onKeydownEnd = function (event) {
if (this.monthsView) {
this.monthsView.el.nativeElement.focus();
this.monthsView.onKeydownEnd(event);
}
};
var IgxMonthPickerComponent_1;
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxMonthPickerComponent.prototype, "id", void 0);
__decorate([
HostBinding('class.igx-calendar'),
__metadata("design:type", Object)
], IgxMonthPickerComponent.prototype, "styleClass", void 0);
__decorate([
ViewChild('months', { read: IgxMonthsViewComponent }),
__metadata("design:type", IgxMonthsViewComponent)
], IgxMonthPickerComponent.prototype, "monthsView", void 0);
__decorate([
ViewChild('decade', { read: IgxYearsViewComponent }),
__metadata("design:type", IgxYearsViewComponent)
], IgxMonthPickerComponent.prototype, "dacadeView", void 0);
__decorate([
ViewChild('days', { read: IgxDaysViewComponent }),
__metadata("design:type", IgxDaysViewComponent)
], IgxMonthPickerComponent.prototype, "daysView", void 0);
__decorate([
HostListener('keydown.pageup', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthPickerComponent.prototype, "onKeydownPageUp", null);
__decorate([
HostListener('keydown.pagedown', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthPickerComponent.prototype, "onKeydownPageDown", null);
__decorate([
HostListener('keydown.home', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthPickerComponent.prototype, "onKeydownHome", null);
__decorate([
HostListener('keydown.end', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthPickerComponent.prototype, "onKeydownEnd", null);
IgxMonthPickerComponent = IgxMonthPickerComponent_1 = __decorate([
Component({
providers: [
{
multi: true,
provide: NG_VALUE_ACCESSOR,
useExisting: IgxMonthPickerComponent_1
}
],
animations: [
trigger('animateView', [
transition('void => 0', useAnimation(fadeIn)),
transition('void => *', useAnimation(scaleInCenter, {
params: {
duration: '.2s',
fromScale: .9
}
}))
]),
trigger('animateChange', [
transition('* => prev', useAnimation(slideInLeft, {
params: {
fromPosition: 'translateX(-30%)'
}
})),
transition('* => next', useAnimation(slideInRight, {
params: {
fromPosition: 'translateX(30%)'
}
}))
])
],
selector: 'igx-month-picker',
template: "<div *ngIf=\"isDefaultView\" [@animateView]=\"activeView\" class=\"igx-calendar__body\" (swiperight)=\"previousYear()\" (swipeleft)=\"nextYear()\">\n <div class=\"igx-calendar-picker\">\n <div tabindex=\"0\" class=\"igx-calendar-picker__prev\" (click)=\"previousYear()\" (keydown)=\"previousYearKB($event)\" [ngStyle]=\"{\n 'min-width.%': 25,\n 'left': 0\n }\">\n <igx-icon fontSet=\"material\">keyboard_arrow_left</igx-icon>\n </div>\n <div [style.width.%]=\"100\">\n <span tabindex=\"0\" #yearsBtn (keydown)=\"activeViewDecadeKB($event)\" (click)=\"activeViewDecade()\" class=\"igx-calendar-picker__date\">\n {{ formattedYear(viewDate) }}\n </span>\n </div>\n <div tabindex=\"0\" class=\"igx-calendar-picker__next\" (click)=\"nextYear()\" (keydown)=\"nextYearKB($event)\" [ngStyle]=\"{\n 'min-width.%': 25,\n 'right': 0\n }\">\n <igx-icon fontSet=\"material\">keyboard_arrow_right</igx-icon>\n </div>\n </div>\n\n <igx-months-view [@animateChange]=\"yearAction\" #months\n (@animateChange.done)=\"animationDone()\"\n [date]=\"viewDate\"\n [locale]=\"locale\"\n [formatView]=\"formatViews.month\"\n [monthFormat]=\"formatOptions.month\"\n (onSelection)=\"selectMonth($event)\">\n </igx-months-view>\n</div>\n<igx-years-view *ngIf=\"isDecadeView\" [@animateView]=\"activeView\" #decade\n [date]=\"viewDate\"\n [locale]=\"locale\"\n [formatView]=\"formatViews.year\"\n [yearFormat]=\"formatOptions.year\"\n (onSelection)=\"selectYear($event)\">\n</igx-years-view>\n"
})
], IgxMonthPickerComponent);
return IgxMonthPickerComponent;
}(IgxMonthPickerBaseDirective));
export { IgxMonthPickerComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month-picker.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/month-picker/month-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostListener,\n    ViewChild,\n    HostBinding,\n    Input\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { trigger, transition, useAnimation } from '@angular/animations';\nimport { fadeIn, scaleInCenter, slideInLeft, slideInRight } from '../../animations/main';\nimport { KEYS } from '../../core/utils';\nimport { IgxMonthsViewComponent } from '../months-view/months-view.component';\nimport { IgxMonthPickerBaseDirective, CalendarView } from '../month-picker-base';\nimport { IgxYearsViewComponent } from '../years-view/years-view.component';\nimport { IgxDaysViewComponent } from '../days-view/days-view.component';\n\nlet NEXT_ID = 0;\n@Component({\n    providers: [\n        {\n            multi: true,\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxMonthPickerComponent\n        }\n    ],\n    animations: [\n        trigger('animateView', [\n            transition('void => 0', useAnimation(fadeIn)),\n            transition('void => *', useAnimation(scaleInCenter, {\n                params: {\n                    duration: '.2s',\n                    fromScale: .9\n                }\n            }))\n        ]),\n        trigger('animateChange', [\n            transition('* => prev', useAnimation(slideInLeft, {\n                params: {\n                    fromPosition: 'translateX(-30%)'\n                }\n            })),\n            transition('* => next', useAnimation(slideInRight, {\n                params: {\n                    fromPosition: 'translateX(30%)'\n                }\n            }))\n        ])\n    ],\n    selector: 'igx-month-picker',\n    templateUrl: 'month-picker.component.html'\n})\nexport class IgxMonthPickerComponent extends IgxMonthPickerBaseDirective {\n    /**\n     * Sets/gets the `id` of the month picker.\n     * If not set, the `id` will have value `\"igx-month-picker-0\"`.\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-month-picker-${NEXT_ID++}`;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding('class.igx-calendar')\n    public styleClass = true;\n\n    /**\n     * @hidden\n     */\n    @ViewChild('months', { read: IgxMonthsViewComponent })\n    public monthsView: IgxMonthsViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild('decade', { read: IgxYearsViewComponent })\n    public dacadeView: IgxYearsViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild('days', { read: IgxDaysViewComponent })\n    public daysView: IgxDaysViewComponent;\n\n    /**\n     * @hidden\n     */\n    public yearAction = '';\n\n    /**\n     * @hidden\n     */\n    public animationDone() {\n        this.yearAction = '';\n    }\n\n    /**\n     * @hidden\n     */\n    public activeViewDecadeKB(event) {\n        super.activeViewDecadeKB(event);\n\n        if (event.key === KEYS.RIGHT_ARROW || event.key === KEYS.RIGHT_ARROW_IE) {\n            event.preventDefault();\n            this.nextYear();\n        }\n\n        if (event.key === KEYS.LEFT_ARROW || event.key === KEYS.LEFT_ARROW_IE) {\n            event.preventDefault();\n            this.previousYear();\n        }\n\n        requestAnimationFrame(() => {\n            if (this.dacadeView) { this.dacadeView.el.nativeElement.focus(); }\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public activeViewDecade() {\n        super.activeViewDecade();\n\n        requestAnimationFrame(() => {\n            this.dacadeView.el.nativeElement.focus();\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public nextYear() {\n        this.yearAction = 'next';\n        this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', 1);\n\n        this.selectDate(this.viewDate);\n        this.onSelection.emit(this.selectedDates);\n    }\n\n    /**\n     * @hidden\n     */\n    public nextYearKB(event) {\n        if (event.key === KEYS.SPACE || event.key === KEYS.SPACE_IE || event.key === KEYS.ENTER) {\n            event.preventDefault();\n            event.stopPropagation();\n\n            this.nextYear();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public previousYear() {\n        this.yearAction = 'prev';\n        this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', -1);\n\n        this.selectDate(this.viewDate);\n        this.onSelection.emit(this.selectedDates);\n    }\n\n    /**\n     * @hidden\n     */\n    public previousYearKB(event) {\n        if (event.key === KEYS.SPACE || event.key === KEYS.SPACE_IE || event.key === KEYS.ENTER) {\n            event.preventDefault();\n            event.stopPropagation();\n\n            this.previousYear();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public selectYear(event: Date) {\n        this.viewDate = new Date(event.getFullYear(), event.getMonth(), event.getDate());\n        this.activeView = CalendarView.DEFAULT;\n\n        this.selectDate(event);\n        this.onSelection.emit(this.selectedDates);\n\n        requestAnimationFrame(() => {\n            if (this.yearsBtn) { this.yearsBtn.nativeElement.focus(); }\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public selectMonth(event: Date) {\n        this.selectDate(event);\n        this.onSelection.emit(this.selectedDates);\n    }\n\n    /**\n     * Selects a date.\n     *```typescript\n     * this.monPicker.selectDate(new Date(`2018-06-12`));\n     *```\n     */\n    public selectDate(value: Date) {\n        if (!value) {\n            return new Date();\n        }\n\n        // TO DO: to be refactored after discussion on the desired behavior\n        super.selectDate(value);\n        this.viewDate = value;\n    }\n\n    /**\n     * @hidden\n     */\n    public writeValue(value: Date) {\n\n        // TO DO: to be refactored after discussion on the desired behavior\n        if (value) {\n            this.viewDate = this.selectedDates = value;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.pageup', ['$event'])\n    public onKeydownPageUp(event: KeyboardEvent) {\n        event.preventDefault();\n        this.yearAction = 'prev';\n        this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', -1);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.pagedown', ['$event'])\n    public onKeydownPageDown(event: KeyboardEvent) {\n        event.preventDefault();\n        this.yearAction = 'next';\n        this.viewDate = this.calendarModel.timedelta(this.viewDate, 'year', 1);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.home', ['$event'])\n    public onKeydownHome(event: KeyboardEvent) {\n        if (this.monthsView) {\n            this.monthsView.el.nativeElement.focus();\n            this.monthsView.onKeydownHome(event);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.end', ['$event'])\n    public onKeydownEnd(event: KeyboardEvent) {\n        if (this.monthsView) {\n            this.monthsView.el.nativeElement.focus();\n            this.monthsView.onKeydownEnd(event);\n        }\n    }\n}\n"]}