UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

429 lines • 28.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Output, EventEmitter, Input, HostBinding, HostListener, ElementRef, Injectable } from '@angular/core'; import { range, Calendar } from '../calendar'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { HammerGestureConfig, HAMMER_GESTURE_CONFIG } from '@angular/platform-browser'; /** @type {?} */ let NEXT_ID = 0; export class CalendarHammerConfig extends HammerGestureConfig { constructor() { super(...arguments); this.overrides = { pan: { direction: Hammer.DIRECTION_VERTICAL, threshold: 1 } }; } } CalendarHammerConfig.decorators = [ { type: Injectable } ]; if (false) { /** @type {?} */ CalendarHammerConfig.prototype.overrides; } export class IgxYearsViewComponent { /** * @param {?} el */ constructor(el) { this.el = el; /** * Sets/gets the `id` of the years view. * If not set, the `id` will have value `"igx-years-view-0"`. * ```html * <igx-years-view id = "my-years-view"></igx-years-view> * ``` * ```typescript * let yearsViewId = this.yearsView.id; * ``` * \@memberof IgxCalendarComponent */ this.id = `igx-years-view-${NEXT_ID++}`; /** * Gets/sets the selected date of the years view. * By default it is the current date. * ```html * <igx-years-view [date]="myDate"></igx-years-view> * ``` * ```typescript * let date = this.yearsView.date; * ``` * \@memberof IgxYearsViewComponent */ this.date = new Date(); /** * Emits an event when a selection is made in the years view. * Provides reference the `date` property in the `IgxYearsViewComponent`. * ```html * <igx-years-view (onSelection)="onSelection($event)"></igx-years-view> * ``` * \@memberof IgxYearsViewComponent */ 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._yearFormat = 'numeric'; /** * @hidden */ this._onTouchedCallback = () => { }; /** * @hidden */ this._onChangeCallback = () => { }; this.initYearFormatter(); this._calendarModel = new Calendar(); } /** * Gets the year format option of the years view. * ```typescript * let yearFormat = this.yearsView.yearFormat. * ``` * @return {?} */ get yearFormat() { return this._yearFormat; } /** * Sets the year format option of the years view. * ```html * <igx-years-view [yearFormat]="numeric"></igx-years-view> * ``` * \@memberof IgxYearsViewComponent * @param {?} value * @return {?} */ set yearFormat(value) { this._yearFormat = value; this.initYearFormatter(); } /** * Gets the `locale` of the years view. * Default value is `"en"`. * ```typescript * let locale = this.yearsView.locale; * ``` * \@memberof IgxYearsViewComponent * @return {?} */ get locale() { return this._locale; } /** * Sets the `locale` of the years view. * Expects a valid BCP 47 language tag. * Default value is `"en"`. * ```html * <igx-years-view [locale]="de"></igx-years-view> * ``` * \@memberof IgxYearsViewComponent * @param {?} value * @return {?} */ set locale(value) { this._locale = value; this.initYearFormatter(); } /** * Returns an array of date objects which are then used to properly * render the years. * * Used in the template of the component. * * @hidden * @return {?} */ get decade() { /** @type {?} */ const result = []; /** @type {?} */ const start = this.date.getFullYear() - 3; /** @type {?} */ const end = this.date.getFullYear() + 4; for (const year of range(start, end)) { result.push(new Date(year, this.date.getMonth(), this.date.getDate())); } return result; } /** * Returns the locale representation of the year in the years view. * * @hidden * @param {?} value * @return {?} */ formattedYear(value) { if (this.formatView) { return this._formatterYear.format(value); } return `${value.getFullYear()}`; } /** * @hidden * @param {?} event * @return {?} */ selectYear(event) { this.date = event; this.onSelection.emit(this.date); this._onChangeCallback(this.date); } /** * @hidden * @param {?} event * @return {?} */ scroll(event) { event.preventDefault(); event.stopPropagation(); /** @type {?} */ const delta = event.deltaY < 0 ? -1 : 1; this.generateYearRange(delta); } /** * @hidden * @param {?} event * @return {?} */ pan(event) { /** @type {?} */ const delta = event.deltaY < 0 ? 1 : -1; this.generateYearRange(delta); } /** * @hidden * @param {?} fn * @return {?} */ registerOnChange(fn) { this._onChangeCallback = fn; } /** * @hidden * @param {?} fn * @return {?} */ registerOnTouched(fn) { this._onTouchedCallback = fn; } /** * @hidden * @param {?} index * @param {?} item * @return {?} */ yearTracker(index, item) { return `${item.getFullYear()}}`; } /** * @hidden * @param {?} value * @return {?} */ writeValue(value) { if (value) { this.date = value; } } /** * @hidden * @param {?} event * @return {?} */ onKeydownArrowDown(event) { event.preventDefault(); event.stopPropagation(); this.generateYearRange(1); } /** * @hidden * @param {?} event * @return {?} */ onKeydownArrowUp(event) { event.preventDefault(); event.stopPropagation(); this.generateYearRange(-1); } /** * @hidden * @return {?} */ onKeydownEnter() { this.onSelection.emit(this.date); this._onChangeCallback(this.date); } /** * @hidden * @private * @return {?} */ initYearFormatter() { this._formatterYear = new Intl.DateTimeFormat(this._locale, { year: this.yearFormat }); } /** * @hidden * @private * @param {?} delta * @return {?} */ generateYearRange(delta) { /** @type {?} */ const currentYear = new Date().getFullYear(); if ((delta > 0 && this.date.getFullYear() - currentYear >= 95) || (delta < 0 && currentYear - this.date.getFullYear() >= 95)) { return; } this.date = this._calendarModel.timedelta(this.date, 'year', delta); } } IgxYearsViewComponent.decorators = [ { type: Component, args: [{ providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: IgxYearsViewComponent, multi: true }, { provide: HAMMER_GESTURE_CONFIG, useClass: CalendarHammerConfig } ], selector: 'igx-years-view', template: "<div class=\"igx-calendar__body\">\n <div class=\"igx-calendar__body-column\" (wheel)=\"scroll($event)\" (pan)=\"pan($event)\">\n <span [igxCalendarYear]=\"year\" [date]=\"date\" (onYearSelection)=\"selectYear($event)\" *ngFor=\"let year of decade; trackBy: yearTracker\">\n {{ formattedYear(year) }}\n </span>\n </div>\n</div>\n" }] } ]; /** @nocollapse */ IgxYearsViewComponent.ctorParameters = () => [ { type: ElementRef } ]; IgxYearsViewComponent.propDecorators = { id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }], date: [{ type: Input }], yearFormat: [{ type: Input }], locale: [{ type: Input }], formatView: [{ type: Input }], onSelection: [{ type: Output }], styleClass: [{ type: HostBinding, args: ['class.igx-calendar',] }], tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }], onKeydownArrowDown: [{ type: HostListener, args: ['keydown.arrowdown', ['$event'],] }], onKeydownArrowUp: [{ type: HostListener, args: ['keydown.arrowup', ['$event'],] }], onKeydownEnter: [{ type: HostListener, args: ['keydown.enter',] }] }; if (false) { /** * Sets/gets the `id` of the years view. * If not set, the `id` will have value `"igx-years-view-0"`. * ```html * <igx-years-view id = "my-years-view"></igx-years-view> * ``` * ```typescript * let yearsViewId = this.yearsView.id; * ``` * \@memberof IgxCalendarComponent * @type {?} */ IgxYearsViewComponent.prototype.id; /** * Gets/sets the selected date of the years view. * By default it is the current date. * ```html * <igx-years-view [date]="myDate"></igx-years-view> * ``` * ```typescript * let date = this.yearsView.date; * ``` * \@memberof IgxYearsViewComponent * @type {?} */ IgxYearsViewComponent.prototype.date; /** * Gets/sets whether the view should be rendered * according to the locale and yearFormat, if any. * @type {?} */ IgxYearsViewComponent.prototype.formatView; /** * Emits an event when a selection is made in the years view. * Provides reference the `date` property in the `IgxYearsViewComponent`. * ```html * <igx-years-view (onSelection)="onSelection($event)"></igx-years-view> * ``` * \@memberof IgxYearsViewComponent * @type {?} */ IgxYearsViewComponent.prototype.onSelection; /** * The default css class applied to the component. * * @hidden * @type {?} */ IgxYearsViewComponent.prototype.styleClass; /** * The default `tabindex` attribute for the component. * * @hidden * @type {?} */ IgxYearsViewComponent.prototype.tabindex; /** * @hidden * @type {?} * @private */ IgxYearsViewComponent.prototype._formatterYear; /** * @hidden * @type {?} * @private */ IgxYearsViewComponent.prototype._locale; /** * @hidden * @type {?} * @private */ IgxYearsViewComponent.prototype._yearFormat; /** * @hidden * @type {?} * @private */ IgxYearsViewComponent.prototype._calendarModel; /** * @hidden * @type {?} * @private */ IgxYearsViewComponent.prototype._onTouchedCallback; /** * @hidden * @type {?} * @private */ IgxYearsViewComponent.prototype._onChangeCallback; /** @type {?} */ IgxYearsViewComponent.prototype.el; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"years-view.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/years-view/years-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input, HostBinding, HostListener, ElementRef, Injectable} from '@angular/core';\nimport { range, Calendar } from '../calendar';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { HammerGestureConfig, HAMMER_GESTURE_CONFIG } from '@angular/platform-browser';\n\nlet NEXT_ID = 0;\n\n@Injectable()\nexport class CalendarHammerConfig extends HammerGestureConfig {\n    public overrides = {\n        pan: { direction: Hammer.DIRECTION_VERTICAL, threshold: 1 }\n    };\n}\n\n@Component({\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxYearsViewComponent,\n            multi: true\n        },\n        {\n            provide: HAMMER_GESTURE_CONFIG,\n            useClass: CalendarHammerConfig\n        }\n    ],\n    selector: 'igx-years-view',\n    templateUrl: 'years-view.component.html'\n})\nexport class IgxYearsViewComponent implements ControlValueAccessor {\n\n    /**\n     * Sets/gets the `id` of the years view.\n     * If not set, the `id` will have value `\"igx-years-view-0\"`.\n     * ```html\n     * <igx-years-view id = \"my-years-view\"></igx-years-view>\n     * ```\n     * ```typescript\n     * let yearsViewId =  this.yearsView.id;\n     * ```\n     * @memberof IgxCalendarComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-years-view-${NEXT_ID++}`;\n\n    /**\n     * Gets/sets the selected date of the years view.\n     * By default it is the current date.\n     * ```html\n     * <igx-years-view [date]=\"myDate\"></igx-years-view>\n     * ```\n     * ```typescript\n     * let date =  this.yearsView.date;\n     * ```\n     * @memberof IgxYearsViewComponent\n     */\n    @Input()\n    public date = new Date();\n\n    /**\n     * Gets the year format option of the years view.\n     * ```typescript\n     * let yearFormat = this.yearsView.yearFormat.\n     * ```\n     */\n    @Input()\n    public get yearFormat(): string {\n        return this._yearFormat;\n    }\n\n    /**\n     * Sets the year format option of the years view.\n     * ```html\n     * <igx-years-view [yearFormat]=\"numeric\"></igx-years-view>\n     * ```\n     * @memberof IgxYearsViewComponent\n     */\n    public set yearFormat(value: string) {\n        this._yearFormat = value;\n        this.initYearFormatter();\n    }\n\n    /**\n     * Gets the `locale` of the years view.\n     * Default value is `\"en\"`.\n     * ```typescript\n     * let locale =  this.yearsView.locale;\n     * ```\n     * @memberof IgxYearsViewComponent\n     */\n    @Input()\n    public get locale(): string {\n        return this._locale;\n    }\n\n    /**\n     * Sets the `locale` of the years view.\n     * Expects a valid BCP 47 language tag.\n     * Default value is `\"en\"`.\n     * ```html\n     * <igx-years-view [locale]=\"de\"></igx-years-view>\n     * ```\n     * @memberof IgxYearsViewComponent\n     */\n    public set locale(value: string) {\n        this._locale = value;\n        this.initYearFormatter();\n    }\n\n    /**\n     * Gets/sets whether the view should be rendered\n     * according to the locale and yearFormat, if any.\n     */\n    @Input()\n    public formatView: boolean;\n\n    /**\n     * Emits an event when a selection is made in the years view.\n     * Provides reference the `date` property in the `IgxYearsViewComponent`.\n     * ```html\n     * <igx-years-view (onSelection)=\"onSelection($event)\"></igx-years-view>\n     * ```\n     * @memberof IgxYearsViewComponent\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     * 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 properly\n     * render the years.\n     *\n     * Used in the template of the component.\n     *\n     * @hidden\n     */\n    get decade(): number[] {\n        const result = [];\n        const start = this.date.getFullYear() - 3;\n        const end = this.date.getFullYear() + 4;\n\n        for (const year of range(start, end)) {\n            result.push(new Date(year, this.date.getMonth(), this.date.getDate()));\n        }\n\n        return result;\n    }\n\n    /**\n     *@hidden\n     */\n    private _formatterYear: any;\n\n    /**\n     *@hidden\n     */\n    private _locale = 'en';\n\n    /**\n     *@hidden\n     */\n    private _yearFormat = 'numeric';\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.initYearFormatter();\n        this._calendarModel = new Calendar();\n    }\n\n    /**\n     * Returns the locale representation of the year in the years view.\n     *\n     * @hidden\n     */\n    public formattedYear(value: Date): string {\n        if (this.formatView) {\n            return this._formatterYear.format(value);\n        }\n        return `${value.getFullYear()}`;\n    }\n\n    /**\n     *@hidden\n     */\n    public selectYear(event) {\n        this.date = event;\n\n        this.onSelection.emit(this.date);\n        this._onChangeCallback(this.date);\n    }\n\n    /**\n     *@hidden\n     */\n    public scroll(event) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const delta = event.deltaY < 0 ? -1 : 1;\n        this.generateYearRange(delta);\n    }\n\n    /**\n     *@hidden\n     */\n    public pan(event) {\n        const delta = event.deltaY < 0 ? 1 : -1;\n        this.generateYearRange(delta);\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 yearTracker(index, item): string {\n        return `${item.getFullYear()}}`;\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    @HostListener('keydown.arrowdown', ['$event'])\n    public onKeydownArrowDown(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        this.generateYearRange(1);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowup', ['$event'])\n    public onKeydownArrowUp(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        this.generateYearRange(-1);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.enter')\n    public onKeydownEnter() {\n        this.onSelection.emit(this.date);\n        this._onChangeCallback(this.date);\n    }\n\n    /**\n     *@hidden\n     */\n    private initYearFormatter() {\n        this._formatterYear = new Intl.DateTimeFormat(this._locale, { year: this.yearFormat });\n    }\n\n    /**\n     *@hidden\n     */\n    private generateYearRange(delta: number) {\n        const currentYear = new Date().getFullYear();\n\n        if ((delta > 0 && this.date.getFullYear() - currentYear >= 95) ||\n            (delta < 0 && currentYear - this.date.getFullYear() >= 95)) {\n            return;\n        }\n        this.date = this._calendarModel.timedelta(this.date, 'year', delta);\n    }\n}\n"]}