@junte/ui
Version:
Quality Angular UI components kit
168 lines • 15.5 kB
JavaScript
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":";AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,EAAE,EAAE,MAAM,qBAAqB,CAAC;AASzC,MAAM,CAAC,IAAM,iBAAiB,GAAG,EAAE,CAAC;AACpC,MAAM,CAAC,IAAM,eAAe,GAAG,IAAI,CAAC;AACpC,MAAM,CAAC,IAAM,YAAY,GAAG,EAAE,CAAC;AAO/B;IAAA;QAEE,OAAE,GAAG,EAAE,CAAC;QACR,YAAO,GAAG,CAAC,CAAC;QAEZ,YAAO,GAAY,EAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAC,CAAC;QAEvD,UAAK,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QACvC,WAAM,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QACxC,aAAQ,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QAC1C,aAAQ,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QAEf,SAAI,GAAG,gBAAgB,CAAC;QAkDjD,SAAI,GAAG,IAAI,YAAY,EAAO,CAAC;QAC/B,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;IA2C/C,CAAC;IAxFU,sBAAI,gCAAI;aAIjB;YACE,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC/B,CAAC;aANQ,UAAS,IAAY;YAC5B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxB,CAAC;;;OAAA;IAUQ,sBAAI,iCAAK;aAIlB;YACE,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAChC,CAAC;aANQ,UAAU,KAAa;YAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;;;OAAA;IAUQ,sBAAI,mCAAO;aAIpB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QAClC,CAAC;aANQ,UAAY,OAAe;YAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9B,CAAC;;;OAAA;IAUQ,sBAAI,mCAAO;aAIpB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QAClC,CAAC;aANQ,UAAY,OAAe;YAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9B,CAAC;;;OAAA;IAUD,8BAAK,GAAL;QACE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAGD,8BAAK,GAAL;QACE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,GAAG,eAAe,GAAG,YAAY,GAAG,IAAI,CAAC,KAAK,GAAG,eAAe,GAAG,IAAI,CAAC,OAAO,GAAG,iBAAiB,GAAG,IAAI,CAAC,OAAO,CAAC;QAC3I,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAED,iCAAQ,GAAR;QAAA,iBAMC;QALC,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;aACnE,SAAS,CAAC;YACT,KAAI,CAAC,OAAO,GAAG,KAAI,CAAC,IAAI,GAAG,eAAe,GAAG,YAAY,GAAG,KAAI,CAAC,KAAK,GAAG,eAAe,GAAG,KAAI,CAAC,OAAO,GAAG,iBAAiB,GAAG,KAAI,CAAC,OAAO,CAAC;YAC3I,KAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;IACP,CAAC;IAED,8BAAK,GAAL;QAAA,iBAkBC;QAjBC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE;YAChB,OAAO;SACR;QAED,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC;YACvB,IAAI,KAAI,CAAC,OAAO,IAAI,CAAC,EAAE;gBACrB,KAAI,CAAC,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,KAAI,CAAC,OAAO,GAAG,eAAe,CAAC,GAAG,YAAY,CAAC,CAAC;gBAChF,KAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,KAAI,CAAC,OAAO,GAAG,eAAe,CAAC,GAAG,YAAY,CAAC,CAAC;gBACjF,KAAI,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,KAAI,CAAC,OAAO,GAAG,iBAAiB,CAAC,GAAG,iBAAiB,CAAC,CAAC;gBAC1F,KAAI,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAI,CAAC,OAAO,GAAG,iBAAiB,CAAC,CAAC;gBACpE,KAAI,CAAC,OAAO,EAAE,CAAC;aAChB;iBAAM;gBACL,KAAI,CAAC,KAAK,EAAE,CAAC;gBACb,KAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACtB;QACH,CAAC,EAAE,IAAI,CAAC,CAAC;IACX,CAAC;IA3FyB;QAAzB,WAAW,CAAC,WAAW,CAAC;;gDAAkC;IAMlD;QAJR,WAAW,CAAC;YACX,WAAW,EAAE,YAAY;YACzB,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,EAAE;;;8CAEP;IAUQ;QAJR,WAAW,CAAC;YACX,WAAW,EAAE,aAAa;YAC1B,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,EAAE;;;+CAEP;IAUQ;QAJR,WAAW,CAAC;YACX,WAAW,EAAE,eAAe;YAC5B,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,EAAE;;;iDAEP;IAUQ;QAJR,WAAW,CAAC;YACX,WAAW,EAAE,eAAe;YAC5B,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,EAAE;;;iDAEP;IAMS;QAAT,MAAM,EAAE;;gDAAgC;IAC/B;QAAT,MAAM,EAAE;;oDAAoC;IAG7C;QADC,SAAS,CAAC,EAAC,WAAW,EAAE,aAAa,EAAC,CAAC;;;;+CAIvC;IAGD;QADC,SAAS,CAAC,EAAC,WAAW,EAAE,aAAa,EAAC,CAAC;;;;+CAIvC;IA3EU,cAAc;QAL1B,SAAS,CAAC;YACT,QAAQ,EAAE,WAAW;YACrB,wFAAqC;;SAEtC,CAAC;OACW,cAAc,CA0G1B;IAAD,qBAAC;CAAA,AA1GD,IA0GC;SA1GY,cAAc","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"]}