@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
353 lines • 29.3 kB
JavaScript
import { __decorate, __extends, __metadata, __values } from "tslib";
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';
var NEXT_ID = 0;
var CalendarHammerConfig = /** @class */ (function (_super) {
__extends(CalendarHammerConfig, _super);
function CalendarHammerConfig() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.overrides = {
pan: { direction: Hammer.DIRECTION_VERTICAL, threshold: 1 }
};
return _this;
}
CalendarHammerConfig = __decorate([
Injectable()
], CalendarHammerConfig);
return CalendarHammerConfig;
}(HammerGestureConfig));
export { CalendarHammerConfig };
var IgxYearsViewComponent = /** @class */ (function () {
function IgxYearsViewComponent(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 = function () { };
/**
*@hidden
*/
this._onChangeCallback = function () { };
this.initYearFormatter();
this._calendarModel = new Calendar();
}
IgxYearsViewComponent_1 = IgxYearsViewComponent;
Object.defineProperty(IgxYearsViewComponent.prototype, "yearFormat", {
/**
* Gets the year format option of the years view.
* ```typescript
* let yearFormat = this.yearsView.yearFormat.
* ```
*/
get: function () {
return this._yearFormat;
},
/**
* Sets the year format option of the years view.
* ```html
* <igx-years-view [yearFormat]="numeric"></igx-years-view>
* ```
* @memberof IgxYearsViewComponent
*/
set: function (value) {
this._yearFormat = value;
this.initYearFormatter();
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxYearsViewComponent.prototype, "locale", {
/**
* Gets the `locale` of the years view.
* Default value is `"en"`.
* ```typescript
* let locale = this.yearsView.locale;
* ```
* @memberof IgxYearsViewComponent
*/
get: function () {
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
*/
set: function (value) {
this._locale = value;
this.initYearFormatter();
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxYearsViewComponent.prototype, "decade", {
/**
* Returns an array of date objects which are then used to properly
* render the years.
*
* Used in the template of the component.
*
* @hidden
*/
get: function () {
var e_1, _a;
var result = [];
var start = this.date.getFullYear() - 3;
var end = this.date.getFullYear() + 4;
try {
for (var _b = __values(range(start, end)), _c = _b.next(); !_c.done; _c = _b.next()) {
var year = _c.value;
result.push(new Date(year, this.date.getMonth(), this.date.getDate()));
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
return result;
},
enumerable: true,
configurable: true
});
/**
* Returns the locale representation of the year in the years view.
*
* @hidden
*/
IgxYearsViewComponent.prototype.formattedYear = function (value) {
if (this.formatView) {
return this._formatterYear.format(value);
}
return "" + value.getFullYear();
};
/**
*@hidden
*/
IgxYearsViewComponent.prototype.selectYear = function (event) {
this.date = event;
this.onSelection.emit(this.date);
this._onChangeCallback(this.date);
};
/**
*@hidden
*/
IgxYearsViewComponent.prototype.scroll = function (event) {
event.preventDefault();
event.stopPropagation();
var delta = event.deltaY < 0 ? -1 : 1;
this.generateYearRange(delta);
};
/**
*@hidden
*/
IgxYearsViewComponent.prototype.pan = function (event) {
var delta = event.deltaY < 0 ? 1 : -1;
this.generateYearRange(delta);
};
/**
* @hidden
*/
IgxYearsViewComponent.prototype.registerOnChange = function (fn) {
this._onChangeCallback = fn;
};
/**
* @hidden
*/
IgxYearsViewComponent.prototype.registerOnTouched = function (fn) {
this._onTouchedCallback = fn;
};
/**
* @hidden
*/
IgxYearsViewComponent.prototype.yearTracker = function (index, item) {
return item.getFullYear() + "}";
};
/**
* @hidden
*/
IgxYearsViewComponent.prototype.writeValue = function (value) {
if (value) {
this.date = value;
}
};
/**
* @hidden
*/
IgxYearsViewComponent.prototype.onKeydownArrowDown = function (event) {
event.preventDefault();
event.stopPropagation();
this.generateYearRange(1);
};
/**
* @hidden
*/
IgxYearsViewComponent.prototype.onKeydownArrowUp = function (event) {
event.preventDefault();
event.stopPropagation();
this.generateYearRange(-1);
};
/**
* @hidden
*/
IgxYearsViewComponent.prototype.onKeydownEnter = function () {
this.onSelection.emit(this.date);
this._onChangeCallback(this.date);
};
/**
*@hidden
*/
IgxYearsViewComponent.prototype.initYearFormatter = function () {
this._formatterYear = new Intl.DateTimeFormat(this._locale, { year: this.yearFormat });
};
/**
*@hidden
*/
IgxYearsViewComponent.prototype.generateYearRange = function (delta) {
var 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);
};
var IgxYearsViewComponent_1;
IgxYearsViewComponent.ctorParameters = function () { return [
{ type: ElementRef }
]; };
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxYearsViewComponent.prototype, "id", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxYearsViewComponent.prototype, "date", void 0);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxYearsViewComponent.prototype, "yearFormat", null);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxYearsViewComponent.prototype, "locale", null);
__decorate([
Input(),
__metadata("design:type", Boolean)
], IgxYearsViewComponent.prototype, "formatView", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxYearsViewComponent.prototype, "onSelection", void 0);
__decorate([
HostBinding('class.igx-calendar'),
__metadata("design:type", Object)
], IgxYearsViewComponent.prototype, "styleClass", void 0);
__decorate([
HostBinding('attr.tabindex'),
__metadata("design:type", Object)
], IgxYearsViewComponent.prototype, "tabindex", void 0);
__decorate([
HostListener('keydown.arrowdown', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxYearsViewComponent.prototype, "onKeydownArrowDown", null);
__decorate([
HostListener('keydown.arrowup', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxYearsViewComponent.prototype, "onKeydownArrowUp", null);
__decorate([
HostListener('keydown.enter'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], IgxYearsViewComponent.prototype, "onKeydownEnter", null);
IgxYearsViewComponent = IgxYearsViewComponent_1 = __decorate([
Component({
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: IgxYearsViewComponent_1,
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"
}),
__metadata("design:paramtypes", [ElementRef])
], IgxYearsViewComponent);
return IgxYearsViewComponent;
}());
export { IgxYearsViewComponent };
//# 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"]}