UNPKG

@junte/ui

Version:

Quality Angular UI components kit

168 lines 15.5 kB
import { __decorate, __metadata } from "tslib"; import { Component, EventEmitter, HostBinding, Input, Output } from '@angular/core'; import { BehaviorSubject, combineLatest } from 'rxjs'; import { MethodApi, PropertyApi } from '../../core/decorators/api'; import { UI } from '../../core/enums/ui'; export var SECONDS_IN_MINUTE = 60; export var SECONDS_IN_HOUR = 3600; export var HOURS_IN_DAY = 24; var TimerComponent = /** @class */ (function () { function TimerComponent() { this.ui = UI; this.remains = 0; this.counter = { days: 0, hours: 0, minutes: 0, seconds: 0 }; this.days$ = new BehaviorSubject(0); this.hours$ = new BehaviorSubject(0); this.minutes$ = new BehaviorSubject(0); this.seconds$ = new BehaviorSubject(0); this.host = 'jnt-timer-host'; this.tick = new EventEmitter(); this.finished = new EventEmitter(); } Object.defineProperty(TimerComponent.prototype, "days", { get: function () { return this.days$.getValue(); }, set: function (days) { this.days$.next(days); }, enumerable: true, configurable: true }); Object.defineProperty(TimerComponent.prototype, "hours", { get: function () { return this.hours$.getValue(); }, set: function (hours) { this.hours$.next(hours); }, enumerable: true, configurable: true }); Object.defineProperty(TimerComponent.prototype, "minutes", { get: function () { return this.minutes$.getValue(); }, set: function (minutes) { this.minutes$.next(minutes); }, enumerable: true, configurable: true }); Object.defineProperty(TimerComponent.prototype, "seconds", { get: function () { return this.seconds$.getValue(); }, set: function (seconds) { this.seconds$.next(seconds); }, enumerable: true, configurable: true }); TimerComponent.prototype.pause = function () { clearInterval(this.timer); this.timer = null; }; TimerComponent.prototype.reset = function () { this.remains = this.days * SECONDS_IN_HOUR * HOURS_IN_DAY + this.hours * SECONDS_IN_HOUR + this.minutes * SECONDS_IN_MINUTE + this.seconds; this.start(); }; TimerComponent.prototype.ngOnInit = function () { var _this = this; combineLatest([this.days$, this.hours$, this.minutes$, this.seconds$]) .subscribe(function () { _this.remains = _this.days * SECONDS_IN_HOUR * HOURS_IN_DAY + _this.hours * SECONDS_IN_HOUR + _this.minutes * SECONDS_IN_MINUTE + _this.seconds; _this.start(); }); }; TimerComponent.prototype.start = function () { var _this = this; if (!!this.timer) { return; } this.pause(); this.timer = setInterval(function () { if (_this.remains >= 0) { _this.counter.days = Math.floor((_this.remains / SECONDS_IN_HOUR) / HOURS_IN_DAY); _this.counter.hours = Math.floor((_this.remains / SECONDS_IN_HOUR) % HOURS_IN_DAY); _this.counter.minutes = Math.floor((_this.remains / SECONDS_IN_MINUTE) % SECONDS_IN_MINUTE); _this.counter.seconds = Math.floor(_this.remains % SECONDS_IN_MINUTE); _this.remains--; } else { _this.pause(); _this.finished.emit(); } }, 1000); }; __decorate([ HostBinding('attr.host'), __metadata("design:type", Object) ], TimerComponent.prototype, "host", void 0); __decorate([ PropertyApi({ description: 'Days count', type: 'number', }), Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], TimerComponent.prototype, "days", null); __decorate([ PropertyApi({ description: 'Hours count', type: 'number', }), Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], TimerComponent.prototype, "hours", null); __decorate([ PropertyApi({ description: 'Minutes count', type: 'number', }), Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], TimerComponent.prototype, "minutes", null); __decorate([ PropertyApi({ description: 'Seconds count', type: 'number', }), Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], TimerComponent.prototype, "seconds", null); __decorate([ Output(), __metadata("design:type", Object) ], TimerComponent.prototype, "tick", void 0); __decorate([ Output(), __metadata("design:type", Object) ], TimerComponent.prototype, "finished", void 0); __decorate([ MethodApi({ description: 'Pause timer' }), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], TimerComponent.prototype, "pause", null); __decorate([ MethodApi({ description: 'Reset timer' }), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], TimerComponent.prototype, "reset", null); TimerComponent = __decorate([ Component({ selector: 'jnt-timer', template: "{{counter.days}}:{{counter.hours}}:{{counter.minutes}}:{{counter.seconds}}\n", styles: [""] }) ], TimerComponent); return TimerComponent; }()); export { TimerComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timer.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/dynamic/timer/timer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostBinding, Input, OnInit, Output } from '@angular/core';\nimport { BehaviorSubject, combineLatest } from 'rxjs';\nimport { MethodApi, PropertyApi } from '../../core/decorators/api';\nimport { UI } from '../../core/enums/ui';\n\ntype Counter = {\n  days: number,\n  hours: number,\n  minutes: number,\n  seconds: number\n}\n\nexport const SECONDS_IN_MINUTE = 60;\nexport const SECONDS_IN_HOUR = 3600;\nexport const HOURS_IN_DAY = 24;\n\n@Component({\n  selector: 'jnt-timer',\n  templateUrl: './timer.component.html',\n  styleUrls: ['./timer.component.scss']\n})\nexport class TimerComponent implements OnInit {\n\n  ui = UI;\n  remains = 0;\n  timer: any;\n  counter: Counter = {days: 0, hours: 0, minutes: 0, seconds: 0};\n\n  private days$ = new BehaviorSubject<number>(0);\n  private hours$ = new BehaviorSubject<number>(0);\n  private minutes$ = new BehaviorSubject<number>(0);\n  private seconds$ = new BehaviorSubject<number>(0);\n\n  @HostBinding('attr.host') readonly host = 'jnt-timer-host';\n\n  @PropertyApi({\n    description: 'Days count',\n    type: 'number',\n  })\n  @Input() set days(days: number) {\n    this.days$.next(days);\n  }\n\n  get days() {\n    return this.days$.getValue();\n  }\n\n  @PropertyApi({\n    description: 'Hours count',\n    type: 'number',\n  })\n  @Input() set hours(hours: number) {\n    this.hours$.next(hours);\n  }\n\n  get hours() {\n    return this.hours$.getValue();\n  }\n\n  @PropertyApi({\n    description: 'Minutes count',\n    type: 'number',\n  })\n  @Input() set minutes(minutes: number) {\n    this.minutes$.next(minutes);\n  }\n\n  get minutes() {\n    return this.minutes$.getValue();\n  }\n\n  @PropertyApi({\n    description: 'Seconds count',\n    type: 'number',\n  })\n  @Input() set seconds(seconds: number) {\n    this.seconds$.next(seconds);\n  }\n\n  get seconds() {\n    return this.seconds$.getValue();\n  }\n\n  @Output() tick = new EventEmitter<any>();\n  @Output() finished = new EventEmitter<any>();\n\n  @MethodApi({description: 'Pause timer'})\n  pause() {\n    clearInterval(this.timer);\n    this.timer = null;\n  }\n\n  @MethodApi({description: 'Reset timer'})\n  reset() {\n    this.remains = this.days * SECONDS_IN_HOUR * HOURS_IN_DAY + this.hours * SECONDS_IN_HOUR + this.minutes * SECONDS_IN_MINUTE + this.seconds;\n    this.start();\n  }\n\n  ngOnInit() {\n    combineLatest([this.days$, this.hours$, this.minutes$, this.seconds$])\n      .subscribe(() => {\n        this.remains = this.days * SECONDS_IN_HOUR * HOURS_IN_DAY + this.hours * SECONDS_IN_HOUR + this.minutes * SECONDS_IN_MINUTE + this.seconds;\n        this.start();\n      });\n  }\n\n  start() {\n    if (!!this.timer) {\n      return;\n    }\n\n    this.pause();\n    this.timer = setInterval(() => {\n      if (this.remains >= 0) {\n        this.counter.days = Math.floor((this.remains / SECONDS_IN_HOUR) / HOURS_IN_DAY);\n        this.counter.hours = Math.floor((this.remains / SECONDS_IN_HOUR) % HOURS_IN_DAY);\n        this.counter.minutes = Math.floor((this.remains / SECONDS_IN_MINUTE) % SECONDS_IN_MINUTE);\n        this.counter.seconds = Math.floor(this.remains % SECONDS_IN_MINUTE);\n        this.remains--;\n      } else {\n        this.pause();\n        this.finished.emit();\n      }\n    }, 1000);\n  }\n\n\n}\n"]}