kwikui
Version:
KwikID's UI Component Library in Angular
195 lines • 24.4 kB
JavaScript
import { __decorate } from "tslib";
import { Component, EventEmitter, Input, Output } from "@angular/core";
import { isNotEmptyValue, logMethod } from "kwikid-toolkit";
import { getTimerMessage } from "./button-api-call.helper";
import * as i0 from "@angular/core";
import * as i1 from "./button-api-call.timer.service";
import * as i2 from "@taiga-ui/core";
import * as i3 from "../messages/messages.component";
import * as i4 from "@angular/common";
export class KwikUIButtonApiCallComponent {
constructor(timerService) {
this.timerService = timerService;
this.apiTimer = undefined;
this.apiStatus = "default";
this.class = "tui-space_right-3 tui-space_bottom-3";
this.disabled = false;
this.id = "";
this.label = "Button";
this.shape = null;
this.showLoader = false;
this.size = "m";
this.styles = "";
this.onClick = new EventEmitter();
this.onApiTimerStop = new EventEmitter();
this.isShowApiTimerMessage = false;
this.icon = "";
this.iconRight = "";
this.apiTimerMessages = [];
}
ngOnInit() {
this.handleApiStatus(this.apiStatus);
this.handleApiTimer(this.apiTimer);
this.timerStopSubscription = this.timerService.stopTimer$.subscribe((reset) => {
if (reset) {
this.handleStopTimer();
}
});
this.timerValueSubscription = this.timerService.timer$.subscribe((value) => {
if (isNotEmptyValue(value)) {
const message = getTimerMessage(this.apiTimer.messageWithTimerPlaceholder, this.apiTimer.timeFormat, value);
this.apiTimerMessages = [
{
message,
type: "info"
}
];
this.isShowApiTimerMessage = true;
}
});
}
ngOnChanges(changes) {
const hasKey = (object, key) => {
return object.hasOwnProperty(key);
};
const verifyChange = (key) => {
return hasKey(changes, key) && !changes[key].firstChange;
};
if (verifyChange("apiStatus")) {
this.handleApiStatus(changes.apiStatus.currentValue);
}
if (verifyChange("disabled")) {
if (this.apiStatus === "default") {
this.disabled = changes.disabled.currentValue;
}
else if (this.apiStatus === "loading") {
this.disabled = true;
}
else {
this.disabled = false;
}
}
if (verifyChange("apiTimer")) {
this.apiTimer = changes.apiTimer.currentValue;
this.handleApiTimer(this.apiTimer, true);
}
}
ngOnDestroy() {
this.handleStopTimer();
this.timerService.stopTimer();
if (this.timerStopSubscription) {
this.timerStopSubscription.unsubscribe();
}
if (this.timerValueSubscription) {
this.timerValueSubscription.unsubscribe();
}
}
handleApiStatus(apiStatus) {
switch (apiStatus) {
case "default":
this.apiStatus = "default";
this.icon = "";
this.iconRight = "";
this.disabled = this.disabled;
this.showLoader = false;
break;
case "loading":
this.apiStatus = "loading";
this.icon = "";
this.iconRight = "";
this.disabled = true;
this.showLoader = true;
break;
case "retry":
this.apiStatus = "retry";
this.icon = "tuiIconRotateCw";
this.iconRight = "";
this.disabled = !!isNotEmptyValue(this.apiTimer);
this.showLoader = false;
break;
case "success":
this.apiStatus = "success";
this.icon = "";
this.iconRight = "tuiIconCheck";
this.disabled = false;
this.showLoader = false;
break;
case "failed":
this.apiStatus = "failed";
this.icon = "";
this.iconRight = "tuiIconClose";
this.disabled = false;
this.showLoader = false;
break;
default:
break;
}
}
handleOnClick(e) {
if (this.apiStatus === "default" || this.apiStatus === "retry") {
this.onClick.emit({ event: e, key: this.id });
}
}
handleApiTimer(apiTimer, onChange = false) {
if (isNotEmptyValue(apiTimer)) {
this.disabled = true;
this.timerService.startTimer(apiTimer);
}
else if (onChange) {
this.resetApiTimer();
}
}
handleStopTimer() {
this.resetApiTimer();
this.onApiTimerStop.emit({ key: this.id });
}
resetApiTimer() {
this.apiTimerMessages = [];
this.isShowApiTimerMessage = false;
this.disabled = false;
}
}
/** @nocollapse */ KwikUIButtonApiCallComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIButtonApiCallComponent, deps: [{ token: i1.KwikUIButtonApiCallTimerService }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ KwikUIButtonApiCallComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikUIButtonApiCallComponent, selector: "kwikui-button-api-call", inputs: { apiTimer: "apiTimer", apiStatus: "apiStatus", class: "class", disabled: "disabled", id: "id", label: "label", shape: "shape", showLoader: "showLoader", size: "size", styles: "styles" }, outputs: { onClick: "onClick", onApiTimerStop: "onApiTimerStop" }, usesOnChanges: true, ngImport: i0, template: "<div>\n <button\n tuiButton\n [appearance]=\"'primary'\"\n [class.default]=\"apiStatus === 'default'\"\n [class.failed]=\"apiStatus === 'failed'\"\n [class.loading]=\"apiStatus === 'loading'\"\n [class.success]=\"apiStatus === 'success'\"\n [class]=\"class\"\n [disabled]=\"disabled\"\n [icon]=\"icon\"\n [iconRight]=\"iconRight\"\n [nativeId]=\"id\"\n [shape]=\"shape\"\n [showLoader]=\"showLoader\"\n [size]=\"size\"\n [style]=\"styles\"\n [type]=\"'button'\"\n (click)=\"handleOnClick($event)\"\n >\n {{ label }}\n </button>\n\n <kwikui-messages\n *ngIf=\"isShowApiTimerMessage\"\n [id]=\"id\"\n [messages]=\"apiTimerMessages\"\n ></kwikui-messages>\n</div>\n", styles: [".w-100{width:100%}button{margin:0}:host .loading{pointer-events:none;cursor:not-allowed}:host .success{--tui-primary: var(--tui-support-04);--tui-primary-hover: var(--tui-support-04);--tui-primary-active: var(--tui-support-04);--tui-primary-text: #fff;pointer-events:none;cursor:not-allowed}:host .failed{--tui-primary: var(--tui-negative);--tui-primary-hover: var(--tui-negative-hover);--tui-primary-active: var(--tui-negative);--tui-primary-text: #fff;pointer-events:none;cursor:not-allowed}\n"], components: [{ type: i2.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { type: i3.KwikUIMessagesComponent, selector: "kwikui-messages", inputs: ["id", "messages"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
__decorate([
logMethod
], KwikUIButtonApiCallComponent.prototype, "handleOnClick", null);
__decorate([
logMethod
], KwikUIButtonApiCallComponent.prototype, "handleApiTimer", null);
__decorate([
logMethod
], KwikUIButtonApiCallComponent.prototype, "handleStopTimer", null);
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIButtonApiCallComponent, decorators: [{
type: Component,
args: [{
selector: "kwikui-button-api-call",
templateUrl: "./button-api-call.component.html",
styleUrls: ["./button-api-call.component.scss"]
}]
}], ctorParameters: function () { return [{ type: i1.KwikUIButtonApiCallTimerService }]; }, propDecorators: { apiTimer: [{
type: Input
}], apiStatus: [{
type: Input
}], class: [{
type: Input
}], disabled: [{
type: Input
}], id: [{
type: Input
}], label: [{
type: Input
}], shape: [{
type: Input
}], showLoader: [{
type: Input
}], size: [{
type: Input
}], styles: [{
type: Input
}], onClick: [{
type: Output
}], onApiTimerStop: [{
type: Output
}], handleOnClick: [], handleApiTimer: [], handleStopTimer: [] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-api-call.component.js","sourceRoot":"","sources":["../../../../../../../projects/kwikui/src/lib/components/custom/button-api-call/button-api-call.component.ts","../../../../../../../projects/kwikui/src/lib/components/custom/button-api-call/button-api-call.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  SimpleChanges\n} from \"@angular/core\";\nimport { isNotEmptyValue, logMethod } from \"kwikid-toolkit\";\nimport { Subscription } from \"rxjs\";\nimport { KwikUIButtonApiCallTimerService } from \"./button-api-call.timer.service\";\nimport { TKwikUIButtonApiCallTimer } from \"./button-api-call.definitions\";\nimport { getTimerMessage } from \"./button-api-call.helper\";\n\n@Component({\n  selector: \"kwikui-button-api-call\",\n  templateUrl: \"./button-api-call.component.html\",\n  styleUrls: [\"./button-api-call.component.scss\"]\n})\nexport class KwikUIButtonApiCallComponent implements OnInit {\n  @Input() apiTimer: TKwikUIButtonApiCallTimer = undefined;\n\n  @Input() apiStatus: \"default\" | \"loading\" | \"retry\" | \"success\" | \"failed\" =\n    \"default\";\n\n  @Input() class = \"tui-space_right-3 tui-space_bottom-3\";\n\n  @Input() disabled = false;\n\n  @Input() id = \"\";\n\n  @Input() label = \"Button\";\n\n  @Input() shape: null | \"square\" | \"rounded\" = null;\n\n  @Input() showLoader = false;\n\n  @Input() size: \"xs\" | \"s\" | \"m\" | \"l\" | \"xl\" = \"m\";\n\n  @Input() styles = \"\";\n\n  @Output() onClick = new EventEmitter<any>();\n\n  @Output() onApiTimerStop: EventEmitter<any> = new EventEmitter<any>();\n\n  isShowApiTimerMessage = false;\n\n  icon = \"\";\n\n  iconRight = \"\";\n\n  apiTimerMessages: Array<any> = [];\n\n  private timerStopSubscription: Subscription;\n\n  private timerValueSubscription: Subscription;\n\n  constructor(public timerService: KwikUIButtonApiCallTimerService) {}\n\n  ngOnInit(): void {\n    this.handleApiStatus(this.apiStatus);\n    this.handleApiTimer(this.apiTimer);\n\n    this.timerStopSubscription = this.timerService.stopTimer$.subscribe(\n      (reset) => {\n        if (reset) {\n          this.handleStopTimer();\n        }\n      }\n    );\n\n    this.timerValueSubscription = this.timerService.timer$.subscribe(\n      (value) => {\n        if (isNotEmptyValue(value)) {\n          const message = getTimerMessage(\n            this.apiTimer.messageWithTimerPlaceholder,\n            this.apiTimer.timeFormat,\n            value\n          );\n          this.apiTimerMessages = [\n            {\n              message,\n              type: \"info\"\n            }\n          ];\n          this.isShowApiTimerMessage = true;\n        }\n      }\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const hasKey = (object: any, key: string): boolean => {\n      return object.hasOwnProperty(key);\n    };\n    const verifyChange = (key: string) => {\n      return hasKey(changes, key) && !changes[key].firstChange;\n    };\n    if (verifyChange(\"apiStatus\")) {\n      this.handleApiStatus(changes.apiStatus.currentValue);\n    }\n    if (verifyChange(\"disabled\")) {\n      if (this.apiStatus === \"default\") {\n        this.disabled = changes.disabled.currentValue;\n      } else if (this.apiStatus === \"loading\") {\n        this.disabled = true;\n      } else {\n        this.disabled = false;\n      }\n    }\n    if (verifyChange(\"apiTimer\")) {\n      this.apiTimer = changes.apiTimer.currentValue;\n      this.handleApiTimer(this.apiTimer, true);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.handleStopTimer();\n    this.timerService.stopTimer();\n\n    if (this.timerStopSubscription) {\n      this.timerStopSubscription.unsubscribe();\n    }\n    if (this.timerValueSubscription) {\n      this.timerValueSubscription.unsubscribe();\n    }\n  }\n\n  handleApiStatus(apiStatus: string): void {\n    switch (apiStatus) {\n      case \"default\":\n        this.apiStatus = \"default\";\n        this.icon = \"\";\n        this.iconRight = \"\";\n        this.disabled = this.disabled;\n        this.showLoader = false;\n        break;\n      case \"loading\":\n        this.apiStatus = \"loading\";\n        this.icon = \"\";\n        this.iconRight = \"\";\n        this.disabled = true;\n        this.showLoader = true;\n        break;\n      case \"retry\":\n        this.apiStatus = \"retry\";\n        this.icon = \"tuiIconRotateCw\";\n        this.iconRight = \"\";\n        this.disabled = !!isNotEmptyValue(this.apiTimer);\n        this.showLoader = false;\n        break;\n      case \"success\":\n        this.apiStatus = \"success\";\n        this.icon = \"\";\n        this.iconRight = \"tuiIconCheck\";\n        this.disabled = false;\n        this.showLoader = false;\n        break;\n      case \"failed\":\n        this.apiStatus = \"failed\";\n        this.icon = \"\";\n        this.iconRight = \"tuiIconClose\";\n        this.disabled = false;\n        this.showLoader = false;\n        break;\n      default:\n        break;\n    }\n  }\n\n  @logMethod\n  handleOnClick(e: any) {\n    if (this.apiStatus === \"default\" || this.apiStatus === \"retry\") {\n      this.onClick.emit({ event: e, key: this.id });\n    }\n  }\n\n  @logMethod\n  handleApiTimer(apiTimer, onChange = false) {\n    if (isNotEmptyValue(apiTimer)) {\n      this.disabled = true;\n      this.timerService.startTimer(apiTimer);\n    } else if (onChange) {\n      this.resetApiTimer();\n    }\n  }\n\n  @logMethod\n  handleStopTimer() {\n    this.resetApiTimer();\n    this.onApiTimerStop.emit({ key: this.id });\n  }\n\n  resetApiTimer() {\n    this.apiTimerMessages = [];\n    this.isShowApiTimerMessage = false;\n    this.disabled = false;\n  }\n}\n","<div>\n  <button\n    tuiButton\n    [appearance]=\"'primary'\"\n    [class.default]=\"apiStatus === 'default'\"\n    [class.failed]=\"apiStatus === 'failed'\"\n    [class.loading]=\"apiStatus === 'loading'\"\n    [class.success]=\"apiStatus === 'success'\"\n    [class]=\"class\"\n    [disabled]=\"disabled\"\n    [icon]=\"icon\"\n    [iconRight]=\"iconRight\"\n    [nativeId]=\"id\"\n    [shape]=\"shape\"\n    [showLoader]=\"showLoader\"\n    [size]=\"size\"\n    [style]=\"styles\"\n    [type]=\"'button'\"\n    (click)=\"handleOnClick($event)\"\n  >\n    {{ label }}\n  </button>\n\n  <kwikui-messages\n    *ngIf=\"isShowApiTimerMessage\"\n    [id]=\"id\"\n    [messages]=\"apiTimerMessages\"\n  ></kwikui-messages>\n</div>\n"]}