zek 14.2.76 → 14.2.77

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,7 @@
1
1
  import { BooleanInput } from '../../../components';
2
2
  import { AlertType } from '../../../models';
3
3
  import * as i0 from "@angular/core";
4
- export declare class AlertComponent {
4
+ export declare class ZekAlert {
5
5
  private _type;
6
6
  get type(): AlertType | string | null | undefined;
7
7
  set type(v: AlertType | string | null | undefined);
@@ -11,6 +11,6 @@ export declare class AlertComponent {
11
11
  title?: string | null;
12
12
  cssAlert: string;
13
13
  cssIcon: string;
14
- static ɵfac: i0.ɵɵFactoryDeclaration<AlertComponent, never>;
15
- static ɵcmp: i0.ɵɵComponentDeclaration<AlertComponent, "zek-alert", never, { "type": "type"; "title": "title"; }, {}, never, ["*"], false>;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<ZekAlert, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<ZekAlert, "zek-alert", never, { "type": "type"; "title": "title"; }, {}, never, ["*"], false>;
16
16
  }
@@ -1,10 +1,10 @@
1
1
  import * as i0 from "@angular/core";
2
- import * as i1 from "./alert/alert.component";
3
- import * as i2 from "./validation/validation.component";
4
- import * as i3 from "./toast/toast.component";
2
+ import * as i1 from "./alert/alert";
3
+ import * as i2 from "./validation/validation";
4
+ import * as i3 from "./toast/toast";
5
5
  import * as i4 from "@angular/common";
6
6
  export declare class AlertModule {
7
7
  static ɵfac: i0.ɵɵFactoryDeclaration<AlertModule, never>;
8
- static ɵmod: i0.ɵɵNgModuleDeclaration<AlertModule, [typeof i1.AlertComponent, typeof i2.ValidationComponent, typeof i3.ToastComponent], [typeof i4.CommonModule], [typeof i1.AlertComponent, typeof i2.ValidationComponent, typeof i3.ToastComponent]>;
8
+ static ɵmod: i0.ɵɵNgModuleDeclaration<AlertModule, [typeof i1.ZekAlert, typeof i2.ZekValidation, typeof i3.ZekToast], [typeof i4.CommonModule], [typeof i1.ZekAlert, typeof i2.ZekValidation, typeof i3.ZekToast]>;
9
9
  static ɵinj: i0.ɵɵInjectorDeclaration<AlertModule>;
10
10
  }
@@ -1,5 +1,5 @@
1
- export * from './alert/alert.component';
2
- export * from './toast/toast.component';
3
- export * from './validation/validation.component';
1
+ export * from './alert/alert';
2
+ export * from './toast/toast';
3
+ export * from './validation/validation';
4
4
  export * from './alert.module';
5
5
  export * from '../../services/alert.service';
@@ -1,7 +1,7 @@
1
1
  import { OnInit, OnDestroy } from '@angular/core';
2
2
  import { AlertService, Toast } from '../../../services/alert.service';
3
3
  import * as i0 from "@angular/core";
4
- export declare class ToastComponent implements OnInit, OnDestroy {
4
+ export declare class ZekToast implements OnInit, OnDestroy {
5
5
  private readonly alertService;
6
6
  timeOut?: number;
7
7
  icon: boolean;
@@ -15,6 +15,6 @@ export declare class ToastComponent implements OnInit, OnDestroy {
15
15
  remove(toast: Toast): void;
16
16
  clearTimeout(): void;
17
17
  cssInit(toast: Toast): void;
18
- static ɵfac: i0.ɵɵFactoryDeclaration<ToastComponent, never>;
19
- static ɵcmp: i0.ɵɵComponentDeclaration<ToastComponent, "zek-toast", never, { "timeOut": "timeOut"; "icon": "icon"; }, {}, never, never, false>;
18
+ static ɵfac: i0.ɵɵFactoryDeclaration<ZekToast, never>;
19
+ static ɵcmp: i0.ɵɵComponentDeclaration<ZekToast, "zek-toast", never, { "timeOut": "timeOut"; "icon": "icon"; }, {}, never, never, false>;
20
20
  }
@@ -1,7 +1,7 @@
1
1
  import { OnInit, OnDestroy } from '@angular/core';
2
2
  import { AlertService, Alert } from '../../../services/alert.service';
3
3
  import * as i0 from "@angular/core";
4
- export declare class ValidationComponent implements OnInit, OnDestroy {
4
+ export declare class ZekValidation implements OnInit, OnDestroy {
5
5
  private readonly alertService;
6
6
  alerts: Alert[];
7
7
  private subscription?;
@@ -12,6 +12,6 @@ export declare class ValidationComponent implements OnInit, OnDestroy {
12
12
  remove(alert: Alert): void;
13
13
  cssIcon(alert: Alert): string | undefined;
14
14
  cssAlert(alert: Alert): "alert-primary" | "alert-secondary" | "alert-success" | "alert-danger" | "alert-warning" | "alert-info" | "alert-light" | "alert-dark" | undefined;
15
- static ɵfac: i0.ɵɵFactoryDeclaration<ValidationComponent, never>;
16
- static ɵcmp: i0.ɵɵComponentDeclaration<ValidationComponent, "zek-validation", never, {}, {}, never, ["*"], false>;
15
+ static ɵfac: i0.ɵɵFactoryDeclaration<ZekValidation, never>;
16
+ static ɵcmp: i0.ɵɵComponentDeclaration<ZekValidation, "zek-validation", never, {}, {}, never, ["*"], false>;
17
17
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "zek",
3
- "version": "14.2.76",
3
+ "version": "14.2.77",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^14.0.0",
6
6
  "@angular/core": "^14.0.0"
@@ -1,52 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import { AlertType } from '../../../models';
3
- import { Convert } from '../../../utils';
4
- import { BootstrapHelper } from '../../../utils/bootstrap.helper';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/common";
7
- export class AlertComponent {
8
- constructor() {
9
- this._type = AlertType.Info;
10
- this._showClose = true;
11
- this.cssAlert = '';
12
- this.cssIcon = '';
13
- }
14
- get type() {
15
- return this._type;
16
- }
17
- set type(v) {
18
- if (v !== this._type) {
19
- this._type = v;
20
- this.cssAlert = '';
21
- this.cssIcon = '';
22
- if (typeof v === 'string') {
23
- let enumValue = BootstrapHelper.getAlertType(v);
24
- if (enumValue) {
25
- this.cssAlert = BootstrapHelper.cssAlert(enumValue);
26
- this.cssIcon = BootstrapHelper.cssAlertIcon(enumValue);
27
- }
28
- }
29
- else {
30
- this.cssAlert = BootstrapHelper.cssAlert(v);
31
- this.cssIcon = BootstrapHelper.cssAlertIcon(v);
32
- }
33
- }
34
- }
35
- get showClose() {
36
- return this._showClose;
37
- }
38
- set showClose(v) {
39
- this._showClose = Convert.toBoolean(v);
40
- }
41
- }
42
- AlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
43
- AlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: AlertComponent, selector: "zek-alert", inputs: { type: "type", title: "title" }, ngImport: i0, template: "<div class=\"alert {{cssAlert}} alert-dismissible fade show\" role=\"alert\">\r\n <button *ngIf=\"_showClose\" type=\"button\" class=\"btn-close\" data-bs-dismiss=\"alert\" aria-label=\"Close\"></button>\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1\" *ngIf=\"cssIcon\">\r\n <span class=\"flex-shrink-0\"><i class=\"{{cssIcon}}\"></i></span>\r\n </div>\r\n <div class=\"col-auto\">\r\n <div *ngIf=\"title\">\r\n <h5 class=\"alert-heading\">{{title}}</h5>\r\n </div>\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
44
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, decorators: [{
45
- type: Component,
46
- args: [{ selector: 'zek-alert', template: "<div class=\"alert {{cssAlert}} alert-dismissible fade show\" role=\"alert\">\r\n <button *ngIf=\"_showClose\" type=\"button\" class=\"btn-close\" data-bs-dismiss=\"alert\" aria-label=\"Close\"></button>\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1\" *ngIf=\"cssIcon\">\r\n <span class=\"flex-shrink-0\"><i class=\"{{cssIcon}}\"></i></span>\r\n </div>\r\n <div class=\"col-auto\">\r\n <div *ngIf=\"title\">\r\n <h5 class=\"alert-heading\">{{title}}</h5>\r\n </div>\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:block}\n"] }]
47
- }], propDecorators: { type: [{
48
- type: Input
49
- }], title: [{
50
- type: Input
51
- }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9hbGVydC9hbGVydC9hbGVydC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL2FsZXJ0L2FsZXJ0L2FsZXJ0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWpELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOzs7QUFPbEUsTUFBTSxPQUFPLGNBQWM7SUFMM0I7UUFNWSxVQUFLLEdBQTBDLFNBQVMsQ0FBQyxJQUFJLENBQUM7UUF3QnRFLGVBQVUsR0FBWSxJQUFJLENBQUM7UUFXM0IsYUFBUSxHQUFHLEVBQUUsQ0FBQztRQUNkLFlBQU8sR0FBRyxFQUFFLENBQUM7S0FVaEI7SUE3Q0csSUFDSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFDRCxJQUFJLElBQUksQ0FBQyxDQUF3QztRQUM3QyxJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2xCLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFBO1lBRWQsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7WUFDbEIsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLEVBQUU7Z0JBQ3ZCLElBQUksU0FBUyxHQUFHLGVBQWUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2hELElBQUksU0FBUyxFQUFFO29CQUNYLElBQUksQ0FBQyxRQUFRLEdBQUcsZUFBZSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztvQkFDcEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxlQUFlLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2lCQUMxRDthQUNKO2lCQUFNO2dCQUNILElBQUksQ0FBQyxRQUFRLEdBQUcsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDNUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ2xEO1NBQ0o7SUFDTCxDQUFDO0lBR0QsSUFBSSxTQUFTO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQzNCLENBQUM7SUFDRCxJQUFJLFNBQVMsQ0FBQyxDQUFlO1FBQ3pCLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMzQyxDQUFDOzsyR0EvQlEsY0FBYzsrRkFBZCxjQUFjLDJGQ1gzQiwwbkJBYU07MkZERk8sY0FBYztrQkFMMUIsU0FBUzsrQkFDSSxXQUFXOzhCQU9qQixJQUFJO3NCQURQLEtBQUs7Z0JBK0JHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IEFsZXJ0VHlwZSB9IGZyb20gJy4uLy4uLy4uL21vZGVscyc7XHJcbmltcG9ydCB7IENvbnZlcnQgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IEJvb3RzdHJhcEhlbHBlciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL2Jvb3RzdHJhcC5oZWxwZXInO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ3play1hbGVydCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYWxlcnQuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVzOiBbJzpob3N0IHsgZGlzcGxheTogYmxvY2s7IH0nXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQWxlcnRDb21wb25lbnQge1xyXG4gICAgcHJpdmF0ZSBfdHlwZTogQWxlcnRUeXBlIHwgc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZCA9IEFsZXJ0VHlwZS5JbmZvO1xyXG4gICAgQElucHV0KClcclxuICAgIGdldCB0eXBlKCk6IEFsZXJ0VHlwZSB8IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl90eXBlO1xyXG4gICAgfVxyXG4gICAgc2V0IHR5cGUodjogQWxlcnRUeXBlIHwgc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZCkge1xyXG4gICAgICAgIGlmICh2ICE9PSB0aGlzLl90eXBlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX3R5cGUgPSB2XHJcblxyXG4gICAgICAgICAgICB0aGlzLmNzc0FsZXJ0ID0gJyc7XHJcbiAgICAgICAgICAgIHRoaXMuY3NzSWNvbiA9ICcnO1xyXG4gICAgICAgICAgICBpZiAodHlwZW9mIHYgPT09ICdzdHJpbmcnKSB7XHJcbiAgICAgICAgICAgICAgICBsZXQgZW51bVZhbHVlID0gQm9vdHN0cmFwSGVscGVyLmdldEFsZXJ0VHlwZSh2KTtcclxuICAgICAgICAgICAgICAgIGlmIChlbnVtVmFsdWUpIHtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNzc0FsZXJ0ID0gQm9vdHN0cmFwSGVscGVyLmNzc0FsZXJ0KGVudW1WYWx1ZSk7XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5jc3NJY29uID0gQm9vdHN0cmFwSGVscGVyLmNzc0FsZXJ0SWNvbihlbnVtVmFsdWUpO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5jc3NBbGVydCA9IEJvb3RzdHJhcEhlbHBlci5jc3NBbGVydCh2KTtcclxuICAgICAgICAgICAgICAgIHRoaXMuY3NzSWNvbiA9IEJvb3RzdHJhcEhlbHBlci5jc3NBbGVydEljb24odik7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgX3Nob3dDbG9zZTogYm9vbGVhbiA9IHRydWU7XHJcbiAgICBnZXQgc2hvd0Nsb3NlKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zaG93Q2xvc2U7XHJcbiAgICB9XHJcbiAgICBzZXQgc2hvd0Nsb3NlKHY6IEJvb2xlYW5JbnB1dCkge1xyXG4gICAgICAgIHRoaXMuX3Nob3dDbG9zZSA9IENvbnZlcnQudG9Cb29sZWFuKHYpO1xyXG4gICAgfVxyXG5cclxuICAgIEBJbnB1dCgpIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcclxuXHJcblxyXG4gICAgY3NzQWxlcnQgPSAnJztcclxuICAgIGNzc0ljb24gPSAnJztcclxuXHJcblxyXG4gICAgLy8gY3NzSWNvbigpIHtcclxuICAgIC8vICAgICByZXR1cm4gQm9vdHN0cmFwSGVscGVyLmNzc0FsZXJ0SWNvbih0aGlzLl90eXBlKTtcclxuICAgIC8vIH1cclxuXHJcbiAgICAvLyBjc3NBbGVydCgpIHtcclxuICAgIC8vICAgICByZXR1cm4gQm9vdHN0cmFwSGVscGVyLmNzc0FsZXJ0KHRoaXMuX3R5cGUpO1xyXG4gICAgLy8gfVxyXG59XHJcblxyXG4iLCI8ZGl2IGNsYXNzPVwiYWxlcnQge3tjc3NBbGVydH19IGFsZXJ0LWRpc21pc3NpYmxlIGZhZGUgc2hvd1wiIHJvbGU9XCJhbGVydFwiPlxyXG4gICAgPGJ1dHRvbiAqbmdJZj1cIl9zaG93Q2xvc2VcIiB0eXBlPVwiYnV0dG9uXCIgY2xhc3M9XCJidG4tY2xvc2VcIiBkYXRhLWJzLWRpc21pc3M9XCJhbGVydFwiIGFyaWEtbGFiZWw9XCJDbG9zZVwiPjwvYnV0dG9uPlxyXG4gICAgPGRpdiBjbGFzcz1cInJvd1wiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtYXV0byBwZS0xXCIgKm5nSWY9XCJjc3NJY29uXCI+XHJcbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZmxleC1zaHJpbmstMFwiPjxpIGNsYXNzPVwie3tjc3NJY29ufX1cIj48L2k+PC9zcGFuPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtYXV0b1wiPlxyXG4gICAgICAgICAgICA8ZGl2ICpuZ0lmPVwidGl0bGVcIj5cclxuICAgICAgICAgICAgICAgIDxoNSBjbGFzcz1cImFsZXJ0LWhlYWRpbmdcIj57e3RpdGxlfX08L2g1PlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
@@ -1,109 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import { BootstrapHelper } from '../../../utils';
3
- import { AlertType } from '../../../models';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "../../../services/alert.service";
6
- import * as i2 from "@angular/common";
7
- export class ToastComponent {
8
- constructor(alertService) {
9
- this.alertService = alertService;
10
- this.icon = true;
11
- this.toasts = [];
12
- }
13
- ngOnInit() {
14
- this.subscription = this.alertService.getToast().subscribe((toast) => {
15
- if (!toast) {
16
- // clear alerts when an empty alert is received
17
- this.toasts = [];
18
- return;
19
- }
20
- // add toast to array
21
- this.cssInit(toast);
22
- this.toasts.unshift(toast);
23
- this.timeout = setTimeout(() => {
24
- this.remove(toast);
25
- // let toastEl = document.getElementById(`toast-${toast.id}`);
26
- // let t = new bootstrap.Toast(toastEl);
27
- // t.show();
28
- }, 3000);
29
- // let toastElList = [].slice.call(document.querySelectorAll('.toast'))
30
- // let toastList = toastElList.map(function (toastEl) {
31
- // return new bootstrap.Toast(toastEl)
32
- // })
33
- // toastList.forEach(t => {
34
- // t.show();
35
- // });
36
- });
37
- }
38
- ngOnDestroy() {
39
- if (this.subscription) {
40
- this.subscription.unsubscribe();
41
- }
42
- this.clearTimeout();
43
- }
44
- clear() {
45
- this.alertService.clear();
46
- }
47
- remove(toast) {
48
- this.toasts = this.toasts.filter(x => x !== toast);
49
- }
50
- clearTimeout() {
51
- if (this.timeout) {
52
- clearTimeout(this.timeout);
53
- this.timeout = null;
54
- }
55
- }
56
- cssInit(toast) {
57
- if (!toast || !toast.type)
58
- return;
59
- if (this.icon) {
60
- toast.icon = BootstrapHelper.cssAlertIcon(toast.type);
61
- }
62
- var v = toast;
63
- switch (toast.type) {
64
- case AlertType.Primary:
65
- v.css = 'bg-primary text-white';
66
- break;
67
- case AlertType.Success:
68
- v.css = 'bg-success text-white';
69
- // v.iconColor = 'text--accent-green';
70
- // v.borderColor = 'border--accent-green';
71
- break;
72
- case AlertType.Danger:
73
- v.css = 'bg-danger text-white';
74
- // v.iconColor = 'text--accent-red';
75
- // v.borderColor = 'border--accent-red';
76
- break;
77
- case AlertType.Warning:
78
- v.css = 'bg-warning text-dark';
79
- // v.iconColor = 'text--accent-yellow';
80
- // v.borderColor = 'border--accent-yellow';
81
- break;
82
- case AlertType.Info:
83
- v.css = 'bg-info text-white';
84
- // v.iconColor = 'text--accent-blue';
85
- // v.borderColor = 'border--accent-blue';
86
- break;
87
- case AlertType.Light:
88
- v.css = 'bg-light text-dark';
89
- break;
90
- case AlertType.Dark:
91
- v.css = 'bg-dark text-white';
92
- break;
93
- default:
94
- v.css = 'bg-secondary text-white';
95
- break;
96
- }
97
- }
98
- }
99
- ToastComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ToastComponent, deps: [{ token: i1.AlertService }], target: i0.ɵɵFactoryTarget.Component });
100
- ToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ToastComponent, selector: "zek-toast", inputs: { timeOut: "timeOut", icon: "icon" }, ngImport: i0, template: "<div class=\"toast-container position-fixed top-0 end-0 p-3\">\r\n <div *ngFor=\"let toast of toasts\" class=\"toast fade show border-0 {{ toast.css }}\" role=\"alert\" aria-live=\"assertive\" aria-atomic=\"true\" data-bs-delay=\"3000\">\r\n <div class=\"toast-header\">\r\n <span class=\"me-1\" *ngIf=\"icon && toast.icon\"><i class=\"{{ toast.icon }}\"></i></span>\r\n <strong class=\"me-auto\" *ngIf=\"toast.title\">{{ toast.title }}</strong>\r\n <button type=\"button\" class=\"btn-close ms-auto me-2\" data-bs-dismiss=\"toast\" aria-label=\"Close\" (click)=\"remove(toast)\"></button>\r\n </div>\r\n <div class=\"toast-body\">\r\n {{ toast.message }}\r\n </div>\r\n </div>\r\n <!-- <div *ngFor=\"let toast of toasts\" class=\"toast fade show\" role=\"alert\" aria-live=\"assertive\" aria-atomic=\"true\" data-bs-delay=\"3000\">\r\n <div class=\"toast-body\">\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1 border-start border-8 {{toast.borderColor}}\">\r\n <span *ngIf=\"toast.icon\" class=\"icon flex-shrink-0 {{toast.iconColor}}\"><i class=\"{{toast.icon}}\"></i></span>\r\n </div>\r\n <div class=\"col\">\r\n <div *ngIf=\"toast.title\"><h5>{{toast.title}}</h5></div>\r\n {{ toast.message }}\r\n </div>\r\n <div class=\"col-auto p-0\">\r\n <button type=\"button\" class=\"btn-close ms-auto me-2\" data-bs-dismiss=\"toast\" aria-label=\"Close\" (click)=\"remove(toast)\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n </div> -->\r\n</div>", styles: [":host>.toast-container{z-index:999999;opacity:.9}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
101
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ToastComponent, decorators: [{
102
- type: Component,
103
- args: [{ selector: 'zek-toast', template: "<div class=\"toast-container position-fixed top-0 end-0 p-3\">\r\n <div *ngFor=\"let toast of toasts\" class=\"toast fade show border-0 {{ toast.css }}\" role=\"alert\" aria-live=\"assertive\" aria-atomic=\"true\" data-bs-delay=\"3000\">\r\n <div class=\"toast-header\">\r\n <span class=\"me-1\" *ngIf=\"icon && toast.icon\"><i class=\"{{ toast.icon }}\"></i></span>\r\n <strong class=\"me-auto\" *ngIf=\"toast.title\">{{ toast.title }}</strong>\r\n <button type=\"button\" class=\"btn-close ms-auto me-2\" data-bs-dismiss=\"toast\" aria-label=\"Close\" (click)=\"remove(toast)\"></button>\r\n </div>\r\n <div class=\"toast-body\">\r\n {{ toast.message }}\r\n </div>\r\n </div>\r\n <!-- <div *ngFor=\"let toast of toasts\" class=\"toast fade show\" role=\"alert\" aria-live=\"assertive\" aria-atomic=\"true\" data-bs-delay=\"3000\">\r\n <div class=\"toast-body\">\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1 border-start border-8 {{toast.borderColor}}\">\r\n <span *ngIf=\"toast.icon\" class=\"icon flex-shrink-0 {{toast.iconColor}}\"><i class=\"{{toast.icon}}\"></i></span>\r\n </div>\r\n <div class=\"col\">\r\n <div *ngIf=\"toast.title\"><h5>{{toast.title}}</h5></div>\r\n {{ toast.message }}\r\n </div>\r\n <div class=\"col-auto p-0\">\r\n <button type=\"button\" class=\"btn-close ms-auto me-2\" data-bs-dismiss=\"toast\" aria-label=\"Close\" (click)=\"remove(toast)\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n </div> -->\r\n</div>", styles: [":host>.toast-container{z-index:999999;opacity:.9}\n"] }]
104
- }], ctorParameters: function () { return [{ type: i1.AlertService }]; }, propDecorators: { timeOut: [{
105
- type: Input
106
- }], icon: [{
107
- type: Input
108
- }] } });
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/alert/toast/toast.component.ts","../../../../../../../projects/zek/src/lib/modules/alert/toast/toast.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, Input } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { BootstrapHelper } from '../../../utils';\r\n//declare let bootstrap: any;\r\n\r\nimport { AlertService, Toast } from '../../../services/alert.service';\r\nimport { AlertType } from '../../../models';\r\n\r\n@Component({\r\n    selector: 'zek-toast',\r\n    styleUrls: ['./toast.component.css'],\r\n    templateUrl: './toast.component.html'\r\n})\r\nexport class ToastComponent implements OnInit, OnDestroy {\r\n    @Input() timeOut?: number;\r\n    @Input() icon = true;\r\n\r\n    toasts: any[] = [];\r\n    private subscription?: Subscription;\r\n    private timeout: any;\r\n\r\n    constructor(private readonly alertService: AlertService) { }\r\n\r\n    ngOnInit() {\r\n        this.subscription = this.alertService.getToast().subscribe((toast: Toast) => {\r\n            if (!toast) {\r\n                // clear alerts when an empty alert is received\r\n                this.toasts = [];\r\n                return;\r\n            }\r\n\r\n            // add toast to array\r\n            this.cssInit(toast);\r\n            this.toasts.unshift(toast);\r\n\r\n            this.timeout = setTimeout(() => {\r\n                this.remove(toast);\r\n                // let toastEl = document.getElementById(`toast-${toast.id}`);\r\n                // let t = new bootstrap.Toast(toastEl);\r\n                // t.show();\r\n            }, 3000);\r\n\r\n\r\n            // let toastElList = [].slice.call(document.querySelectorAll('.toast'))\r\n            // let toastList = toastElList.map(function (toastEl) {\r\n            //     return new bootstrap.Toast(toastEl)\r\n            // })\r\n            // toastList.forEach(t => {\r\n            //     t.show();\r\n            // });\r\n        });\r\n\r\n\r\n\r\n    }\r\n\r\n\r\n    ngOnDestroy() {\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n        this.clearTimeout();\r\n    }\r\n\r\n\r\n    clear() {\r\n        this.alertService.clear();\r\n    }\r\n    remove(toast: Toast) {\r\n        this.toasts = this.toasts.filter(x => x !== toast);\r\n    }\r\n\r\n    clearTimeout() {\r\n        if (this.timeout) {\r\n            clearTimeout(this.timeout);\r\n            this.timeout = null;\r\n        }\r\n    }\r\n\r\n\r\n    cssInit(toast: Toast) {\r\n        if (!toast || !toast.type)\r\n            return;\r\n\r\n\r\n        if (this.icon) {\r\n            toast.icon = BootstrapHelper.cssAlertIcon(toast.type);\r\n        }\r\n\r\n        var v = toast as any;\r\n        switch (toast.type) {\r\n            case AlertType.Primary:\r\n                v.css = 'bg-primary text-white';\r\n                break;\r\n            case AlertType.Success:\r\n                v.css = 'bg-success text-white';\r\n                // v.iconColor = 'text--accent-green';\r\n                // v.borderColor = 'border--accent-green';\r\n                break;\r\n            case AlertType.Danger:\r\n                v.css = 'bg-danger text-white';\r\n                // v.iconColor = 'text--accent-red';\r\n                // v.borderColor = 'border--accent-red';\r\n                break;\r\n            case AlertType.Warning:\r\n                v.css = 'bg-warning text-dark';\r\n                // v.iconColor = 'text--accent-yellow';\r\n                // v.borderColor = 'border--accent-yellow';\r\n                break;\r\n            case AlertType.Info:\r\n                v.css = 'bg-info text-white';\r\n                // v.iconColor = 'text--accent-blue';\r\n                // v.borderColor = 'border--accent-blue';\r\n                break;\r\n            case AlertType.Light:\r\n                v.css = 'bg-light text-dark';\r\n                break;\r\n            case AlertType.Dark:\r\n                v.css = 'bg-dark text-white';\r\n                break;\r\n\r\n\r\n            default:\r\n                v.css = 'bg-secondary text-white';\r\n                break;\r\n        }\r\n    }\r\n}\r\n\r\n","<div class=\"toast-container position-fixed top-0 end-0 p-3\">\r\n    <div *ngFor=\"let toast of toasts\" class=\"toast fade show border-0 {{ toast.css }}\" role=\"alert\" aria-live=\"assertive\" aria-atomic=\"true\" data-bs-delay=\"3000\">\r\n        <div class=\"toast-header\">\r\n            <span class=\"me-1\" *ngIf=\"icon && toast.icon\"><i class=\"{{ toast.icon }}\"></i></span>\r\n            <strong class=\"me-auto\" *ngIf=\"toast.title\">{{ toast.title }}</strong>\r\n            <button type=\"button\" class=\"btn-close ms-auto me-2\" data-bs-dismiss=\"toast\" aria-label=\"Close\" (click)=\"remove(toast)\"></button>\r\n        </div>\r\n        <div class=\"toast-body\">\r\n            {{ toast.message }}\r\n        </div>\r\n    </div>\r\n    <!-- <div *ngFor=\"let toast of toasts\" class=\"toast fade show\" role=\"alert\" aria-live=\"assertive\" aria-atomic=\"true\" data-bs-delay=\"3000\">\r\n        <div class=\"toast-body\">\r\n            <div class=\"row\">\r\n                <div class=\"col-auto pe-1 border-start border-8 {{toast.borderColor}}\">\r\n                    <span *ngIf=\"toast.icon\" class=\"icon flex-shrink-0 {{toast.iconColor}}\"><i class=\"{{toast.icon}}\"></i></span>\r\n                </div>\r\n                <div class=\"col\">\r\n                    <div *ngIf=\"toast.title\"><h5>{{toast.title}}</h5></div>\r\n                    {{ toast.message }}\r\n                </div>\r\n                <div class=\"col-auto p-0\">\r\n                    <button type=\"button\" class=\"btn-close ms-auto me-2\" data-bs-dismiss=\"toast\" aria-label=\"Close\" (click)=\"remove(toast)\"></button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div> -->\r\n</div>"]}
@@ -1,85 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import { AlertType } from '../../../models';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "../../../services/alert.service";
5
- import * as i2 from "@angular/common";
6
- export class ValidationComponent {
7
- constructor(alertService) {
8
- this.alertService = alertService;
9
- this.alerts = [];
10
- }
11
- ngOnInit() {
12
- this.subscription = this.alertService.getAlert().subscribe((alert) => {
13
- if (!alert) {
14
- // clear alerts when an empty alert is received
15
- this.alerts = [];
16
- return;
17
- }
18
- // add alert to array
19
- this.alerts.push(alert);
20
- });
21
- }
22
- ngOnDestroy() {
23
- this.subscription?.unsubscribe();
24
- }
25
- clear() {
26
- this.alertService.clear();
27
- }
28
- remove(alert) {
29
- this.alerts = this.alerts.filter(x => x !== alert);
30
- }
31
- cssIcon(alert) {
32
- if (!alert) {
33
- return;
34
- }
35
- if (alert.icon && alert.icon.length > 0)
36
- return alert.icon;
37
- if (!alert.type) {
38
- return;
39
- }
40
- switch (alert.type) {
41
- case AlertType.Success:
42
- return 'fas fa-check';
43
- case AlertType.Danger:
44
- case AlertType.Warning:
45
- return 'fas fa-exclamation-triangle';
46
- case AlertType.Info:
47
- return 'fas fa-info-circle';
48
- default:
49
- return;
50
- }
51
- }
52
- cssAlert(alert) {
53
- if (!alert) {
54
- return;
55
- }
56
- // return css class based on alert type
57
- switch (alert.type) {
58
- case AlertType.Primary:
59
- return 'alert-primary';
60
- case AlertType.Secondary:
61
- return 'alert-secondary';
62
- case AlertType.Success:
63
- return 'alert-success';
64
- case AlertType.Danger:
65
- return 'alert-danger';
66
- case AlertType.Warning:
67
- return 'alert-warning';
68
- case AlertType.Info:
69
- return 'alert-info';
70
- case AlertType.Light:
71
- return 'alert-light';
72
- case AlertType.Dark:
73
- return 'alert-dark';
74
- default:
75
- return 'alert-secondary';
76
- }
77
- }
78
- }
79
- ValidationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ValidationComponent, deps: [{ token: i1.AlertService }], target: i0.ɵɵFactoryTarget.Component });
80
- ValidationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ValidationComponent, selector: "zek-validation", ngImport: i0, template: "<div *ngFor=\"let alert of alerts\" class=\"alert {{ cssAlert(alert) }} alert-dismissible fade show mt-3\" role=\"alert\">\r\n <button (click)=\"remove(alert)\" type=\"button\" class=\"btn-close\" aria-label=\"Close\"></button>\r\n <div *ngFor=\"let message of alert.messages\">\r\n <i *ngIf=\"cssIcon(alert)\" class=\"{{ cssIcon(alert) }}\"></i>\r\n {{message}}\r\n </div>\r\n <ng-content></ng-content>\r\n</div>", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
81
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ValidationComponent, decorators: [{
82
- type: Component,
83
- args: [{ selector: 'zek-validation', template: "<div *ngFor=\"let alert of alerts\" class=\"alert {{ cssAlert(alert) }} alert-dismissible fade show mt-3\" role=\"alert\">\r\n <button (click)=\"remove(alert)\" type=\"button\" class=\"btn-close\" aria-label=\"Close\"></button>\r\n <div *ngFor=\"let message of alert.messages\">\r\n <i *ngIf=\"cssIcon(alert)\" class=\"{{ cssIcon(alert) }}\"></i>\r\n {{message}}\r\n </div>\r\n <ng-content></ng-content>\r\n</div>", styles: [":host{display:block}\n"] }]
84
- }], ctorParameters: function () { return [{ type: i1.AlertService }]; } });
85
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL2FsZXJ0L3ZhbGlkYXRpb24vdmFsaWRhdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL2FsZXJ0L3ZhbGlkYXRpb24vdmFsaWRhdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUU3RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7Ozs7QUFTNUMsTUFBTSxPQUFPLG1CQUFtQjtJQUk1QixZQUE2QixZQUEwQjtRQUExQixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUh2RCxXQUFNLEdBQVksRUFBRSxDQUFDO0lBR3NDLENBQUM7SUFFNUQsUUFBUTtRQUNKLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFZLEVBQUUsRUFBRTtZQUN4RSxJQUFJLENBQUMsS0FBSyxFQUFFO2dCQUNSLCtDQUErQztnQkFDL0MsSUFBSSxDQUFDLE1BQU0sR0FBRyxFQUFFLENBQUM7Z0JBQ2pCLE9BQU87YUFDVjtZQUNELHFCQUFxQjtZQUNyQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM1QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsQ0FBQztJQUNyQyxDQUFDO0lBR0QsS0FBSztRQUNELElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDOUIsQ0FBQztJQUNELE1BQU0sQ0FBQyxLQUFZO1FBQ2YsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQVk7UUFDaEIsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNSLE9BQU87U0FDVjtRQUVELElBQUksS0FBSyxDQUFDLElBQUksSUFBSSxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDO1lBQ25DLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQztRQUd0QixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRTtZQUNiLE9BQU87U0FDVjtRQUVELFFBQVEsS0FBSyxDQUFDLElBQUksRUFBRTtZQUNoQixLQUFLLFNBQVMsQ0FBQyxPQUFPO2dCQUNsQixPQUFPLGNBQWMsQ0FBQztZQUMxQixLQUFLLFNBQVMsQ0FBQyxNQUFNLENBQUM7WUFDdEIsS0FBSyxTQUFTLENBQUMsT0FBTztnQkFDbEIsT0FBTyw2QkFBNkIsQ0FBQztZQUN6QyxLQUFLLFNBQVMsQ0FBQyxJQUFJO2dCQUNmLE9BQU8sb0JBQW9CLENBQUM7WUFDaEM7Z0JBQ0ksT0FBTztTQUNkO0lBQ0wsQ0FBQztJQUVELFFBQVEsQ0FBQyxLQUFZO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDUixPQUFPO1NBQ1Y7UUFFRCx1Q0FBdUM7UUFDdkMsUUFBUSxLQUFLLENBQUMsSUFBSSxFQUFFO1lBQ2hCLEtBQUssU0FBUyxDQUFDLE9BQU87Z0JBQ2xCLE9BQU8sZUFBZSxDQUFDO1lBQzNCLEtBQUssU0FBUyxDQUFDLFNBQVM7Z0JBQ3BCLE9BQU8saUJBQWlCLENBQUM7WUFDN0IsS0FBSyxTQUFTLENBQUMsT0FBTztnQkFDbEIsT0FBTyxlQUFlLENBQUM7WUFDM0IsS0FBSyxTQUFTLENBQUMsTUFBTTtnQkFDakIsT0FBTyxjQUFjLENBQUM7WUFDMUIsS0FBSyxTQUFTLENBQUMsT0FBTztnQkFDbEIsT0FBTyxlQUFlLENBQUM7WUFDM0IsS0FBSyxTQUFTLENBQUMsSUFBSTtnQkFDZixPQUFPLFlBQVksQ0FBQztZQUN4QixLQUFLLFNBQVMsQ0FBQyxLQUFLO2dCQUNoQixPQUFPLGFBQWEsQ0FBQztZQUN6QixLQUFLLFNBQVMsQ0FBQyxJQUFJO2dCQUNmLE9BQU8sWUFBWSxDQUFDO1lBQ3hCO2dCQUNJLE9BQU8saUJBQWlCLENBQUM7U0FDaEM7SUFDTCxDQUFDOztnSEFsRlEsbUJBQW1CO29HQUFuQixtQkFBbUIsc0RDWGhDLHliQU9NOzJGRElPLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDSSxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBBbGVydFR5cGUgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMnO1xyXG5cclxuaW1wb3J0IHsgQWxlcnRTZXJ2aWNlLCBBbGVydCB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2FsZXJ0LnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ3play12YWxpZGF0aW9uJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi92YWxpZGF0aW9uLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlczogWyc6aG9zdCB7IGRpc3BsYXk6IGJsb2NrOyB9J11cclxufSlcclxuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XHJcbiAgICBhbGVydHM6IEFsZXJ0W10gPSBbXTtcclxuICAgIHByaXZhdGUgc3Vic2NyaXB0aW9uPzogU3Vic2NyaXB0aW9uO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgYWxlcnRTZXJ2aWNlOiBBbGVydFNlcnZpY2UpIHsgfVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5hbGVydFNlcnZpY2UuZ2V0QWxlcnQoKS5zdWJzY3JpYmUoKGFsZXJ0OiBBbGVydCkgPT4ge1xyXG4gICAgICAgICAgICBpZiAoIWFsZXJ0KSB7XHJcbiAgICAgICAgICAgICAgICAvLyBjbGVhciBhbGVydHMgd2hlbiBhbiBlbXB0eSBhbGVydCBpcyByZWNlaXZlZFxyXG4gICAgICAgICAgICAgICAgdGhpcy5hbGVydHMgPSBbXTtcclxuICAgICAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAvLyBhZGQgYWxlcnQgdG8gYXJyYXlcclxuICAgICAgICAgICAgdGhpcy5hbGVydHMucHVzaChhbGVydCk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICAgICAgdGhpcy5zdWJzY3JpcHRpb24/LnVuc3Vic2NyaWJlKCk7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIGNsZWFyKCkge1xyXG4gICAgICAgIHRoaXMuYWxlcnRTZXJ2aWNlLmNsZWFyKCk7XHJcbiAgICB9XHJcbiAgICByZW1vdmUoYWxlcnQ6IEFsZXJ0KSB7XHJcbiAgICAgICAgdGhpcy5hbGVydHMgPSB0aGlzLmFsZXJ0cy5maWx0ZXIoeCA9PiB4ICE9PSBhbGVydCk7XHJcbiAgICB9XHJcblxyXG4gICAgY3NzSWNvbihhbGVydDogQWxlcnQpIHtcclxuICAgICAgICBpZiAoIWFsZXJ0KSB7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmIChhbGVydC5pY29uICYmIGFsZXJ0Lmljb24ubGVuZ3RoID4gMClcclxuICAgICAgICAgICAgcmV0dXJuIGFsZXJ0Lmljb247XHJcblxyXG5cclxuICAgICAgICBpZiAoIWFsZXJ0LnR5cGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgc3dpdGNoIChhbGVydC50eXBlKSB7XHJcbiAgICAgICAgICAgIGNhc2UgQWxlcnRUeXBlLlN1Y2Nlc3M6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gJ2ZhcyBmYS1jaGVjayc7XHJcbiAgICAgICAgICAgIGNhc2UgQWxlcnRUeXBlLkRhbmdlcjpcclxuICAgICAgICAgICAgY2FzZSBBbGVydFR5cGUuV2FybmluZzpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnZmFzIGZhLWV4Y2xhbWF0aW9uLXRyaWFuZ2xlJztcclxuICAgICAgICAgICAgY2FzZSBBbGVydFR5cGUuSW5mbzpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnZmFzIGZhLWluZm8tY2lyY2xlJztcclxuICAgICAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgY3NzQWxlcnQoYWxlcnQ6IEFsZXJ0KSB7XHJcbiAgICAgICAgaWYgKCFhbGVydCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICAvLyByZXR1cm4gY3NzIGNsYXNzIGJhc2VkIG9uIGFsZXJ0IHR5cGVcclxuICAgICAgICBzd2l0Y2ggKGFsZXJ0LnR5cGUpIHtcclxuICAgICAgICAgICAgY2FzZSBBbGVydFR5cGUuUHJpbWFyeTpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtcHJpbWFyeSc7XHJcbiAgICAgICAgICAgIGNhc2UgQWxlcnRUeXBlLlNlY29uZGFyeTpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtc2Vjb25kYXJ5JztcclxuICAgICAgICAgICAgY2FzZSBBbGVydFR5cGUuU3VjY2VzczpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtc3VjY2Vzcyc7XHJcbiAgICAgICAgICAgIGNhc2UgQWxlcnRUeXBlLkRhbmdlcjpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtZGFuZ2VyJztcclxuICAgICAgICAgICAgY2FzZSBBbGVydFR5cGUuV2FybmluZzpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtd2FybmluZyc7XHJcbiAgICAgICAgICAgIGNhc2UgQWxlcnRUeXBlLkluZm86XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gJ2FsZXJ0LWluZm8nO1xyXG4gICAgICAgICAgICBjYXNlIEFsZXJ0VHlwZS5MaWdodDpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtbGlnaHQnO1xyXG4gICAgICAgICAgICBjYXNlIEFsZXJ0VHlwZS5EYXJrOlxyXG4gICAgICAgICAgICAgICAgcmV0dXJuICdhbGVydC1kYXJrJztcclxuICAgICAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtc2Vjb25kYXJ5JztcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIiwiPGRpdiAqbmdGb3I9XCJsZXQgYWxlcnQgb2YgYWxlcnRzXCIgY2xhc3M9XCJhbGVydCB7eyBjc3NBbGVydChhbGVydCkgfX0gYWxlcnQtZGlzbWlzc2libGUgZmFkZSBzaG93IG10LTNcIiByb2xlPVwiYWxlcnRcIj5cclxuICAgIDxidXR0b24gKGNsaWNrKT1cInJlbW92ZShhbGVydClcIiB0eXBlPVwiYnV0dG9uXCIgY2xhc3M9XCJidG4tY2xvc2VcIiBhcmlhLWxhYmVsPVwiQ2xvc2VcIj48L2J1dHRvbj5cclxuICAgIDxkaXYgKm5nRm9yPVwibGV0IG1lc3NhZ2Ugb2YgYWxlcnQubWVzc2FnZXNcIj5cclxuICAgICAgICA8aSAqbmdJZj1cImNzc0ljb24oYWxlcnQpXCIgY2xhc3M9XCJ7eyBjc3NJY29uKGFsZXJ0KSB9fVwiPjwvaT5cclxuICAgICAgICB7e21lc3NhZ2V9fVxyXG4gICAgPC9kaXY+XHJcbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbjwvZGl2PiJdfQ==