UNPKG

@junte/ui

Version:

Quality Angular UI components kit

149 lines 14.3 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 const SECONDS_IN_MINUTE = 60; export const SECONDS_IN_HOUR = 3600; export const HOURS_IN_DAY = 24; let TimerComponent = class TimerComponent { constructor() { 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(); } set days(days) { this.days$.next(days); } get days() { return this.days$.getValue(); } set hours(hours) { this.hours$.next(hours); } get hours() { return this.hours$.getValue(); } set minutes(minutes) { this.minutes$.next(minutes); } get minutes() { return this.minutes$.getValue(); } set seconds(seconds) { this.seconds$.next(seconds); } get seconds() { return this.seconds$.getValue(); } pause() { clearInterval(this.timer); this.timer = null; } reset() { this.remains = this.days * SECONDS_IN_HOUR * HOURS_IN_DAY + this.hours * SECONDS_IN_HOUR + this.minutes * SECONDS_IN_MINUTE + this.seconds; this.start(); } ngOnInit() { combineLatest([this.days$, this.hours$, this.minutes$, this.seconds$]) .subscribe(() => { this.remains = this.days * SECONDS_IN_HOUR * HOURS_IN_DAY + this.hours * SECONDS_IN_HOUR + this.minutes * SECONDS_IN_MINUTE + this.seconds; this.start(); }); } start() { if (!!this.timer) { return; } this.pause(); this.timer = setInterval(() => { 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); 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"]}