@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
402 lines • 38 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Output, EventEmitter, Input, HostBinding, HostListener, ViewChildren, QueryList, ElementRef } from '@angular/core';
import { Calendar } from '../calendar';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { IgxCalendarMonthDirective } from '../calendar.directives';
var NEXT_ID = 0;
var IgxMonthsViewComponent = /** @class */ (function () {
function IgxMonthsViewComponent(el) {
this.el = el;
/**
* Sets/gets the `id` of the months view.
* If not set, the `id` will have value `"igx-months-view-0"`.
* ```html
* <igx-months-view id="my-months-view"></igx-months-view>
* ```
* ```typescript
* let monthsViewId = this.monthsView.id;
* ```
* @memberof IgxMonthsViewComponent
*/
this.id = "igx-months-view-" + NEXT_ID++;
/**
* Gets/sets the selected date of the months view.
* By default it is the current date.
* ```html
* <igx-months-view [date]="myDate"></igx-months-view>
* ```
* ```typescript
* let date = this.monthsView.date;
* ```
* @memberof IgxMonthsViewComponent
*/
this.date = new Date();
/**
* Gets/sets whether the view should be rendered
* according to the locale and monthFormat, if any.
*/
this.formatView = true;
/**
* Emits an event when a selection is made in the months view.
* Provides reference the `date` property in the `IgxMonthsViewComponent`.
* ```html
* <igx-months-view (onSelection)="onSelection($event)"></igx-months-view>
* ```
* @memberof IgxMonthsViewComponent
*/
this.onSelection = new EventEmitter();
/**
* The default css class applied to the component.
*
* @hidden
*/
this.styleClass = true;
/**
* The default `tabindex` attribute for the component.
*
* @hidden
*/
this.tabindex = 0;
/**
*@hidden
*/
this._locale = 'en';
/**
*@hidden
*/
this._monthFormat = 'short';
/**
*@hidden
*/
this._onTouchedCallback = function () { };
/**
*@hidden
*/
this._onChangeCallback = function () { };
this.initMonthFormatter();
this._calendarModel = new Calendar();
}
IgxMonthsViewComponent_1 = IgxMonthsViewComponent;
Object.defineProperty(IgxMonthsViewComponent.prototype, "monthFormat", {
/**
* Gets the month format option of the months view.
* ```typescript
* let monthFormat = this.monthsView.monthFormat.
* ```
*/
get: function () {
return this._monthFormat;
},
/**
* Sets the month format option of the months view.
* ```html
* <igx-months-view> [monthFormat] = "short'"</igx-months-view>
* ```
* @memberof IgxMonthsViewComponent
*/
set: function (value) {
this._monthFormat = value;
this.initMonthFormatter();
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMonthsViewComponent.prototype, "locale", {
/**
* Gets the `locale` of the months view.
* Default value is `"en"`.
* ```typescript
* let locale = this.monthsView.locale;
* ```
* @memberof IgxMonthsViewComponent
*/
get: function () {
return this._locale;
},
/**
* Sets the `locale` of the months view.
* Expects a valid BCP 47 language tag.
* Default value is `"en"`.
* ```html
* <igx-months-view [locale]="de"></igx-months-view>
* ```
* @memberof IgxMonthsViewComponent
*/
set: function (value) {
this._locale = value;
this.initMonthFormatter();
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMonthsViewComponent.prototype, "months", {
/**
* Returns an array of date objects which are then used to
* properly render the month names.
*
* Used in the template of the component
*
* @hidden
*/
get: function () {
var start = new Date(this.date.getFullYear(), 0, 1);
var result = [];
for (var i = 0; i < 12; i++) {
result.push(start);
start = this._calendarModel.timedelta(start, 'month', 1);
}
return result;
},
enumerable: true,
configurable: true
});
/**
* Returns the locale representation of the month in the months view.
*
* @hidden
*/
IgxMonthsViewComponent.prototype.formattedMonth = function (value) {
if (this.formatView) {
return this._formatterMonth.format(value);
}
return "" + value.getMonth();
};
/**
*@hidden
*/
IgxMonthsViewComponent.prototype.selectMonth = function (event) {
this.onSelection.emit(event);
this.date = event;
this._onChangeCallback(this.date);
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.registerOnChange = function (fn) {
this._onChangeCallback = fn;
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.registerOnTouched = function (fn) {
this._onTouchedCallback = fn;
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.writeValue = function (value) {
if (value) {
this.date = value;
}
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.monthTracker = function (index, item) {
return item.getMonth() + "}";
};
/**
*@hidden
*/
IgxMonthsViewComponent.prototype.initMonthFormatter = function () {
this._formatterMonth = new Intl.DateTimeFormat(this._locale, { month: this.monthFormat });
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.onKeydownArrowUp = function (event) {
event.preventDefault();
event.stopPropagation();
var node = this.dates.find(function (date) { return date.nativeElement === event.target; });
if (!node) {
return;
}
var months = this.dates.toArray();
var nodeRect = node.nativeElement.getBoundingClientRect();
for (var index = months.indexOf(node) - 1; index >= 0; index--) {
var nextNodeRect = months[index].nativeElement.getBoundingClientRect();
var tolerance = 6;
if (nodeRect.top !== nextNodeRect.top && (nextNodeRect.left - nodeRect.left) < tolerance) {
months[index].nativeElement.focus();
break;
}
}
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.onKeydownArrowDown = function (event) {
event.preventDefault();
event.stopPropagation();
var node = this.dates.find(function (date) { return date.nativeElement === event.target; });
if (!node) {
return;
}
var months = this.dates.toArray();
var nodeRect = node.nativeElement.getBoundingClientRect();
for (var index = months.indexOf(node) + 1; index < months.length; index++) {
var nextNodeRect = months[index].nativeElement.getBoundingClientRect();
var tolerance = 6;
if (nextNodeRect.top !== nodeRect.top && (nodeRect.left - nextNodeRect.left) < tolerance) {
months[index].nativeElement.focus();
break;
}
}
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.onKeydownArrowRight = function (event) {
event.preventDefault();
event.stopPropagation();
var node = this.dates.find(function (date) { return date.nativeElement === event.target; });
if (!node) {
return;
}
var months = this.dates.toArray();
if (months.indexOf(node) + 1 < months.length) {
var month = months[months.indexOf(node) + 1];
month.nativeElement.focus();
}
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.onKeydownArrowLeft = function (event) {
event.preventDefault();
event.stopPropagation();
var node = this.dates.find(function (date) { return date.nativeElement === event.target; });
if (!node) {
return;
}
var months = this.dates.toArray();
if (months.indexOf(node) - 1 >= 0) {
var month = months[months.indexOf(node) - 1];
month.nativeElement.focus();
}
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.onKeydownHome = function (event) {
event.preventDefault();
event.stopPropagation();
var month = this.dates.toArray()[0];
month.nativeElement.focus();
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.onKeydownEnd = function (event) {
event.preventDefault();
event.stopPropagation();
var months = this.dates.toArray();
var month = months[months.length - 1];
month.nativeElement.focus();
};
/**
* @hidden
*/
IgxMonthsViewComponent.prototype.onKeydownEnter = function (event) {
var value = this.dates.find(function (date) { return date.nativeElement === event.target; }).value;
this.date = new Date(value.getFullYear(), value.getMonth(), this.date.getDate());
this.onSelection.emit(this.date);
this._onChangeCallback(this.date);
};
var IgxMonthsViewComponent_1;
IgxMonthsViewComponent.ctorParameters = function () { return [
{ type: ElementRef }
]; };
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxMonthsViewComponent.prototype, "id", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxMonthsViewComponent.prototype, "date", void 0);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxMonthsViewComponent.prototype, "monthFormat", null);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxMonthsViewComponent.prototype, "locale", null);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxMonthsViewComponent.prototype, "formatView", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxMonthsViewComponent.prototype, "onSelection", void 0);
__decorate([
HostBinding('class.igx-calendar'),
__metadata("design:type", Object)
], IgxMonthsViewComponent.prototype, "styleClass", void 0);
__decorate([
ViewChildren(IgxCalendarMonthDirective, { read: IgxCalendarMonthDirective }),
__metadata("design:type", QueryList)
], IgxMonthsViewComponent.prototype, "dates", void 0);
__decorate([
HostBinding('attr.tabindex'),
__metadata("design:type", Object)
], IgxMonthsViewComponent.prototype, "tabindex", void 0);
__decorate([
HostListener('keydown.arrowup', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthsViewComponent.prototype, "onKeydownArrowUp", null);
__decorate([
HostListener('keydown.arrowdown', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthsViewComponent.prototype, "onKeydownArrowDown", null);
__decorate([
HostListener('keydown.arrowright', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthsViewComponent.prototype, "onKeydownArrowRight", null);
__decorate([
HostListener('keydown.arrowleft', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthsViewComponent.prototype, "onKeydownArrowLeft", null);
__decorate([
HostListener('keydown.home', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthsViewComponent.prototype, "onKeydownHome", null);
__decorate([
HostListener('keydown.end', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxMonthsViewComponent.prototype, "onKeydownEnd", null);
__decorate([
HostListener('keydown.enter', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxMonthsViewComponent.prototype, "onKeydownEnter", null);
IgxMonthsViewComponent = IgxMonthsViewComponent_1 = __decorate([
Component({
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxMonthsViewComponent_1, multi: true }],
selector: 'igx-months-view',
template: "<div class=\"igx-calendar__body\">\n <div class=\"igx-calendar__body-row--wrap\">\n <div [igxCalendarMonth]=\"month\" [date]=\"date\" (onMonthSelection)=\"selectMonth($event)\" [index]=\"i\" *ngFor=\"let month of months; index as i; trackBy: monthTracker\">\n {{ formattedMonth(month) | titlecase }}\n </div>\n </div>\n</div>\n\n"
}),
__metadata("design:paramtypes", [ElementRef])
], IgxMonthsViewComponent);
return IgxMonthsViewComponent;
}());
export { IgxMonthsViewComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"months-view.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/months-view/months-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Output,\n    EventEmitter,\n    Input,\n    HostBinding,\n    HostListener,\n    ViewChildren,\n    QueryList,\n    ElementRef\n} from '@angular/core';\nimport { Calendar } from '../calendar';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IgxCalendarMonthDirective } from '../calendar.directives';\n\nlet NEXT_ID = 0;\n\n@Component({\n    providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxMonthsViewComponent, multi: true }],\n    selector: 'igx-months-view',\n    templateUrl: 'months-view.component.html'\n})\nexport class IgxMonthsViewComponent implements ControlValueAccessor {\n\n    /**\n     * Sets/gets the `id` of the months view.\n     * If not set, the `id` will have value `\"igx-months-view-0\"`.\n     * ```html\n     * <igx-months-view id=\"my-months-view\"></igx-months-view>\n     * ```\n     * ```typescript\n     * let monthsViewId =  this.monthsView.id;\n     * ```\n     * @memberof IgxMonthsViewComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-months-view-${NEXT_ID++}`;\n\n    /**\n     * Gets/sets the selected date of the months view.\n     * By default it is the current date.\n     * ```html\n     * <igx-months-view [date]=\"myDate\"></igx-months-view>\n     * ```\n     * ```typescript\n     * let date =  this.monthsView.date;\n     * ```\n     * @memberof IgxMonthsViewComponent\n     */\n    @Input()\n    public date = new Date();\n\n    /**\n     * Gets the month format option of the months view.\n     * ```typescript\n     * let monthFormat = this.monthsView.monthFormat.\n     * ```\n     */\n    @Input()\n    public get monthFormat(): string {\n        return this._monthFormat;\n    }\n\n    /**\n     * Sets the month format option of the months view.\n     * ```html\n     * <igx-months-view> [monthFormat] = \"short'\"</igx-months-view>\n     * ```\n     * @memberof IgxMonthsViewComponent\n     */\n    public set monthFormat(value: string) {\n        this._monthFormat = value;\n        this.initMonthFormatter();\n    }\n\n    /**\n     * Gets the `locale` of the months view.\n     * Default value is `\"en\"`.\n     * ```typescript\n     * let locale =  this.monthsView.locale;\n     * ```\n     * @memberof IgxMonthsViewComponent\n     */\n    @Input()\n    public get locale(): string {\n        return this._locale;\n    }\n\n    /**\n     * Sets the `locale` of the months view.\n     * Expects a valid BCP 47 language tag.\n     * Default value is `\"en\"`.\n     * ```html\n     * <igx-months-view [locale]=\"de\"></igx-months-view>\n     * ```\n     * @memberof IgxMonthsViewComponent\n     */\n    public set locale(value: string) {\n        this._locale = value;\n        this.initMonthFormatter();\n    }\n\n    /**\n     * Gets/sets whether the view should be rendered\n     * according to the locale and monthFormat, if any.\n     */\n    @Input()\n    public formatView = true;\n\n    /**\n     * Emits an event when a selection is made in the months view.\n     * Provides reference the `date` property in the `IgxMonthsViewComponent`.\n     * ```html\n     * <igx-months-view (onSelection)=\"onSelection($event)\"></igx-months-view>\n     * ```\n     * @memberof IgxMonthsViewComponent\n     */\n    @Output()\n    public onSelection = new EventEmitter<Date>();\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    @ViewChildren(IgxCalendarMonthDirective, { read: IgxCalendarMonthDirective })\n    public dates: QueryList<IgxCalendarMonthDirective>;\n\n\n    /**\n     * The default `tabindex` attribute for the component.\n     *\n     * @hidden\n     */\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n    /**\n     * Returns an array of date objects which are then used to\n     * properly render the month names.\n     *\n     * Used in the template of the component\n     *\n     * @hidden\n     */\n    get months(): Date[] {\n        let start = new Date(this.date.getFullYear(), 0, 1);\n        const result = [];\n\n        for (let i = 0; i < 12; i++) {\n            result.push(start);\n            start = this._calendarModel.timedelta(start, 'month', 1);\n        }\n\n        return result;\n    }\n\n    /**\n     *@hidden\n     */\n    private _formatterMonth: any;\n\n    /**\n     *@hidden\n     */\n    private _locale = 'en';\n\n    /**\n     *@hidden\n     */\n    private _monthFormat = 'short';\n\n    /**\n     *@hidden\n     */\n    private _calendarModel: Calendar;\n\n    /**\n     *@hidden\n     */\n    private _onTouchedCallback: () => void = () => { };\n    /**\n     *@hidden\n     */\n    private _onChangeCallback: (_: Date) => void = () => { };\n\n    constructor(public el: ElementRef) {\n        this.initMonthFormatter();\n        this._calendarModel = new Calendar();\n    }\n\n    /**\n     * Returns the locale representation of the month in the months view.\n     *\n     * @hidden\n     */\n    public formattedMonth(value: Date): string {\n        if (this.formatView) {\n            return this._formatterMonth.format(value);\n        }\n        return `${value.getMonth()}`;\n    }\n\n    /**\n     *@hidden\n     */\n    public selectMonth(event) {\n        this.onSelection.emit(event);\n\n        this.date = event;\n        this._onChangeCallback(this.date);\n    }\n\n    /**\n     * @hidden\n     */\n    public registerOnChange(fn: (v: Date) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /**\n     * @hidden\n     */\n    public registerOnTouched(fn: () => void) {\n        this._onTouchedCallback = fn;\n    }\n\n    /**\n     * @hidden\n     */\n    public writeValue(value: Date) {\n        if (value) {\n            this.date = value;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public monthTracker(index, item): string {\n        return `${item.getMonth()}}`;\n    }\n\n    /**\n     *@hidden\n     */\n    private initMonthFormatter() {\n        this._formatterMonth = new Intl.DateTimeFormat(this._locale, { month: this.monthFormat });\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowup', ['$event'])\n    public onKeydownArrowUp(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const node = this.dates.find((date) => date.nativeElement === event.target);\n        if (!node) {\n            return;\n        }\n\n        const months = this.dates.toArray();\n        const nodeRect = node.nativeElement.getBoundingClientRect();\n\n        for (let index = months.indexOf(node) - 1; index >= 0; index--) {\n            const nextNodeRect = months[index].nativeElement.getBoundingClientRect();\n            const tolerance = 6;\n            if (nodeRect.top !== nextNodeRect.top && (nextNodeRect.left - nodeRect.left) < tolerance) {\n                months[index].nativeElement.focus();\n                break;\n            }\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowdown', ['$event'])\n    public onKeydownArrowDown(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const node = this.dates.find((date) => date.nativeElement === event.target);\n        if (!node) {\n            return;\n        }\n\n        const months = this.dates.toArray();\n        const nodeRect = node.nativeElement.getBoundingClientRect();\n\n        for (let index = months.indexOf(node) + 1; index < months.length; index++) {\n            const nextNodeRect = months[index].nativeElement.getBoundingClientRect();\n            const tolerance = 6;\n            if (nextNodeRect.top !== nodeRect.top && (nodeRect.left - nextNodeRect.left) < tolerance ) {\n                months[index].nativeElement.focus();\n                break;\n            }\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowright', ['$event'])\n    public onKeydownArrowRight(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const node = this.dates.find((date) => date.nativeElement === event.target);\n        if (!node) { return; }\n\n        const months = this.dates.toArray();\n        if (months.indexOf(node) + 1 < months.length) {\n            const month = months[months.indexOf(node) + 1];\n\n            month.nativeElement.focus();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowleft', ['$event'])\n    public onKeydownArrowLeft(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const node = this.dates.find((date) => date.nativeElement === event.target);\n        if (!node) { return; }\n\n        const months = this.dates.toArray();\n        if (months.indexOf(node) - 1 >= 0) {\n            const month = months[months.indexOf(node) - 1];\n\n            month.nativeElement.focus();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.home', ['$event'])\n    public onKeydownHome(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const month = this.dates.toArray()[0];\n\n        month.nativeElement.focus();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.end', ['$event'])\n    public onKeydownEnd(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const months = this.dates.toArray();\n        const month = months[months.length - 1];\n\n        month.nativeElement.focus();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.enter', ['$event'])\n    public onKeydownEnter(event) {\n        const value = this.dates.find((date) => date.nativeElement === event.target).value;\n        this.date = new Date(value.getFullYear(), value.getMonth(), this.date.getDate());\n\n        this.onSelection.emit(this.date);\n        this._onChangeCallback(this.date);\n    }\n}\n"]}