ngx-material-timepicker
Version:
Handy material design timepicker for angular
408 lines • 35.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, EventEmitter, HostListener, Input, Output, TemplateRef, ViewChild } from '@angular/core';
import { merge } from 'rxjs';
import { NgxMaterialTimepickerService } from './services/ngx-material-timepicker.service';
import { TimeUnit } from './models/time-unit.enum';
import { animate, style, transition, trigger } from '@angular/animations';
import { NgxMaterialTimepickerEventService } from './services/ngx-material-timepicker-event.service';
import { filter } from 'rxjs/operators';
/** @enum {string} */
var AnimationState = {
ENTER: 'enter',
LEAVE: 'leave',
};
export { AnimationState };
/** @type {?} */
var ESCAPE = 27;
var NgxMaterialTimepickerComponent = /** @class */ (function () {
function NgxMaterialTimepickerComponent(timepickerService, eventService) {
var _this = this;
this.timepickerService = timepickerService;
this.eventService = eventService;
this.timeUnit = TimeUnit;
this.activeTimeUnit = TimeUnit.HOUR;
this.isOpened = false;
this.isEsc = true;
this.timeSet = new EventEmitter();
this.opened = new EventEmitter();
this.closed = new EventEmitter();
this.hourSelected = new EventEmitter();
this.subscriptions = [];
this.subscriptions.push(merge(this.eventService.backdropClick, this.eventService.keydownEvent.pipe(filter(function (e) { return e.keyCode === ESCAPE && _this.isEsc; })))
.subscribe(function () { return _this.close(); }));
}
Object.defineProperty(NgxMaterialTimepickerComponent.prototype, "minutesGap", {
get: /**
* @return {?}
*/
function () {
return this._minutesGap;
},
set: /**
* @param {?} gap
* @return {?}
*/
function (gap) {
if (gap == null) {
return;
}
gap = Math.floor(gap);
this._minutesGap = gap <= 59 ? gap : 1;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NgxMaterialTimepickerComponent.prototype, "defaultTime", {
set: /**
* @param {?} time
* @return {?}
*/
function (time) {
this.setDefaultTime(time);
},
enumerable: true,
configurable: true
});
Object.defineProperty(NgxMaterialTimepickerComponent.prototype, "minTime", {
get: /**
* @return {?}
*/
function () {
return this.timepickerInput && this.timepickerInput.min;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NgxMaterialTimepickerComponent.prototype, "maxTime", {
get: /**
* @return {?}
*/
function () {
return this.timepickerInput && this.timepickerInput.max;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NgxMaterialTimepickerComponent.prototype, "disabled", {
get: /**
* @return {?}
*/
function () {
return this.timepickerInput && this.timepickerInput.disabled;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NgxMaterialTimepickerComponent.prototype, "format", {
get: /**
* @return {?}
*/
function () {
return this.timepickerInput && this.timepickerInput.format;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.subscriptions.push(this.timepickerService.selectedHour
.subscribe(function (hour) { return _this.selectedHour = hour; }));
this.subscriptions.push(this.timepickerService.selectedMinute
.subscribe(function (minute) { return _this.selectedMinute = minute; }));
this.subscriptions.push(this.timepickerService.selectedPeriod
.subscribe(function (period) { return _this.selectedPeriod = period; }));
};
/***
* Register an input with this timepicker.
* input - The timepicker input to register with this timepicker
*/
/**
*
* Register an input with this timepicker.
* input - The timepicker input to register with this timepicker
* @param {?} input
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.registerInput = /**
*
* Register an input with this timepicker.
* input - The timepicker input to register with this timepicker
* @param {?} input
* @return {?}
*/
function (input) {
if (this.timepickerInput) {
throw Error('A Timepicker can only be associated with a single input.');
}
this.timepickerInput = input;
};
/**
* @param {?} hour
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.onHourChange = /**
* @param {?} hour
* @return {?}
*/
function (hour) {
this.timepickerService.hour = hour;
};
/**
* @param {?} hour
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.onHourSelected = /**
* @param {?} hour
* @return {?}
*/
function (hour) {
this.changeTimeUnit(TimeUnit.MINUTE);
this.hourSelected.next(hour);
};
/**
* @param {?} minute
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.onMinuteChange = /**
* @param {?} minute
* @return {?}
*/
function (minute) {
this.timepickerService.minute = minute;
};
/**
* @param {?} period
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.changePeriod = /**
* @param {?} period
* @return {?}
*/
function (period) {
this.timepickerService.period = period;
};
/**
* @param {?} unit
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.changeTimeUnit = /**
* @param {?} unit
* @return {?}
*/
function (unit) {
this.activeTimeUnit = unit;
};
/**
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.setTime = /**
* @return {?}
*/
function () {
this.timeSet.next(this.timepickerService.getFullTime(this.format));
this.close();
};
/**
* @param {?} time
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.setDefaultTime = /**
* @param {?} time
* @return {?}
*/
function (time) {
this.timepickerService.setDefaultTimeIfAvailable(time, (/** @type {?} */ (this.minTime)), (/** @type {?} */ (this.maxTime)), this.format, this.minutesGap);
};
/**
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.open = /**
* @return {?}
*/
function () {
this.isOpened = true;
if (!this.disableAnimation) {
this.animationState = AnimationState.ENTER;
}
this.opened.next();
};
/**
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.close = /**
* @return {?}
*/
function () {
if (this.disableAnimation) {
this.closeTimepicker();
return;
}
this.animationState = AnimationState.LEAVE;
};
/**
* @param {?} event
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.animationDone = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (event.phaseName === 'done' && event.toState === AnimationState.LEAVE) {
this.closeTimepicker();
}
};
/**
* @param {?} e
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.onKeydown = /**
* @param {?} e
* @return {?}
*/
function (e) {
this.eventService.dispatchEvent(e);
e.stopPropagation();
};
/**
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.subscriptions.forEach(function (subscription) { return subscription.unsubscribe(); });
};
/**
* @private
* @return {?}
*/
NgxMaterialTimepickerComponent.prototype.closeTimepicker = /**
* @private
* @return {?}
*/
function () {
this.isOpened = false;
this.activeTimeUnit = TimeUnit.HOUR;
this.closed.next();
};
NgxMaterialTimepickerComponent.decorators = [
{ type: Component, args: [{
selector: 'ngx-material-timepicker',
template: "<div class=\"timepicker-backdrop-overlay\" *ngIf=\"isOpened\" [overlay]=\"preventOverlayClick\"></div>\n<div class=\"timepicker-overlay\" *ngIf=\"isOpened\">\n <div class=\"timepicker\" [@timepicker]=\"animationState\" (@timepicker.done)=\"animationDone($event)\">\n <header class=\"timepicker__header\">\n <ngx-material-timepicker-dial [format]=\"format\" [hour]=\"selectedHour?.time\"\n [minute]=\"selectedMinute?.time\"\n [period]=\"selectedPeriod\" [activeTimeUnit]=\"activeTimeUnit\"\n [minTime]=\"minTime\" [maxTime]=\"maxTime\"\n [isEditable]=\"enableKeyboardInput\"\n [editableHintTmpl]=\"editableHintTmpl\"\n [minutesGap]=\"minutesGap\"\n (periodChanged)=\"changePeriod($event)\"\n (timeUnitChanged)=\"changeTimeUnit($event)\"\n (hourChanged)=\"onHourChange($event)\"\n (minuteChanged)=\"onMinuteChange($event)\"\n ></ngx-material-timepicker-dial>\n </header>\n <div class=\"timepicker__main-content\">\n <div class=\"timepicker__body\" [ngSwitch]=\"activeTimeUnit\">\n <div *ngSwitchCase=\"timeUnit.HOUR\">\n <ngx-material-timepicker-24-hours-face *ngIf=\"format === 24;else ampmHours\"\n (hourChange)=\"onHourChange($event)\"\n [selectedHour]=\"selectedHour\"\n [minTime]=\"minTime\"\n [maxTime]=\"maxTime\"\n [format]=\"format\"\n (hourSelected)=\"onHourSelected($event)\"></ngx-material-timepicker-24-hours-face>\n <ng-template #ampmHours>\n <ngx-material-timepicker-12-hours-face\n (hourChange)=\"onHourChange($event)\"\n [selectedHour]=\"selectedHour\"\n [period]=\"selectedPeriod\"\n [minTime]=\"minTime\"\n [maxTime]=\"maxTime\"\n (hourSelected)=\"onHourSelected($event)\"></ngx-material-timepicker-12-hours-face>\n </ng-template>\n </div>\n <ngx-material-timepicker-minutes-face *ngSwitchCase=\"timeUnit.MINUTE\"\n [selectedMinute]=\"selectedMinute\"\n [selectedHour]=\"selectedHour?.time\"\n [minTime]=\"minTime\"\n [maxTime]=\"maxTime\"\n [format]=\"format\"\n [period]=\"selectedPeriod\"\n [minutesGap]=\"minutesGap\"\n (minuteChange)=\"onMinuteChange($event)\"></ngx-material-timepicker-minutes-face>\n </div>\n <div class=\"timepicker__actions\">\n <div (click)=\"close()\">\n <!--suppress HtmlUnknownAttribute -->\n <ng-container *ngTemplateOutlet=\"cancelBtnTmpl ? cancelBtnTmpl : cancelBtnDefault\"></ng-container>\n </div>\n <div (click)=\"setTime()\">\n <!--suppress HtmlUnknownAttribute -->\n <ng-container\n *ngTemplateOutlet=\"confirmBtnTmpl ? confirmBtnTmpl : confirmBtnDefault\"></ng-container>\n </div>\n </div>\n </div>\n </div>\n</div>\n<ng-template #cancelBtnDefault>\n <ngx-material-timepicker-button>Cancel</ngx-material-timepicker-button>\n</ng-template>\n<ng-template #confirmBtnDefault>\n <ngx-material-timepicker-button>Ok</ngx-material-timepicker-button>\n</ng-template>\n",
animations: [
trigger('timepicker', [
transition("* => " + AnimationState.ENTER, [
style({ transform: 'translateY(-30%)' }),
animate('0.2s ease-out', style({ transform: 'translateY(0)' }))
]),
transition(AnimationState.ENTER + " => " + AnimationState.LEAVE, [
style({ transform: 'translateY(0)', opacity: 1 }),
animate('0.2s ease-out', style({ transform: 'translateY(-30%)', opacity: 0 }))
])
])
],
providers: [NgxMaterialTimepickerService],
styles: [":host{--body-background-color:#fff;--primary-font-family:'Roboto',sans-serif;--button-color:deepskyblue;--dial-active-color:#fff;--dial-inactive-color:rgba(255, 255, 255, .5);--dial-background-color:deepskyblue;--clock-face-time-active-color:#fff;--clock-face-time-inactive-color:#6c6c6c;--clock-face-inner-time-inactive-color:#929292;--clock-face-time-disabled-color:#c5c5c5;--clock-face-background-color:#f0f0f0;--clock-hand-color:deepskyblue}.timepicker-backdrop-overlay{position:fixed;top:0;bottom:0;right:0;left:0;background-color:rgba(0,0,0,.3);z-index:999;pointer-events:auto}.timepicker-overlay{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:999;pointer-events:none}.timepicker{width:300px;border-radius:2px;box-shadow:rgba(0,0,0,.25) 0 14px 45px,rgba(0,0,0,.22) 0 10px 18px;outline:0;position:static;z-index:999;pointer-events:auto}.timepicker__header{padding:15px 30px;background-color:#00bfff}@supports (background-color:var(--dial-background-color)){.timepicker__header{background-color:var(--dial-background-color)}}.timepicker__body{padding:15px 5px;display:flex;justify-content:center;align-items:center;background-color:#fff}@supports (background-color:var(--body-background-color)){.timepicker__body{background-color:var(--body-background-color)}}.timepicker__actions{display:flex;justify-content:flex-end;padding:15px;background-color:#fff}@supports (background-color:var(--body-background-color)){.timepicker__actions{background-color:var(--body-background-color)}}@media (max-device-width:1023px) and (orientation:landscape){.timepicker{display:flex;width:515px}.timepicker__header{display:flex;align-items:center}.timepicker__main-content{display:flex;flex-direction:column;width:100%}.timepicker__actions{padding:5px;margin-top:-1px}}"]
}] }
];
/** @nocollapse */
NgxMaterialTimepickerComponent.ctorParameters = function () { return [
{ type: NgxMaterialTimepickerService },
{ type: NgxMaterialTimepickerEventService }
]; };
NgxMaterialTimepickerComponent.propDecorators = {
cancelBtnTmpl: [{ type: Input }],
editableHintTmpl: [{ type: Input }],
confirmBtnTmpl: [{ type: Input }],
isEsc: [{ type: Input, args: ['ESC',] }],
enableKeyboardInput: [{ type: Input }],
preventOverlayClick: [{ type: Input }],
disableAnimation: [{ type: Input }],
minutesGap: [{ type: Input }],
defaultTime: [{ type: Input }],
timeSet: [{ type: Output }],
opened: [{ type: Output }],
closed: [{ type: Output }],
hourSelected: [{ type: Output }],
timepickerComponent: [{ type: ViewChild, args: ['timepickerww',] }],
onKeydown: [{ type: HostListener, args: ['keydown', ['$event'],] }]
};
return NgxMaterialTimepickerComponent;
}());
export { NgxMaterialTimepickerComponent };
if (false) {
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.selectedHour;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.selectedMinute;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.selectedPeriod;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.timeUnit;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.activeTimeUnit;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.isOpened;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.animationState;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.cancelBtnTmpl;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.editableHintTmpl;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.confirmBtnTmpl;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.isEsc;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.enableKeyboardInput;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.preventOverlayClick;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.disableAnimation;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.timeSet;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.opened;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.closed;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.hourSelected;
/** @type {?} */
NgxMaterialTimepickerComponent.prototype.timepickerComponent;
/**
* @type {?}
* @private
*/
NgxMaterialTimepickerComponent.prototype._minutesGap;
/**
* @type {?}
* @private
*/
NgxMaterialTimepickerComponent.prototype.timepickerInput;
/**
* @type {?}
* @private
*/
NgxMaterialTimepickerComponent.prototype.subscriptions;
/**
* @type {?}
* @private
*/
NgxMaterialTimepickerComponent.prototype.timepickerService;
/**
* @type {?}
* @private
*/
NgxMaterialTimepickerComponent.prototype.eventService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-material-timepicker.component.js","sourceRoot":"ng://ngx-material-timepicker/","sources":["src/app/material-timepicker/ngx-material-timepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';\nimport { ClockFaceTime } from './models/clock-face-time.interface';\nimport { TimePeriod } from './models/time-period.enum';\nimport { merge, Subscription } from 'rxjs';\nimport { NgxMaterialTimepickerService } from './services/ngx-material-timepicker.service';\nimport { TimeUnit } from './models/time-unit.enum';\nimport { animate, AnimationEvent, style, transition, trigger } from '@angular/animations';\nimport { NgxMaterialTimepickerEventService } from './services/ngx-material-timepicker-event.service';\nimport { filter } from 'rxjs/operators';\nimport { TimepickerDirective } from './directives/ngx-timepicker.directive';\nimport { DateTime } from 'luxon';\n\nexport enum AnimationState {\n    ENTER = 'enter',\n    LEAVE = 'leave'\n}\n\n\nconst ESCAPE = 27;\n\n@Component({\n    selector: 'ngx-material-timepicker',\n    templateUrl: './ngx-material-timepicker.component.html',\n    styleUrls: ['./ngx-material-timepicker.component.scss'],\n    animations: [\n        trigger('timepicker', [\n            transition(`* => ${AnimationState.ENTER}`, [\n                style({transform: 'translateY(-30%)'}),\n                animate('0.2s ease-out', style({transform: 'translateY(0)'}))\n            ]),\n            transition(`${AnimationState.ENTER} => ${AnimationState.LEAVE}`, [\n                style({transform: 'translateY(0)', opacity: 1}),\n                animate('0.2s ease-out', style({transform: 'translateY(-30%)', opacity: 0}))\n            ])\n        ])\n    ],\n    providers: [NgxMaterialTimepickerService]\n})\nexport class NgxMaterialTimepickerComponent implements OnInit, OnDestroy {\n\n    selectedHour: ClockFaceTime;\n    selectedMinute: ClockFaceTime;\n    selectedPeriod: TimePeriod;\n\n    timeUnit = TimeUnit;\n    activeTimeUnit = TimeUnit.HOUR;\n\n    isOpened = false;\n    animationState: AnimationState;\n\n    @Input() cancelBtnTmpl: TemplateRef<Node>;\n    @Input() editableHintTmpl: TemplateRef<Node>;\n    @Input() confirmBtnTmpl: TemplateRef<Node>;\n    @Input('ESC') isEsc = true;\n    @Input() enableKeyboardInput: boolean;\n    @Input() preventOverlayClick: boolean;\n    @Input() disableAnimation: boolean;\n\n    @Input()\n    set minutesGap(gap: number) {\n        if (gap == null) {\n            return;\n        }\n        gap = Math.floor(gap);\n        this._minutesGap = gap <= 59 ? gap : 1;\n    }\n\n    get minutesGap(): number {\n        return this._minutesGap;\n    }\n\n    @Input()\n    set defaultTime(time: string) {\n        this.setDefaultTime(time);\n    }\n\n    @Output() timeSet = new EventEmitter<string>();\n    @Output() opened = new EventEmitter<null>();\n    @Output() closed = new EventEmitter<null>();\n    @Output() hourSelected = new EventEmitter<number>();\n\n    @ViewChild('timepickerww') timepickerComponent: ElementRef;\n\n    private _minutesGap: number;\n    private timepickerInput: TimepickerDirective;\n    private subscriptions: Subscription[] = [];\n\n    constructor(private timepickerService: NgxMaterialTimepickerService,\n                private eventService: NgxMaterialTimepickerEventService) {\n\n        this.subscriptions.push(merge(this.eventService.backdropClick,\n            this.eventService.keydownEvent.pipe(filter(e => e.keyCode === ESCAPE && this.isEsc)))\n            .subscribe(() => this.close()));\n\n    }\n\n    get minTime(): string | DateTime {\n        return this.timepickerInput && this.timepickerInput.min;\n    }\n\n    get maxTime(): string | DateTime {\n        return this.timepickerInput && this.timepickerInput.max;\n    }\n\n    get disabled(): boolean {\n        return this.timepickerInput && this.timepickerInput.disabled;\n    }\n\n    get format(): number {\n        return this.timepickerInput && this.timepickerInput.format;\n    }\n\n    ngOnInit() {\n        this.subscriptions.push(this.timepickerService.selectedHour\n            .subscribe(hour => this.selectedHour = hour));\n\n        this.subscriptions.push(this.timepickerService.selectedMinute\n            .subscribe(minute => this.selectedMinute = minute));\n\n        this.subscriptions.push(this.timepickerService.selectedPeriod\n            .subscribe(period => this.selectedPeriod = period));\n    }\n\n    /***\n     * Register an input with this timepicker.\n     * input - The timepicker input to register with this timepicker\n     */\n    registerInput(input: TimepickerDirective): void {\n        if (this.timepickerInput) {\n            throw Error('A Timepicker can only be associated with a single input.');\n        }\n        this.timepickerInput = input;\n    }\n\n    onHourChange(hour: ClockFaceTime): void {\n        this.timepickerService.hour = hour;\n    }\n\n    onHourSelected(hour: number): void {\n        this.changeTimeUnit(TimeUnit.MINUTE);\n        this.hourSelected.next(hour);\n    }\n\n    onMinuteChange(minute: ClockFaceTime): void {\n        this.timepickerService.minute = minute;\n    }\n\n    changePeriod(period: TimePeriod): void {\n        this.timepickerService.period = period;\n    }\n\n    changeTimeUnit(unit: TimeUnit): void {\n        this.activeTimeUnit = unit;\n    }\n\n    setTime(): void {\n        this.timeSet.next(this.timepickerService.getFullTime(this.format));\n        this.close();\n    }\n\n    setDefaultTime(time: string): void {\n        this.timepickerService.setDefaultTimeIfAvailable(\n            time, this.minTime as DateTime, this.maxTime as DateTime, this.format, this.minutesGap);\n    }\n\n    open(): void {\n        this.isOpened = true;\n        if (!this.disableAnimation) {\n            this.animationState = AnimationState.ENTER;\n        }\n        this.opened.next();\n    }\n\n    close(): void {\n        if (this.disableAnimation) {\n            this.closeTimepicker();\n            return;\n        }\n        this.animationState = AnimationState.LEAVE;\n    }\n\n    animationDone(event: AnimationEvent): void {\n        if (event.phaseName === 'done' && event.toState === AnimationState.LEAVE) {\n            this.closeTimepicker();\n        }\n    }\n\n    @HostListener('keydown', ['$event'])\n    onKeydown(e: KeyboardEvent) {\n        this.eventService.dispatchEvent(e);\n        e.stopPropagation();\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(subscription => subscription.unsubscribe());\n    }\n\n    private closeTimepicker(): void {\n        this.isOpened = false;\n        this.activeTimeUnit = TimeUnit.HOUR;\n        this.closed.next();\n    }\n}\n"]}