zek 14.2.75 → 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.
- package/esm2020/lib/components/base.component.mjs +6 -3
- package/esm2020/lib/components/edit-base.component.mjs +27 -36
- package/esm2020/lib/components/list-base.component.mjs +27 -22
- package/esm2020/lib/modules/alert/alert/alert.mjs +52 -0
- package/esm2020/lib/modules/alert/alert.module.mjs +15 -15
- package/esm2020/lib/modules/alert/index.mjs +4 -4
- package/esm2020/lib/modules/alert/toast/toast.mjs +109 -0
- package/esm2020/lib/modules/alert/validation/validation.mjs +85 -0
- package/esm2020/lib/modules/list-toolbar/list-toolbar.component.mjs +3 -2
- package/esm2020/lib/services/http-error-handler.service.mjs +4 -1
- package/fesm2015/zek.mjs +94 -84
- package/fesm2015/zek.mjs.map +1 -1
- package/fesm2020/zek.mjs +94 -84
- package/fesm2020/zek.mjs.map +1 -1
- package/lib/components/base.component.d.ts +1 -0
- package/lib/components/edit-base.component.d.ts +4 -4
- package/lib/components/list-base.component.d.ts +3 -3
- package/lib/modules/alert/alert/alert.d.ts +16 -0
- package/lib/modules/alert/alert.module.d.ts +4 -4
- package/lib/modules/alert/index.d.ts +3 -3
- package/lib/modules/alert/toast/{toast.component.d.ts → toast.d.ts} +3 -3
- package/lib/modules/alert/validation/{validation.component.d.ts → validation.d.ts} +3 -3
- package/package.json +1 -1
- package/esm2020/lib/modules/alert/alert/alert.component.mjs +0 -44
- package/esm2020/lib/modules/alert/toast/toast.component.mjs +0 -109
- package/esm2020/lib/modules/alert/validation/validation.component.mjs +0 -85
- package/lib/modules/alert/alert/alert.component.d.ts +0 -12
|
@@ -14,6 +14,7 @@ export declare class BaseComponent<TModel = any> extends CoreComponent {
|
|
|
14
14
|
protected get url(): string;
|
|
15
15
|
model?: TModel | null;
|
|
16
16
|
protected getParam(name: string): string | null;
|
|
17
|
+
protected getQueryParam(name: string): string | null;
|
|
17
18
|
protected navigateReturnUrl(): void;
|
|
18
19
|
cancel(): void;
|
|
19
20
|
downloadFile(blob: Blob | null, fileName: string, type: string): void;
|
|
@@ -35,9 +35,9 @@ export declare class EditFormComponent<TModel = any> extends BaseComponent<TMode
|
|
|
35
35
|
}
|
|
36
36
|
export declare class EditBaseComponent<TModel = any> extends EditFormComponent<TModel> {
|
|
37
37
|
readonly service: IService;
|
|
38
|
-
readonly
|
|
39
|
-
readonly
|
|
40
|
-
constructor(service: IService,
|
|
38
|
+
readonly translate: TranslateService;
|
|
39
|
+
readonly alert: AlertService;
|
|
40
|
+
constructor(service: IService, translate: TranslateService, alert: AlertService, route: ActivatedRoute, router: Router);
|
|
41
41
|
protected internalSave(navigateToReturnUrl?: boolean | null): Promise<boolean>;
|
|
42
42
|
protected internalApprove(model?: any): Promise<boolean>;
|
|
43
43
|
protected internalDisapprove(model?: any): Promise<boolean>;
|
|
@@ -52,7 +52,7 @@ export declare class EditBaseComponent<TModel = any> extends EditFormComponent<T
|
|
|
52
52
|
}
|
|
53
53
|
export declare class EditComponent<TModel> extends EditBaseComponent<TModel> {
|
|
54
54
|
private readonly ctorModel;
|
|
55
|
-
constructor(ctorModel: IObjectConstructor<TModel>, service: IService,
|
|
55
|
+
constructor(ctorModel: IObjectConstructor<TModel>, service: IService, translate: TranslateService, alert: AlertService, route: ActivatedRoute, router: Router);
|
|
56
56
|
protected initCreate(): void;
|
|
57
57
|
static ɵfac: i0.ɵɵFactoryDeclaration<EditComponent<any>, never>;
|
|
58
58
|
static ɵdir: i0.ɵɵDirectiveDeclaration<EditComponent<any>, never, never, {}, {}, never, never, false>;
|
|
@@ -8,8 +8,8 @@ import { AlertService } from '../services/alert.service';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export declare class ListBaseComponent<TService extends IService = IService> extends BaseComponent<PagedList> {
|
|
10
10
|
protected readonly service: TService;
|
|
11
|
-
readonly
|
|
12
|
-
readonly
|
|
11
|
+
readonly translate: TranslateService;
|
|
12
|
+
readonly alert: AlertService;
|
|
13
13
|
filter: any;
|
|
14
14
|
saveFilter: boolean;
|
|
15
15
|
sortFields: any;
|
|
@@ -25,7 +25,7 @@ export declare class ListBaseComponent<TService extends IService = IService> ext
|
|
|
25
25
|
};
|
|
26
26
|
protected readonly approveModal?: ModalComponent | null;
|
|
27
27
|
protected readonly disapproveModal?: ModalComponent | null;
|
|
28
|
-
constructor(service: TService,
|
|
28
|
+
constructor(service: TService, translate: TranslateService, alert: AlertService, route: ActivatedRoute, router: Router);
|
|
29
29
|
init(): void;
|
|
30
30
|
bindModel(): Promise<void>;
|
|
31
31
|
protected initDefaultFilter(): void;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BooleanInput } from '../../../components';
|
|
2
|
+
import { AlertType } from '../../../models';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class ZekAlert {
|
|
5
|
+
private _type;
|
|
6
|
+
get type(): AlertType | string | null | undefined;
|
|
7
|
+
set type(v: AlertType | string | null | undefined);
|
|
8
|
+
_showClose: boolean;
|
|
9
|
+
get showClose(): boolean;
|
|
10
|
+
set showClose(v: BooleanInput);
|
|
11
|
+
title?: string | null;
|
|
12
|
+
cssAlert: string;
|
|
13
|
+
cssIcon: string;
|
|
14
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ZekAlert, never>;
|
|
15
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ZekAlert, "zek-alert", never, { "type": "type"; "title": "title"; }, {}, never, ["*"], false>;
|
|
16
|
+
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
|
-
import * as i1 from "./alert/alert
|
|
3
|
-
import * as i2 from "./validation/validation
|
|
4
|
-
import * as i3 from "./toast/toast
|
|
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.
|
|
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
|
|
2
|
-
export * from './toast/toast
|
|
3
|
-
export * from './validation/validation
|
|
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
|
|
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<
|
|
19
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<
|
|
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
|
|
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<
|
|
16
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<
|
|
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,44 +0,0 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { AlertType } from '../../../models';
|
|
3
|
-
import { BootstrapHelper } from '../../../utils/bootstrap.helper';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/common";
|
|
6
|
-
export class AlertComponent {
|
|
7
|
-
constructor() {
|
|
8
|
-
this._type = AlertType.Info;
|
|
9
|
-
this.cssAlert = '';
|
|
10
|
-
this.cssIcon = '';
|
|
11
|
-
}
|
|
12
|
-
get type() {
|
|
13
|
-
return this._type;
|
|
14
|
-
}
|
|
15
|
-
set type(v) {
|
|
16
|
-
if (v !== this._type) {
|
|
17
|
-
this._type = v;
|
|
18
|
-
this.cssAlert = '';
|
|
19
|
-
this.cssIcon = '';
|
|
20
|
-
if (typeof v === 'string') {
|
|
21
|
-
let enumValue = BootstrapHelper.getAlertType(v);
|
|
22
|
-
if (enumValue) {
|
|
23
|
-
this.cssAlert = BootstrapHelper.cssAlert(enumValue);
|
|
24
|
-
this.cssIcon = BootstrapHelper.cssAlertIcon(enumValue);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
else {
|
|
28
|
-
this.cssAlert = BootstrapHelper.cssAlert(v);
|
|
29
|
-
this.cssIcon = BootstrapHelper.cssAlertIcon(v);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
AlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
35
|
-
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 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"] }] });
|
|
36
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, decorators: [{
|
|
37
|
-
type: Component,
|
|
38
|
-
args: [{ selector: 'zek-alert', template: "<div class=\"alert {{cssAlert}} alert-dismissible fade show\" role=\"alert\">\r\n <button 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"] }]
|
|
39
|
-
}], propDecorators: { type: [{
|
|
40
|
-
type: Input
|
|
41
|
-
}], title: [{
|
|
42
|
-
type: Input
|
|
43
|
-
}] } });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9hbGVydC9hbGVydC9hbGVydC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL2FsZXJ0L2FsZXJ0L2FsZXJ0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7OztBQU9sRSxNQUFNLE9BQU8sY0FBYztJQUwzQjtRQU1ZLFVBQUssR0FBMEMsU0FBUyxDQUFDLElBQUksQ0FBQztRQTJCdEUsYUFBUSxHQUFHLEVBQUUsQ0FBQztRQUNkLFlBQU8sR0FBRyxFQUFFLENBQUM7S0FVaEI7SUFyQ0csSUFDSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFDRCxJQUFJLElBQUksQ0FBQyxDQUF3QztRQUM3QyxJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2xCLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFBO1lBRWQsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7WUFDbEIsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLEVBQUU7Z0JBQ3ZCLElBQUksU0FBUyxHQUFHLGVBQWUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2hELElBQUksU0FBUyxFQUFFO29CQUNYLElBQUksQ0FBQyxRQUFRLEdBQUcsZUFBZSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztvQkFDcEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxlQUFlLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2lCQUMxRDthQUNKO2lCQUFNO2dCQUNILElBQUksQ0FBQyxRQUFRLEdBQUcsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDNUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ2xEO1NBQ0o7SUFDTCxDQUFDOzsyR0F2QlEsY0FBYzsrRkFBZCxjQUFjLDJGQ1QzQixxbUJBYU07MkZESk8sY0FBYztrQkFMMUIsU0FBUzsrQkFDSSxXQUFXOzhCQU9qQixJQUFJO3NCQURQLEtBQUs7Z0JBdUJHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWxlcnRUeXBlIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzJztcclxuaW1wb3J0IHsgQm9vdHN0cmFwSGVscGVyIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvYm9vdHN0cmFwLmhlbHBlcic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnemVrLWFsZXJ0JyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9hbGVydC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZXM6IFsnOmhvc3QgeyBkaXNwbGF5OiBibG9jazsgfSddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBbGVydENvbXBvbmVudCB7XHJcbiAgICBwcml2YXRlIF90eXBlOiBBbGVydFR5cGUgfCBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkID0gQWxlcnRUeXBlLkluZm87XHJcbiAgICBASW5wdXQoKVxyXG4gICAgZ2V0IHR5cGUoKTogQWxlcnRUeXBlIHwgc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZCB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3R5cGU7XHJcbiAgICB9XHJcbiAgICBzZXQgdHlwZSh2OiBBbGVydFR5cGUgfCBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkKSB7XHJcbiAgICAgICAgaWYgKHYgIT09IHRoaXMuX3R5cGUpIHtcclxuICAgICAgICAgICAgdGhpcy5fdHlwZSA9IHZcclxuXHJcbiAgICAgICAgICAgIHRoaXMuY3NzQWxlcnQgPSAnJztcclxuICAgICAgICAgICAgdGhpcy5jc3NJY29uID0gJyc7XHJcbiAgICAgICAgICAgIGlmICh0eXBlb2YgdiA9PT0gJ3N0cmluZycpIHtcclxuICAgICAgICAgICAgICAgIGxldCBlbnVtVmFsdWUgPSBCb290c3RyYXBIZWxwZXIuZ2V0QWxlcnRUeXBlKHYpO1xyXG4gICAgICAgICAgICAgICAgaWYgKGVudW1WYWx1ZSkge1xyXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuY3NzQWxlcnQgPSBCb290c3RyYXBIZWxwZXIuY3NzQWxlcnQoZW51bVZhbHVlKTtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNzc0ljb24gPSBCb290c3RyYXBIZWxwZXIuY3NzQWxlcnRJY29uKGVudW1WYWx1ZSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmNzc0FsZXJ0ID0gQm9vdHN0cmFwSGVscGVyLmNzc0FsZXJ0KHYpO1xyXG4gICAgICAgICAgICAgICAgdGhpcy5jc3NJY29uID0gQm9vdHN0cmFwSGVscGVyLmNzc0FsZXJ0SWNvbih2KTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBASW5wdXQoKSB0aXRsZT86IHN0cmluZyB8IG51bGw7XHJcblxyXG5cclxuICAgIGNzc0FsZXJ0ID0gJyc7XHJcbiAgICBjc3NJY29uID0gJyc7XHJcblxyXG5cclxuICAgIC8vIGNzc0ljb24oKSB7XHJcbiAgICAvLyAgICAgcmV0dXJuIEJvb3RzdHJhcEhlbHBlci5jc3NBbGVydEljb24odGhpcy5fdHlwZSk7XHJcbiAgICAvLyB9XHJcblxyXG4gICAgLy8gY3NzQWxlcnQoKSB7XHJcbiAgICAvLyAgICAgcmV0dXJuIEJvb3RzdHJhcEhlbHBlci5jc3NBbGVydCh0aGlzLl90eXBlKTtcclxuICAgIC8vIH1cclxufVxyXG5cclxuIiwiPGRpdiBjbGFzcz1cImFsZXJ0IHt7Y3NzQWxlcnR9fSBhbGVydC1kaXNtaXNzaWJsZSBmYWRlIHNob3dcIiByb2xlPVwiYWxlcnRcIj5cclxuICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiIGNsYXNzPVwiYnRuLWNsb3NlXCIgZGF0YS1icy1kaXNtaXNzPVwiYWxlcnRcIiBhcmlhLWxhYmVsPVwiQ2xvc2VcIj48L2J1dHRvbj5cclxuICAgIDxkaXYgY2xhc3M9XCJyb3dcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLWF1dG8gcGUtMVwiICpuZ0lmPVwiY3NzSWNvblwiPlxyXG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cImZsZXgtc2hyaW5rLTBcIj48aSBjbGFzcz1cInt7Y3NzSWNvbn19XCI+PC9pPjwvc3Bhbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLWF1dG9cIj5cclxuICAgICAgICAgICAgPGRpdiAqbmdJZj1cInRpdGxlXCI+XHJcbiAgICAgICAgICAgICAgICA8aDUgY2xhc3M9XCJhbGVydC1oZWFkaW5nXCI+e3t0aXRsZX19PC9oNT5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj4iXX0=
|
|
@@ -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":"AAAA,OAAO,EAAE,SAAS,EAAqB,KAAK,EAAE,MAAM,eAAe,CAAC;AAEpE,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAIjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;;;;AAO5C,MAAM,OAAO,cAAc;IAQvB,YAA6B,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;QAN9C,SAAI,GAAG,IAAI,CAAC;QAErB,WAAM,GAAU,EAAE,CAAC;IAIwC,CAAC;IAE5D,QAAQ;QACJ,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC,CAAC,KAAY,EAAE,EAAE;YACxE,IAAI,CAAC,KAAK,EAAE;gBACR,+CAA+C;gBAC/C,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;gBACjB,OAAO;aACV;YAED,qBAAqB;YACrB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACpB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAE3B,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC3B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACnB,8DAA8D;gBAC9D,wCAAwC;gBACxC,YAAY;YAChB,CAAC,EAAE,IAAI,CAAC,CAAC;YAGT,uEAAuE;YACvE,uDAAuD;YACvD,0CAA0C;YAC1C,KAAK;YACL,2BAA2B;YAC3B,gBAAgB;YAChB,MAAM;QACV,CAAC,CAAC,CAAC;IAIP,CAAC;IAGD,WAAW;QACP,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;SACnC;QACD,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAGD,KAAK;QACD,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;IACD,MAAM,CAAC,KAAY;QACf,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC;IACvD,CAAC;IAED,YAAY;QACR,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACvB;IACL,CAAC;IAGD,OAAO,CAAC,KAAY;QAChB,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,IAAI;YACrB,OAAO;QAGX,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,KAAK,CAAC,IAAI,GAAG,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;SACzD;QAED,IAAI,CAAC,GAAG,KAAY,CAAC;QACrB,QAAQ,KAAK,CAAC,IAAI,EAAE;YAChB,KAAK,SAAS,CAAC,OAAO;gBAClB,CAAC,CAAC,GAAG,GAAG,uBAAuB,CAAC;gBAChC,MAAM;YACV,KAAK,SAAS,CAAC,OAAO;gBAClB,CAAC,CAAC,GAAG,GAAG,uBAAuB,CAAC;gBAChC,sCAAsC;gBACtC,0CAA0C;gBAC1C,MAAM;YACV,KAAK,SAAS,CAAC,MAAM;gBACjB,CAAC,CAAC,GAAG,GAAG,sBAAsB,CAAC;gBAC/B,oCAAoC;gBACpC,wCAAwC;gBACxC,MAAM;YACV,KAAK,SAAS,CAAC,OAAO;gBAClB,CAAC,CAAC,GAAG,GAAG,sBAAsB,CAAC;gBAC/B,uCAAuC;gBACvC,2CAA2C;gBAC3C,MAAM;YACV,KAAK,SAAS,CAAC,IAAI;gBACf,CAAC,CAAC,GAAG,GAAG,oBAAoB,CAAC;gBAC7B,qCAAqC;gBACrC,yCAAyC;gBACzC,MAAM;YACV,KAAK,SAAS,CAAC,KAAK;gBAChB,CAAC,CAAC,GAAG,GAAG,oBAAoB,CAAC;gBAC7B,MAAM;YACV,KAAK,SAAS,CAAC,IAAI;gBACf,CAAC,CAAC,GAAG,GAAG,oBAAoB,CAAC;gBAC7B,MAAM;YAGV;gBACI,CAAC,CAAC,GAAG,GAAG,yBAAyB,CAAC;gBAClC,MAAM;SACb;IACL,CAAC;;2GAjHQ,cAAc;+FAAd,cAAc,+FCb3B,4sDA2BM;2FDdO,cAAc;kBAL1B,SAAS;+BACI,WAAW;mGAKZ,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK","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==
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { AlertType } from '../../../models';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export declare class AlertComponent {
|
|
4
|
-
private _type;
|
|
5
|
-
get type(): AlertType | string | null | undefined;
|
|
6
|
-
set type(v: AlertType | string | null | undefined);
|
|
7
|
-
title?: string | null;
|
|
8
|
-
cssAlert: string;
|
|
9
|
-
cssIcon: string;
|
|
10
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<AlertComponent, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AlertComponent, "zek-alert", never, { "type": "type"; "title": "title"; }, {}, never, ["*"], false>;
|
|
12
|
-
}
|