ngx-material-timepicker
Version:
Handy material design timepicker for angular
226 lines • 20.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/* tslint:disable:triple-equals */
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { TimeUnit } from '../../models/time-unit.enum';
import { TimeFormatterPipe } from '../../pipes/time-formatter.pipe';
var NgxMaterialTimepickerDialControlComponent = /** @class */ (function () {
function NgxMaterialTimepickerDialControlComponent() {
this.timeUnitChanged = new EventEmitter();
this.timeChanged = new EventEmitter();
this.focused = new EventEmitter();
this.unfocused = new EventEmitter();
}
Object.defineProperty(NgxMaterialTimepickerDialControlComponent.prototype, "selectedTime", {
get: /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (!!this.time) {
return this.timeList.find(function (t) { return t.time === +_this.time; });
}
},
enumerable: true,
configurable: true
});
/**
* @param {?} changes
* @return {?}
*/
NgxMaterialTimepickerDialControlComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes['time'] && (changes['time'].currentValue !== undefined)) {
if (this.isEditable && !changes['time'].firstChange) {
return;
}
this.time = new TimeFormatterPipe().transform(+changes['time'].currentValue, this.timeUnit);
}
};
/**
* @param {?} event
* @param {?} unit
* @return {?}
*/
NgxMaterialTimepickerDialControlComponent.prototype.saveTimeAndChangeTimeUnit = /**
* @param {?} event
* @param {?} unit
* @return {?}
*/
function (event, unit) {
event.preventDefault();
this.previousTime = this.time;
this.timeUnitChanged.next(unit);
this.focused.next();
};
/**
* @return {?}
*/
NgxMaterialTimepickerDialControlComponent.prototype.updateTime = /**
* @return {?}
*/
function () {
/** @type {?} */
var time = this.selectedTime;
if (time) {
this.timeChanged.next(time);
this.previousTime = time.time;
}
};
/**
* @return {?}
*/
NgxMaterialTimepickerDialControlComponent.prototype.formatTime = /**
* @return {?}
*/
function () {
if (this.isEditable) {
/** @type {?} */
var time = this.time || this.previousTime;
this.time = new TimeFormatterPipe().transform(+time, this.timeUnit);
this.unfocused.next();
}
};
/**
* @param {?} e
* @return {?}
*/
NgxMaterialTimepickerDialControlComponent.prototype.onKeyDown = /**
* @param {?} e
* @return {?}
*/
function (e) {
/** @type {?} */
var char = String.fromCharCode(e.keyCode);
if ((!isInputAllowed(e)) || isTimeDisabledToChange(this.time, char, this.timeList)) {
e.preventDefault();
}
if (isInputAllowed(e)) {
this.changeTimeByArrow(e.keyCode);
}
};
/**
* @private
* @param {?} keyCode
* @return {?}
*/
NgxMaterialTimepickerDialControlComponent.prototype.changeTimeByArrow = /**
* @private
* @param {?} keyCode
* @return {?}
*/
function (keyCode) {
/** @type {?} */
var ARROW_UP = 38;
/** @type {?} */
var ARROW_DOWN = 40;
/** @type {?} */
var time;
if (keyCode === ARROW_UP) {
time = String(+this.time + (this.minutesGap || 1));
}
else if (keyCode === ARROW_DOWN) {
time = String(+this.time - (this.minutesGap || 1));
}
if (!isTimeUnavailable(time, this.timeList)) {
this.time = time;
this.updateTime();
}
};
NgxMaterialTimepickerDialControlComponent.decorators = [
{ type: Component, args: [{
selector: 'ngx-material-timepicker-dial-control',
template: "<!--suppress HtmlFormInputWithoutLabel -->\n<input class=\"timepicker-dial__control timepicker-dial__item\"\n [ngClass]=\"{'timepicker-dial__item_active': isActive, 'timepicker-dial__control_editable': isEditable}\"\n [(ngModel)]=\"time\" (input)=\"updateTime()\" (focus)=\"saveTimeAndChangeTimeUnit($event, timeUnit)\"\n (blur)=\"formatTime()\" [readonly]=\"!isEditable\" [timepickerAutofocus]=\"isActive\" (keydown)=\"onKeyDown($event)\">\n",
styles: [".timepicker-dial__item{cursor:pointer;color:rgba(255,255,255,.5);font-family:Roboto,sans-serif}@supports (font-family:var(--primary-font-family)){.timepicker-dial__item{font-family:var(--primary-font-family);color:var(--dial-inactive-color)}}.timepicker-dial__item_active{color:#fff}@supports (color:var(--dial-active-color)){.timepicker-dial__item_active{color:var(--dial-active-color)}}.timepicker-dial__control{border:none;background-color:transparent;font-size:50px;width:60px;padding:0;border-radius:3px}.timepicker-dial__control_editable:focus{color:#00bfff;background-color:#fff;outline:#00bfff}"]
}] }
];
NgxMaterialTimepickerDialControlComponent.propDecorators = {
timeList: [{ type: Input }],
timeUnit: [{ type: Input }],
time: [{ type: Input }],
isActive: [{ type: Input }],
isEditable: [{ type: Input }],
minutesGap: [{ type: Input }],
timeUnitChanged: [{ type: Output }],
timeChanged: [{ type: Output }],
focused: [{ type: Output }],
unfocused: [{ type: Output }]
};
return NgxMaterialTimepickerDialControlComponent;
}());
export { NgxMaterialTimepickerDialControlComponent };
if (false) {
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.previousTime;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.timeList;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.timeUnit;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.time;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.isActive;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.isEditable;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.minutesGap;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.timeUnitChanged;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.timeChanged;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.focused;
/** @type {?} */
NgxMaterialTimepickerDialControlComponent.prototype.unfocused;
}
/**
* @param {?} e
* @return {?}
*/
function isInputAllowed(e) {
// Allow: backspace, delete, tab, escape, enter
if ([46, 8, 9, 27, 13].some(function (n) { return n === e.keyCode; }) ||
// Allow: Ctrl/cmd+A
(e.keyCode == 65 && (e.ctrlKey === true || e.metaKey === true)) ||
// Allow: Ctrl/cmd+C
(e.keyCode == 67 && (e.ctrlKey === true || e.metaKey === true)) ||
// Allow: Ctrl/cmd+X
(e.keyCode == 88 && (e.ctrlKey === true || e.metaKey === true)) ||
// Allow: home, end, left, right, up, down
(e.keyCode >= 35 && e.keyCode <= 40)) {
return true;
}
return !((e.keyCode < 48 || e.keyCode > 57) && (e.keyCode < 96 || e.keyCode > 105));
}
/**
* @param {?} currentTime
* @param {?} nextTime
* @param {?} timeList
* @return {?}
*/
function isTimeDisabledToChange(currentTime, nextTime, timeList) {
/** @type {?} */
var isNumber = /\d/.test(nextTime);
if (isNumber) {
/** @type {?} */
var time = currentTime + nextTime;
return isTimeUnavailable(time, timeList);
}
}
/**
* @param {?} time
* @param {?} timeList
* @return {?}
*/
function isTimeUnavailable(time, timeList) {
/** @type {?} */
var selectedTime = timeList.find(function (value) { return value.time === +time; });
return !selectedTime || (selectedTime && selectedTime.disabled);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-material-timepicker-dial-control.component.js","sourceRoot":"ng://ngx-material-timepicker/","sources":["src/app/material-timepicker/components/timepicker-dial-control/ngx-material-timepicker-dial-control.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable:triple-equals */\nimport { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { ClockFaceTime } from '../../models/clock-face-time.interface';\nimport { TimeUnit } from '../../models/time-unit.enum';\nimport { TimeFormatterPipe } from '../../pipes/time-formatter.pipe';\n\n@Component({\n    selector: 'ngx-material-timepicker-dial-control',\n    templateUrl: 'ngx-material-timepicker-dial-control.component.html',\n    styleUrls: ['ngx-material-timepicker-dial-control.component.scss']\n})\nexport class NgxMaterialTimepickerDialControlComponent implements OnChanges {\n\n    previousTime: number | string;\n\n    @Input() timeList: ClockFaceTime[];\n    @Input() timeUnit: TimeUnit;\n    @Input() time: string;\n    @Input() isActive: boolean;\n    @Input() isEditable: boolean;\n    @Input() minutesGap: number;\n\n    @Output() timeUnitChanged = new EventEmitter<TimeUnit>();\n    @Output() timeChanged = new EventEmitter<ClockFaceTime>();\n    @Output() focused = new EventEmitter<null>();\n    @Output() unfocused = new EventEmitter<null>();\n\n    private get selectedTime(): ClockFaceTime {\n        if (!!this.time) {\n            return this.timeList.find(t => t.time === +this.time);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['time'] && (changes['time'].currentValue !== undefined)) {\n            if (this.isEditable && !changes['time'].firstChange) {\n                return;\n            }\n            this.time = new TimeFormatterPipe().transform(+changes['time'].currentValue, this.timeUnit);\n        }\n    }\n\n    saveTimeAndChangeTimeUnit(event: FocusEvent, unit: TimeUnit): void {\n        event.preventDefault();\n        this.previousTime = this.time;\n        this.timeUnitChanged.next(unit);\n        this.focused.next();\n    }\n\n    updateTime(): void {\n        const time = this.selectedTime;\n        if (time) {\n            this.timeChanged.next(time);\n            this.previousTime = time.time;\n        }\n    }\n\n    formatTime(): void {\n        if (this.isEditable) {\n            const time = this.time || this.previousTime;\n            this.time = new TimeFormatterPipe().transform(+time, this.timeUnit);\n            this.unfocused.next();\n        }\n    }\n\n    onKeyDown(e: KeyboardEvent): void {\n        const char = String.fromCharCode(e.keyCode);\n\n\n        if ((!isInputAllowed(e)) || isTimeDisabledToChange(this.time, char, this.timeList)) {\n            e.preventDefault();\n        }\n\n        if (isInputAllowed(e)) {\n            this.changeTimeByArrow(e.keyCode);\n        }\n    }\n\n    private changeTimeByArrow(keyCode: number): void {\n        const ARROW_UP = 38;\n        const ARROW_DOWN = 40;\n        let time: string;\n\n        if (keyCode === ARROW_UP) {\n            time = String(+this.time + (this.minutesGap || 1));\n        } else if (keyCode === ARROW_DOWN) {\n            time = String(+this.time - (this.minutesGap || 1));\n        }\n\n        if (!isTimeUnavailable(time, this.timeList)) {\n            this.time = time;\n            this.updateTime();\n        }\n    }\n\n}\n\nfunction isInputAllowed(e: KeyboardEvent): boolean {\n    // Allow: backspace, delete, tab, escape, enter\n    if ([46, 8, 9, 27, 13].some(n => n === e.keyCode) ||\n        // Allow: Ctrl/cmd+A\n        (e.keyCode == 65 && (e.ctrlKey === true || e.metaKey === true)) ||\n        // Allow: Ctrl/cmd+C\n        (e.keyCode == 67 && (e.ctrlKey === true || e.metaKey === true)) ||\n        // Allow: Ctrl/cmd+X\n        (e.keyCode == 88 && (e.ctrlKey === true || e.metaKey === true)) ||\n        // Allow: home, end, left, right, up, down\n        (e.keyCode >= 35 && e.keyCode <= 40)) {\n\n        return true;\n    }\n    return !((e.keyCode < 48 || e.keyCode > 57) && (e.keyCode < 96 || e.keyCode > 105));\n}\n\nfunction isTimeDisabledToChange(currentTime: string, nextTime: string, timeList: ClockFaceTime[]): boolean {\n    const isNumber = /\\d/.test(nextTime);\n\n    if (isNumber) {\n        const time = currentTime + nextTime;\n        return isTimeUnavailable(time, timeList);\n    }\n}\n\nfunction isTimeUnavailable(time: string, timeList: ClockFaceTime[]): boolean {\n    const selectedTime = timeList.find(value => value.time === +time);\n    return !selectedTime || (selectedTime && selectedTime.disabled);\n}\n"]}