zek 16.0.7 → 16.0.9
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/esm2022/lib/models/alert-type.mjs +2 -12
- package/esm2022/lib/modules/alert/alert/alert.mjs +4 -16
- package/esm2022/lib/modules/alert/toast/toast.mjs +9 -10
- package/esm2022/lib/modules/alert/validation/validation.mjs +4 -34
- package/esm2022/lib/services/alert.service.mjs +7 -8
- package/esm2022/lib/services/http-error-handler.service.mjs +2 -3
- package/esm2022/lib/utils/bootstrap.helper.mjs +23 -26
- package/fesm2022/zek.mjs +209 -263
- package/fesm2022/zek.mjs.map +1 -1
- package/lib/models/alert-type.d.ts +1 -10
- package/lib/modules/alert/alert/alert.d.ts +2 -2
- package/lib/modules/alert/validation/validation.d.ts +1 -1
- package/lib/utils/bootstrap.helper.d.ts +0 -1
- package/package.json +1 -1
|
@@ -1,12 +1,2 @@
|
|
|
1
|
-
export
|
|
2
|
-
|
|
3
|
-
AlertType[AlertType["Primary"] = 1] = "Primary";
|
|
4
|
-
AlertType[AlertType["Secondary"] = 2] = "Secondary";
|
|
5
|
-
AlertType[AlertType["Success"] = 3] = "Success";
|
|
6
|
-
AlertType[AlertType["Danger"] = 4] = "Danger";
|
|
7
|
-
AlertType[AlertType["Warning"] = 5] = "Warning";
|
|
8
|
-
AlertType[AlertType["Info"] = 6] = "Info";
|
|
9
|
-
AlertType[AlertType["Light"] = 7] = "Light";
|
|
10
|
-
AlertType[AlertType["Dark"] = 8] = "Dark";
|
|
11
|
-
})(AlertType || (AlertType = {}));
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQtdHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL21vZGVscy9hbGVydC10eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLFNBU1g7QUFURCxXQUFZLFNBQVM7SUFDakIsK0NBQVcsQ0FBQTtJQUNYLG1EQUFTLENBQUE7SUFDVCwrQ0FBTyxDQUFBO0lBQ1AsNkNBQU0sQ0FBQTtJQUNOLCtDQUFPLENBQUE7SUFDUCx5Q0FBSSxDQUFBO0lBQ0osMkNBQUssQ0FBQTtJQUNMLHlDQUFJLENBQUE7QUFDUixDQUFDLEVBVFcsU0FBUyxLQUFULFNBQVMsUUFTcEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBBbGVydFR5cGUge1xyXG4gICAgUHJpbWFyeSA9IDEsXHJcbiAgICBTZWNvbmRhcnksXHJcbiAgICBTdWNjZXNzLFxyXG4gICAgRGFuZ2VyLFxyXG4gICAgV2FybmluZyxcclxuICAgIEluZm8sXHJcbiAgICBMaWdodCxcclxuICAgIERhcmtcclxufSJdfQ==
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQtdHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL21vZGVscy9hbGVydC10eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBBbGVydFR5cGUgPSAncHJpbWFyeScgfCAnc2Vjb25kYXJ5JyB8ICdzdWNjZXNzJyB8ICdkYW5nZXInIHwgJ3dhcm5pbmcnIHwgJ2luZm8nIHwgJ2xpZ2h0JyB8ICdkYXJrJztcclxuIl19
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { AlertType } from '../../../models';
|
|
3
2
|
import { Convert } from '../../../utils';
|
|
4
3
|
import { BootstrapHelper } from '../../../utils/bootstrap.helper';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "@angular/common";
|
|
7
6
|
class ZekAlert {
|
|
8
7
|
constructor() {
|
|
9
|
-
this._type =
|
|
8
|
+
this._type = 'info';
|
|
10
9
|
this._showClose = true;
|
|
11
10
|
this.cssAlert = '';
|
|
12
11
|
this.cssIcon = '';
|
|
@@ -17,19 +16,8 @@ class ZekAlert {
|
|
|
17
16
|
set type(v) {
|
|
18
17
|
if (v !== this._type) {
|
|
19
18
|
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
|
-
}
|
|
19
|
+
this.cssAlert = BootstrapHelper.cssAlert(v);
|
|
20
|
+
this.cssIcon = BootstrapHelper.cssAlertIcon(v);
|
|
33
21
|
}
|
|
34
22
|
}
|
|
35
23
|
get showClose() {
|
|
@@ -52,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
52
40
|
}], title: [{
|
|
53
41
|
type: Input
|
|
54
42
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL2FsZXJ0L2FsZXJ0L2FsZXJ0LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9hbGVydC9hbGVydC9hbGVydC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR2pELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7OztBQUVsRSxNQUthLFFBQVE7SUFMckI7UUFNWSxVQUFLLEdBQWlDLE1BQU0sQ0FBQztRQWFyRCxlQUFVLEdBQVksSUFBSSxDQUFDO1FBWTNCLGFBQVEsR0FBRyxFQUFFLENBQUM7UUFDZCxZQUFPLEdBQUcsRUFBRSxDQUFDO0tBQ2hCO0lBMUJHLElBQ0ksSUFBSTtRQUNKLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0lBQ0QsSUFBSSxJQUFJLENBQUMsQ0FBK0I7UUFDcEMsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNsQixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQTtZQUNkLElBQUksQ0FBQyxRQUFRLEdBQUcsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1QyxJQUFJLENBQUMsT0FBTyxHQUFHLGVBQWUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDbEQ7SUFDTCxDQUFDO0lBR0QsSUFDSSxTQUFTO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQzNCLENBQUM7SUFDRCxJQUFJLFNBQVMsQ0FBQyxDQUFlO1FBQ3pCLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7OEdBckJRLFFBQVE7a0dBQVIsUUFBUSxtSENYckIsMG5CQWFNOztTREZPLFFBQVE7MkZBQVIsUUFBUTtrQkFMcEIsU0FBUzsrQkFDSSxXQUFXOzhCQU9qQixJQUFJO3NCQURQLEtBQUs7Z0JBY0YsU0FBUztzQkFEWixLQUFLO2dCQVFHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IEFsZXJ0VHlwZSB9IGZyb20gJy4uLy4uLy4uL21vZGVscyc7XHJcbmltcG9ydCB7IENvbnZlcnQgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IEJvb3RzdHJhcEhlbHBlciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL2Jvb3RzdHJhcC5oZWxwZXInO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ3play1hbGVydCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYWxlcnQuaHRtbCcsXHJcbiAgICBzdHlsZXM6IFsnOmhvc3QgeyBkaXNwbGF5OiBibG9jazsgfSddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBaZWtBbGVydCB7XHJcbiAgICBwcml2YXRlIF90eXBlOiBBbGVydFR5cGUgfCBudWxsIHwgdW5kZWZpbmVkID0gJ2luZm8nO1xyXG4gICAgQElucHV0KClcclxuICAgIGdldCB0eXBlKCk6IEFsZXJ0VHlwZSB8IG51bGwgfCB1bmRlZmluZWQge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl90eXBlO1xyXG4gICAgfVxyXG4gICAgc2V0IHR5cGUodjogQWxlcnRUeXBlIHwgbnVsbCB8IHVuZGVmaW5lZCkge1xyXG4gICAgICAgIGlmICh2ICE9PSB0aGlzLl90eXBlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX3R5cGUgPSB2XHJcbiAgICAgICAgICAgIHRoaXMuY3NzQWxlcnQgPSBCb290c3RyYXBIZWxwZXIuY3NzQWxlcnQodik7XHJcbiAgICAgICAgICAgIHRoaXMuY3NzSWNvbiA9IEJvb3RzdHJhcEhlbHBlci5jc3NBbGVydEljb24odik7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIF9zaG93Q2xvc2U6IGJvb2xlYW4gPSB0cnVlO1xyXG4gICAgQElucHV0KClcclxuICAgIGdldCBzaG93Q2xvc2UoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3Nob3dDbG9zZTtcclxuICAgIH1cclxuICAgIHNldCBzaG93Q2xvc2UodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5fc2hvd0Nsb3NlID0gQ29udmVydC50b0Jvb2xlYW5Qcm9wZXJ0eSh2KTtcclxuICAgIH1cclxuXHJcbiAgICBASW5wdXQoKSB0aXRsZT86IHN0cmluZyB8IG51bGw7XHJcblxyXG5cclxuICAgIGNzc0FsZXJ0ID0gJyc7XHJcbiAgICBjc3NJY29uID0gJyc7XHJcbn1cclxuXHJcbiIsIjxkaXYgY2xhc3M9XCJhbGVydCB7e2Nzc0FsZXJ0fX0gYWxlcnQtZGlzbWlzc2libGUgZmFkZSBzaG93XCIgcm9sZT1cImFsZXJ0XCI+XHJcbiAgICA8YnV0dG9uICpuZ0lmPVwiX3Nob3dDbG9zZVwiIHR5cGU9XCJidXR0b25cIiBjbGFzcz1cImJ0bi1jbG9zZVwiIGRhdGEtYnMtZGlzbWlzcz1cImFsZXJ0XCIgYXJpYS1sYWJlbD1cIkNsb3NlXCI+PC9idXR0b24+XHJcbiAgICA8ZGl2IGNsYXNzPVwicm93XCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1hdXRvIHBlLTFcIiAqbmdJZj1cImNzc0ljb25cIj5cclxuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJmbGV4LXNocmluay0wXCI+PGkgY2xhc3M9XCJ7e2Nzc0ljb259fVwiPjwvaT48L3NwYW4+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1hdXRvXCI+XHJcbiAgICAgICAgICAgIDxkaXYgKm5nSWY9XCJ0aXRsZVwiPlxyXG4gICAgICAgICAgICAgICAgPGg1IGNsYXNzPVwiYWxlcnQtaGVhZGluZ1wiPnt7dGl0bGV9fTwvaDU+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuPC9kaXY+Il19
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import { BootstrapHelper, Convert } from '../../../utils';
|
|
3
|
-
import { AlertType } from '../../../models';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
import * as i1 from "../../../services/alert.service";
|
|
6
5
|
import * as i2 from "@angular/common";
|
|
@@ -69,38 +68,38 @@ class ZekToast {
|
|
|
69
68
|
cssInit(toast) {
|
|
70
69
|
if (!toast || !toast.type)
|
|
71
70
|
return;
|
|
72
|
-
if (this.icon) {
|
|
71
|
+
if (this.icon && !toast.icon) {
|
|
73
72
|
toast.icon = BootstrapHelper.cssAlertIcon(toast.type);
|
|
74
73
|
}
|
|
75
74
|
var v = toast;
|
|
76
75
|
switch (toast.type) {
|
|
77
|
-
case
|
|
76
|
+
case 'primary':
|
|
78
77
|
v.css = 'bg-primary text-white';
|
|
79
78
|
break;
|
|
80
|
-
case
|
|
79
|
+
case 'success':
|
|
81
80
|
v.css = 'bg-success text-white';
|
|
82
81
|
// v.iconColor = 'text--accent-green';
|
|
83
82
|
// v.borderColor = 'border--accent-green';
|
|
84
83
|
break;
|
|
85
|
-
case
|
|
84
|
+
case 'danger':
|
|
86
85
|
v.css = 'bg-danger text-white';
|
|
87
86
|
// v.iconColor = 'text--accent-red';
|
|
88
87
|
// v.borderColor = 'border--accent-red';
|
|
89
88
|
break;
|
|
90
|
-
case
|
|
89
|
+
case 'warning':
|
|
91
90
|
v.css = 'bg-warning text-dark';
|
|
92
91
|
// v.iconColor = 'text--accent-yellow';
|
|
93
92
|
// v.borderColor = 'border--accent-yellow';
|
|
94
93
|
break;
|
|
95
|
-
case
|
|
94
|
+
case 'info':
|
|
96
95
|
v.css = 'bg-info text-white';
|
|
97
96
|
// v.iconColor = 'text--accent-blue';
|
|
98
97
|
// v.borderColor = 'border--accent-blue';
|
|
99
98
|
break;
|
|
100
|
-
case
|
|
99
|
+
case 'light':
|
|
101
100
|
v.css = 'bg-light text-dark';
|
|
102
101
|
break;
|
|
103
|
-
case
|
|
102
|
+
case 'dark':
|
|
104
103
|
v.css = 'bg-dark text-white';
|
|
105
104
|
break;
|
|
106
105
|
default:
|
|
@@ -120,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
120
119
|
}], icon: [{
|
|
121
120
|
type: Input
|
|
122
121
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/alert/toast/toast.ts","../../../../../../../projects/zek/src/lib/modules/alert/toast/toast.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, Input } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { BootstrapHelper, Convert } from '../../../utils';\r\n//declare let bootstrap: any;\r\n\r\nimport { AlertService, Toast } from '../../../services/alert.service';\r\nimport { AlertType } from '../../../models';\r\nimport { NumberInput } from '../../../components';\r\n\r\nfunction clamp(v: number, min = 100, max = 10000) {\r\n    return Math.max(min, Math.min(max, v));\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-toast',\r\n    styleUrls: ['./toast.css'],\r\n    templateUrl: './toast.html'\r\n})\r\nexport class ZekToast implements OnInit, OnDestroy {\r\n    @Input()\r\n    get delay(): number {\r\n        return this._delay;\r\n    }\r\n    set delay(v: NumberInput) {\r\n        let tmp = clamp(Convert.toNumber(v) || 0);\r\n        if (this._delay !== tmp) {\r\n            this._delay = tmp;\r\n        }\r\n    }\r\n    _delay: number = 3000;\r\n    \r\n    \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            }, this._delay);\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>"]}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/alert/toast/toast.ts","../../../../../../../projects/zek/src/lib/modules/alert/toast/toast.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, Input } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { BootstrapHelper, Convert } from '../../../utils';\r\n//declare let bootstrap: any;\r\n\r\nimport { AlertService, Toast } from '../../../services/alert.service';\r\nimport { AlertType } from '../../../models';\r\nimport { NumberInput } from '../../../components';\r\n\r\nfunction clamp(v: number, min = 100, max = 10000) {\r\n    return Math.max(min, Math.min(max, v));\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-toast',\r\n    styleUrls: ['./toast.css'],\r\n    templateUrl: './toast.html'\r\n})\r\nexport class ZekToast implements OnInit, OnDestroy {\r\n    @Input()\r\n    get delay(): number {\r\n        return this._delay;\r\n    }\r\n    set delay(v: NumberInput) {\r\n        let tmp = clamp(Convert.toNumber(v) || 0);\r\n        if (this._delay !== tmp) {\r\n            this._delay = tmp;\r\n        }\r\n    }\r\n    _delay: number = 3000;\r\n    \r\n    \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            }, this._delay);\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 && !toast.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 'primary':\r\n                v.css = 'bg-primary text-white';\r\n                break;\r\n            case '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 '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 '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 '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 'light':\r\n                v.css = 'bg-light text-dark';\r\n                break;\r\n            case '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,5 +1,5 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { BootstrapHelper } from '../../../utils';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../../../services/alert.service";
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
@@ -37,43 +37,13 @@ class ZekValidation {
|
|
|
37
37
|
if (!alert.type) {
|
|
38
38
|
return;
|
|
39
39
|
}
|
|
40
|
-
|
|
41
|
-
case AlertType.Success:
|
|
42
|
-
return 'fa-solid fa-check';
|
|
43
|
-
case AlertType.Danger:
|
|
44
|
-
case AlertType.Warning:
|
|
45
|
-
return 'fa-solid fa-triangle-exclamation';
|
|
46
|
-
case AlertType.Info:
|
|
47
|
-
return 'fa-solid fa-circle-info';
|
|
48
|
-
default:
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
40
|
+
return BootstrapHelper.cssAlertIcon(alert.type);
|
|
51
41
|
}
|
|
52
42
|
cssAlert(alert) {
|
|
53
43
|
if (!alert) {
|
|
54
44
|
return;
|
|
55
45
|
}
|
|
56
|
-
|
|
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
|
-
}
|
|
46
|
+
return BootstrapHelper.cssAlert(alert.type);
|
|
77
47
|
}
|
|
78
48
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekValidation, deps: [{ token: i1.AlertService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
49
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekValidation, 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"] }] }); }
|
|
@@ -83,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
83
53
|
type: Component,
|
|
84
54
|
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"] }]
|
|
85
55
|
}], ctorParameters: function () { return [{ type: i1.AlertService }]; } });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL21vZHVsZXMvYWxlcnQvdmFsaWRhdGlvbi92YWxpZGF0aW9uLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9hbGVydC92YWxpZGF0aW9uL3ZhbGlkYXRpb24uaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUc3RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFFakQsTUFLYSxhQUFhO0lBSXRCLFlBQTZCLFlBQTBCO1FBQTFCLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBSHZELFdBQU0sR0FBWSxFQUFFLENBQUM7SUFHc0MsQ0FBQztJQUU1RCxRQUFRO1FBQ0osSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQVksRUFBRSxFQUFFO1lBQ3hFLElBQUksQ0FBQyxLQUFLLEVBQUU7Z0JBQ1IsK0NBQStDO2dCQUMvQyxJQUFJLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQztnQkFDakIsT0FBTzthQUNWO1lBQ0QscUJBQXFCO1lBQ3JCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFHRCxLQUFLO1FBQ0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBQ0QsTUFBTSxDQUFDLEtBQVk7UUFDZixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLEtBQUssQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFRCxPQUFPLENBQUMsS0FBWTtRQUNoQixJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ1IsT0FBTztTQUNWO1FBRUQsSUFBSSxLQUFLLENBQUMsSUFBSSxJQUFJLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUM7WUFDbkMsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDO1FBR3RCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFO1lBQ2IsT0FBTztTQUNWO1FBRUQsT0FBTyxlQUFlLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsUUFBUSxDQUFDLEtBQVk7UUFDakIsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNSLE9BQU87U0FDVjtRQUVELE9BQU8sZUFBZSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEQsQ0FBQzs4R0FwRFEsYUFBYTtrR0FBYixhQUFhLHNEQ1YxQix5YkFPTTs7U0RHTyxhQUFhOzJGQUFiLGFBQWE7a0JBTHpCLFNBQVM7K0JBQ0ksZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQWxlcnRTZXJ2aWNlLCBBbGVydCB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2FsZXJ0LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBCb290c3RyYXBIZWxwZXIgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnemVrLXZhbGlkYXRpb24nLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3ZhbGlkYXRpb24uaHRtbCcsXHJcbiAgICBzdHlsZXM6IFsnOmhvc3QgeyBkaXNwbGF5OiBibG9jazsgfSddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBaZWtWYWxpZGF0aW9uIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG4gICAgYWxlcnRzOiBBbGVydFtdID0gW107XHJcbiAgICBwcml2YXRlIHN1YnNjcmlwdGlvbj86IFN1YnNjcmlwdGlvbjtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGFsZXJ0U2VydmljZTogQWxlcnRTZXJ2aWNlKSB7IH1cclxuXHJcbiAgICBuZ09uSW5pdCgpIHtcclxuICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbiA9IHRoaXMuYWxlcnRTZXJ2aWNlLmdldEFsZXJ0KCkuc3Vic2NyaWJlKChhbGVydDogQWxlcnQpID0+IHtcclxuICAgICAgICAgICAgaWYgKCFhbGVydCkge1xyXG4gICAgICAgICAgICAgICAgLy8gY2xlYXIgYWxlcnRzIHdoZW4gYW4gZW1wdHkgYWxlcnQgaXMgcmVjZWl2ZWRcclxuICAgICAgICAgICAgICAgIHRoaXMuYWxlcnRzID0gW107XHJcbiAgICAgICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgLy8gYWRkIGFsZXJ0IHRvIGFycmF5XHJcbiAgICAgICAgICAgIHRoaXMuYWxlcnRzLnB1c2goYWxlcnQpO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIG5nT25EZXN0cm95KCkge1xyXG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uPy51bnN1YnNjcmliZSgpO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICBjbGVhcigpIHtcclxuICAgICAgICB0aGlzLmFsZXJ0U2VydmljZS5jbGVhcigpO1xyXG4gICAgfVxyXG4gICAgcmVtb3ZlKGFsZXJ0OiBBbGVydCkge1xyXG4gICAgICAgIHRoaXMuYWxlcnRzID0gdGhpcy5hbGVydHMuZmlsdGVyKHggPT4geCAhPT0gYWxlcnQpO1xyXG4gICAgfVxyXG5cclxuICAgIGNzc0ljb24oYWxlcnQ6IEFsZXJ0KSB7XHJcbiAgICAgICAgaWYgKCFhbGVydCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBpZiAoYWxlcnQuaWNvbiAmJiBhbGVydC5pY29uLmxlbmd0aCA+IDApXHJcbiAgICAgICAgICAgIHJldHVybiBhbGVydC5pY29uO1xyXG5cclxuXHJcbiAgICAgICAgaWYgKCFhbGVydC50eXBlKSB7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiBCb290c3RyYXBIZWxwZXIuY3NzQWxlcnRJY29uKGFsZXJ0LnR5cGUpO1xyXG4gICAgfVxyXG5cclxuICAgIGNzc0FsZXJ0KGFsZXJ0OiBBbGVydCkge1xyXG4gICAgICAgIGlmICghYWxlcnQpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIEJvb3RzdHJhcEhlbHBlci5jc3NBbGVydChhbGVydC50eXBlKTtcclxuICAgIH1cclxufSIsIjxkaXYgKm5nRm9yPVwibGV0IGFsZXJ0IG9mIGFsZXJ0c1wiIGNsYXNzPVwiYWxlcnQge3sgY3NzQWxlcnQoYWxlcnQpIH19IGFsZXJ0LWRpc21pc3NpYmxlIGZhZGUgc2hvdyBtdC0zXCIgcm9sZT1cImFsZXJ0XCI+XHJcbiAgICA8YnV0dG9uIChjbGljayk9XCJyZW1vdmUoYWxlcnQpXCIgdHlwZT1cImJ1dHRvblwiIGNsYXNzPVwiYnRuLWNsb3NlXCIgYXJpYS1sYWJlbD1cIkNsb3NlXCI+PC9idXR0b24+XHJcbiAgICA8ZGl2ICpuZ0Zvcj1cImxldCBtZXNzYWdlIG9mIGFsZXJ0Lm1lc3NhZ2VzXCI+XHJcbiAgICAgICAgPGkgKm5nSWY9XCJjc3NJY29uKGFsZXJ0KVwiIGNsYXNzPVwie3sgY3NzSWNvbihhbGVydCkgfX1cIj48L2k+XHJcbiAgICAgICAge3ttZXNzYWdlfX1cclxuICAgIDwvZGl2PlxyXG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG48L2Rpdj4iXX0=
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { NavigationStart } from '@angular/router';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
|
-
import { AlertType } from '../models';
|
|
5
4
|
import { BootstrapHelper } from '../utils/bootstrap.helper';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "@angular/router";
|
|
@@ -50,22 +49,22 @@ class AlertService {
|
|
|
50
49
|
return this.toastSubject.asObservable();
|
|
51
50
|
}
|
|
52
51
|
success(message, title, icon) {
|
|
53
|
-
this.show(message, title,
|
|
52
|
+
this.show(message, title, 'success', icon);
|
|
54
53
|
}
|
|
55
54
|
error(message, title, icon) {
|
|
56
|
-
this.show(message, title,
|
|
55
|
+
this.show(message, title, 'danger', icon);
|
|
57
56
|
}
|
|
58
57
|
warning(message, title, icon) {
|
|
59
|
-
this.show(message, title,
|
|
58
|
+
this.show(message, title, 'warning', icon);
|
|
60
59
|
}
|
|
61
60
|
info(message, title, icon) {
|
|
62
|
-
this.show(message, title,
|
|
61
|
+
this.show(message, title, 'info', icon);
|
|
63
62
|
}
|
|
64
63
|
show(message, title, alertType, icon) {
|
|
65
|
-
if (!icon)
|
|
64
|
+
if (!icon) {
|
|
66
65
|
icon = BootstrapHelper.cssAlertIcon(alertType);
|
|
66
|
+
}
|
|
67
67
|
this.toastSubject.next({ message, title, type: alertType, icon }); //, id: `${this.id++}`
|
|
68
|
-
//$.notify(message, alertType ? AlertType[alertType].toLowerCase() : undefined, icon);
|
|
69
68
|
}
|
|
70
69
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AlertService, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
71
70
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AlertService }); }
|
|
@@ -74,4 +73,4 @@ export { AlertService };
|
|
|
74
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AlertService, decorators: [{
|
|
75
74
|
type: Injectable
|
|
76
75
|
}], ctorParameters: function () { return [{ type: i1.Router }]; } });
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL3NlcnZpY2VzL2FsZXJ0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQVUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDMUQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUUvQixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7OztBQUU1RCxNQUFNLE9BQU8sU0FBUztDQU1yQjtBQUVELE1BQU0sT0FBTyxLQUFNLFNBQVEsU0FBUztDQUVuQztBQUVELE1BQU0sT0FBTyxLQUFNLFNBQVEsU0FBUztDQUVuQztBQUVELE1BQ2EsWUFBWTtJQUlyQixrQkFBa0I7SUFFbEIsWUFBWSxNQUFjO1FBTGxCLGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBQU8sQ0FBQztRQUNsQyxpQkFBWSxHQUFHLElBQUksT0FBTyxFQUFPLENBQUM7UUFDbEMseUJBQW9CLEdBQUcsS0FBSyxDQUFDO1FBSWpDLGtGQUFrRjtRQUNsRixNQUFNLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUM1QixJQUFJLEtBQUssWUFBWSxlQUFlLEVBQUU7Z0JBQ2xDLElBQUksSUFBSSxDQUFDLG9CQUFvQixFQUFFO29CQUMzQixzQ0FBc0M7b0JBQ3RDLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7aUJBQ3JDO3FCQUFNO29CQUNILHVCQUF1QjtvQkFDdkIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO2lCQUNoQjthQUNKO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsR0FBRyxDQUFDLFNBQW9CLEVBQUUsT0FBZSxFQUFFLG9CQUFvQixHQUFHLEtBQUs7UUFDbkUsSUFBSSxRQUFRLEdBQUcsRUFBRSxDQUFDO1FBQ2xCLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxTQUFTLEVBQUUsUUFBUSxFQUFFLG9CQUFvQixDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUNELFFBQVEsQ0FBQyxTQUFvQixFQUFFLFFBQWtCLEVBQUUsb0JBQW9CLEdBQUcsS0FBSztRQUMzRSxJQUFJLENBQUMsb0JBQW9CLEdBQUcsb0JBQW9CLENBQUM7UUFDakQsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQVEsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQzNFLENBQUM7SUFDRCxLQUFLO1FBQ0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUdELFFBQVE7UUFDSixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDNUMsQ0FBQztJQUNELFFBQVE7UUFDSixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDNUMsQ0FBQztJQUdELE9BQU8sQ0FBQyxPQUFlLEVBQUUsS0FBcUIsRUFBRSxJQUFvQjtRQUNoRSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFDRCxLQUFLLENBQUMsT0FBZSxFQUFFLEtBQXFCLEVBQUUsSUFBb0I7UUFDOUQsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBQ0QsT0FBTyxDQUFDLE9BQWUsRUFBRSxLQUFxQixFQUFFLElBQW9CO1FBQ2hFLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUNELElBQUksQ0FBQyxPQUFlLEVBQUUsS0FBcUIsRUFBRSxJQUFvQjtRQUM3RCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFDTyxJQUFJLENBQUMsT0FBZSxFQUFFLEtBQXFCLEVBQUUsU0FBNEIsRUFBRSxJQUFvQjtRQUNuRyxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ1AsSUFBSSxHQUFHLGVBQWUsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUE7U0FDakQ7UUFFRCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBUSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUEsc0JBQXNCO0lBQ25HLENBQUM7OEdBN0RRLFlBQVk7a0hBQVosWUFBWTs7U0FBWixZQUFZOzJGQUFaLFlBQVk7a0JBRHhCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJvdXRlciwgTmF2aWdhdGlvblN0YXJ0IH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBBbGVydFR5cGUgfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBCb290c3RyYXBIZWxwZXIgfSBmcm9tICcuLi91dGlscy9ib290c3RyYXAuaGVscGVyJztcclxuXHJcbmV4cG9ydCBjbGFzcyBCYXNlQWxlcnQge1xyXG4gICAgdHlwZT86IEFsZXJ0VHlwZSB8IG51bGw7XHJcbiAgICBpY29uPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHRpdGxlPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGNzcz86IHN0cmluZyB8IG51bGw7XHJcbiAgICAvLyBpZD86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIEFsZXJ0IGV4dGVuZHMgQmFzZUFsZXJ0IHtcclxuICAgIG1lc3NhZ2VzPzogc3RyaW5nW107XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBUb2FzdCBleHRlbmRzIEJhc2VBbGVydCB7XHJcbiAgICBtZXNzYWdlPzogc3RyaW5nIHwgbnVsbDtcclxufVxyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQWxlcnRTZXJ2aWNlIHtcclxuICAgIHByaXZhdGUgYWxlcnRTdWJqZWN0ID0gbmV3IFN1YmplY3Q8YW55PigpO1xyXG4gICAgcHJpdmF0ZSB0b2FzdFN1YmplY3QgPSBuZXcgU3ViamVjdDxhbnk+KCk7XHJcbiAgICBwcml2YXRlIGtlZXBBZnRlclJvdXRlQ2hhbmdlID0gZmFsc2U7XHJcbiAgICAvLyBwcml2YXRlIGlkID0gMDtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihyb3V0ZXI6IFJvdXRlcikge1xyXG4gICAgICAgIC8vIGNsZWFyIGFsZXJ0IG1lc3NhZ2VzIG9uIHJvdXRlIGNoYW5nZSB1bmxlc3MgJ2tlZXBBZnRlclJvdXRlQ2hhbmdlJyBmbGFnIGlzIHRydWVcclxuICAgICAgICByb3V0ZXIuZXZlbnRzLnN1YnNjcmliZShldmVudCA9PiB7XHJcbiAgICAgICAgICAgIGlmIChldmVudCBpbnN0YW5jZW9mIE5hdmlnYXRpb25TdGFydCkge1xyXG4gICAgICAgICAgICAgICAgaWYgKHRoaXMua2VlcEFmdGVyUm91dGVDaGFuZ2UpIHtcclxuICAgICAgICAgICAgICAgICAgICAvLyBvbmx5IGtlZXAgZm9yIGEgc2luZ2xlIHJvdXRlIGNoYW5nZVxyXG4gICAgICAgICAgICAgICAgICAgIHRoaXMua2VlcEFmdGVyUm91dGVDaGFuZ2UgPSBmYWxzZTtcclxuICAgICAgICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgICAgICAgICAgLy8gY2xlYXIgYWxlcnQgbWVzc2FnZXNcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNsZWFyKCk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBhZGQoYWxlcnRUeXBlOiBBbGVydFR5cGUsIG1lc3NhZ2U6IFN0cmluZywga2VlcEFmdGVyUm91dGVDaGFuZ2UgPSBmYWxzZSkge1xyXG4gICAgICAgIGxldCBtZXNzYWdlcyA9IFtdO1xyXG4gICAgICAgIG1lc3NhZ2VzLnB1c2gobWVzc2FnZSk7XHJcbiAgICAgICAgdGhpcy5hZGRSYW5nZShhbGVydFR5cGUsIG1lc3NhZ2VzLCBrZWVwQWZ0ZXJSb3V0ZUNoYW5nZSk7XHJcbiAgICB9XHJcbiAgICBhZGRSYW5nZShhbGVydFR5cGU6IEFsZXJ0VHlwZSwgbWVzc2FnZXM6IFN0cmluZ1tdLCBrZWVwQWZ0ZXJSb3V0ZUNoYW5nZSA9IGZhbHNlKSB7XHJcbiAgICAgICAgdGhpcy5rZWVwQWZ0ZXJSb3V0ZUNoYW5nZSA9IGtlZXBBZnRlclJvdXRlQ2hhbmdlO1xyXG4gICAgICAgIHRoaXMuYWxlcnRTdWJqZWN0Lm5leHQoPEFsZXJ0PnsgdHlwZTogYWxlcnRUeXBlLCBtZXNzYWdlczogbWVzc2FnZXMgfSk7XHJcbiAgICB9XHJcbiAgICBjbGVhcigpIHtcclxuICAgICAgICB0aGlzLmFsZXJ0U3ViamVjdC5uZXh0KG51bGwpO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICBnZXRBbGVydCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5hbGVydFN1YmplY3QuYXNPYnNlcnZhYmxlKCk7XHJcbiAgICB9XHJcbiAgICBnZXRUb2FzdCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy50b2FzdFN1YmplY3QuYXNPYnNlcnZhYmxlKCk7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIHN1Y2Nlc3MobWVzc2FnZTogc3RyaW5nLCB0aXRsZT86IHN0cmluZyB8IG51bGwsIGljb24/OiBzdHJpbmcgfCBudWxsKSB7XHJcbiAgICAgICAgdGhpcy5zaG93KG1lc3NhZ2UsIHRpdGxlLCAnc3VjY2VzcycsIGljb24pO1xyXG4gICAgfVxyXG4gICAgZXJyb3IobWVzc2FnZTogc3RyaW5nLCB0aXRsZT86IHN0cmluZyB8IG51bGwsIGljb24/OiBzdHJpbmcgfCBudWxsKSB7XHJcbiAgICAgICAgdGhpcy5zaG93KG1lc3NhZ2UsIHRpdGxlLCAnZGFuZ2VyJywgaWNvbik7XHJcbiAgICB9XHJcbiAgICB3YXJuaW5nKG1lc3NhZ2U6IHN0cmluZywgdGl0bGU/OiBzdHJpbmcgfCBudWxsLCBpY29uPzogc3RyaW5nIHwgbnVsbCkge1xyXG4gICAgICAgIHRoaXMuc2hvdyhtZXNzYWdlLCB0aXRsZSwgJ3dhcm5pbmcnLCBpY29uKTtcclxuICAgIH1cclxuICAgIGluZm8obWVzc2FnZTogc3RyaW5nLCB0aXRsZT86IHN0cmluZyB8IG51bGwsIGljb24/OiBzdHJpbmcgfCBudWxsKSB7XHJcbiAgICAgICAgdGhpcy5zaG93KG1lc3NhZ2UsIHRpdGxlLCAnaW5mbycsIGljb24pO1xyXG4gICAgfVxyXG4gICAgcHJpdmF0ZSBzaG93KG1lc3NhZ2U6IHN0cmluZywgdGl0bGU/OiBzdHJpbmcgfCBudWxsLCBhbGVydFR5cGU/OiBBbGVydFR5cGUgfCBudWxsLCBpY29uPzogc3RyaW5nIHwgbnVsbCkge1xyXG4gICAgICAgIGlmICghaWNvbikge1xyXG4gICAgICAgICAgICBpY29uID0gQm9vdHN0cmFwSGVscGVyLmNzc0FsZXJ0SWNvbihhbGVydFR5cGUpXHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLnRvYXN0U3ViamVjdC5uZXh0KDxUb2FzdD57IG1lc3NhZ2UsIHRpdGxlLCB0eXBlOiBhbGVydFR5cGUsIGljb24gfSk7Ly8sIGlkOiBgJHt0aGlzLmlkKyt9YFxyXG4gICAgfVxyXG59Il19
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { of } from 'rxjs';
|
|
3
|
-
import { AlertType } from '../models';
|
|
4
3
|
import { ObjectHelper } from '../utils/object-helper';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "./alert.service";
|
|
@@ -109,7 +108,7 @@ class HttpErrorHandler {
|
|
|
109
108
|
}
|
|
110
109
|
}
|
|
111
110
|
}
|
|
112
|
-
this.alert.addRange(
|
|
111
|
+
this.alert.addRange('danger', errorMessages);
|
|
113
112
|
}
|
|
114
113
|
break;
|
|
115
114
|
case 401: //Unauthorized
|
|
@@ -139,4 +138,4 @@ export { HttpErrorHandler };
|
|
|
139
138
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: HttpErrorHandler, decorators: [{
|
|
140
139
|
type: Injectable
|
|
141
140
|
}], ctorParameters: function () { return [{ type: i1.AlertService }, { type: i2.TranslateService }, { type: i3.Router }]; } });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-error-handler.service.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/services/http-error-handler.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { Router } from '@angular/router';\r\nimport { Observable, of } from 'rxjs';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { AlertService } from './alert.service';\r\nimport { AlertType } from '../models';\r\nimport { ObjectHelper } from '../utils/object-helper';\r\n\r\n/** Type of the handleError function returned by HttpErrorHandler.createHandleError */\r\nexport type HandleError = <T = any>(operation?: string, result?: T, show?: boolean) => (error: HttpErrorResponse) => Observable<T>;\r\nexport type HandleErrorResult = <T = any>(operation?: string, result?: T, show?: boolean) => (error: HttpErrorResponse) => Observable<T>;\r\n\r\n/** Handles HttpClient errors */\r\n@Injectable()\r\nexport class HttpErrorHandler {\r\n    constructor(\r\n        private readonly alert: AlertService,\r\n        private readonly translate: TranslateService,\r\n        private readonly router: Router) { }\r\n\r\n    /** Create curried handleError function that already knows the service name */\r\n    createHandleError = (serviceName = '') => <T>(operation = 'operation', result = {} as T, show = true) => this.handleError(serviceName, operation, result, show);\r\n    createHandleErrorResult = (serviceName = '') => <T>(operation = 'operation', result = {} as T, show = true) => this.handleErrorResult(serviceName, operation, result, show);\r\n\r\n    /**\r\n     * Returns a function that handles Http operation failures.\r\n     * This error handler lets the app continue to run as if no error occurred.\r\n     * @param serviceName = name of the data service that attempted the operation\r\n     * @param operation - name of the operation that failed\r\n     * @param result - optional value to return as the observable result\r\n     * @param show - optional value to show error\r\n     */\r\n    handleError<T>(serviceName = '', operation = 'operation', result = {} as T, show?: boolean) {\r\n        return (response: HttpErrorResponse): Observable<T> => {\r\n            console.error(response);\r\n\r\n            if (show) {\r\n                this.showError(serviceName, operation, response)\r\n            }\r\n\r\n            return of(result);\r\n        };\r\n    }\r\n\r\n\r\n\r\n    /**\r\n     * Returns a function that handles Http operation failures.\r\n     * This error handler lets the app continue to run as if no error occurred.\r\n     * @param serviceName = name of the data service that attempted the operation\r\n     * @param operation - name of the operation that failed\r\n     * @param show - optional value to show error\r\n     */\r\n    handleErrorResult<T>(serviceName = '', operation = 'operation', result = {} as T, show?: boolean) {\r\n        return (response: HttpErrorResponse): Observable<any> => {\r\n            console.error(response);\r\n\r\n            if (show) {\r\n                this.showError(serviceName, operation, response)\r\n            }\r\n\r\n\r\n            let error: any;           \r\n            if (typeof response.error === 'string' && response.error[0] === '{') {\r\n                error = JSON.parse(response.error);\r\n            } else {\r\n                error = response.error;\r\n            }\r\n\r\n            if (error instanceof ErrorEvent) {\r\n                error = response.error.message;\r\n            }\r\n\r\n            return ObjectHelper.isDefined(error) ? of(error) : of(result);\r\n        };\r\n    }\r\n\r\n\r\n    private showError(serviceName: string, operation: string, response: HttpErrorResponse) {\r\n        switch (response.status) {\r\n            case 0://No Connection\r\n                this.alert.error(`Can't connect to api server.`);\r\n                break;\r\n\r\n            case 400://Bad Request\r\n                let error: any;\r\n                if (typeof response.error === 'string' && response.error[0] === '{') {\r\n                    error = JSON.parse(response.error);\r\n                } else {\r\n                    error = response.error;\r\n                }\r\n\r\n                if (error instanceof ErrorEvent) {\r\n                    this.alert.error(`${serviceName}: ${operation} failed: ${response.error.message}`);\r\n                } if (typeof error === 'string') {\r\n                    this.alert.error(response.error as string);\r\n                } else if (typeof error === 'object') {\r\n                    const errors = error.traceId || error.success === false\r\n                        ? error.errors\r\n                        : error;\r\n\r\n                    const errorMessages: string[] = [];\r\n                    const properties = Object.getOwnPropertyNames(errors);\r\n\r\n                    for (let property of properties) {\r\n                        const messages = errors[property];\r\n                        if (messages instanceof Array) {\r\n                            for (let message of messages) {\r\n                                const messageKey = `Validation.${message}`;\r\n                                let translatedMessage = this.translate.instant(messageKey);\r\n                                // if translation not found then use message\r\n                                if (messageKey == translatedMessage) {\r\n                                    translatedMessage = message;\r\n                                }\r\n\r\n                                if (property) {\r\n                                    const propertyKey = `Fields.${property}`;\r\n                                    let translatedProperty = this.translate.instant(`Fields.${property}`);\r\n                                    // if translation not found then use property\r\n                                    if (propertyKey == translatedProperty) {\r\n                                        translatedProperty = property\r\n                                    }\r\n                                    errorMessages.push(translatedProperty + ' - ' + translatedMessage);\r\n                                }\r\n                                else {\r\n                                    errorMessages.push(translatedMessage);\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                    this.alert.addRange(AlertType.Danger, errorMessages);\r\n                }\r\n                break;\r\n\r\n            case 401://Unauthorized\r\n                this.alert.error('Unauthorized');\r\n                this.router.navigate(['/login']);\r\n                break;\r\n\r\n            case 403://Forbidden\r\n                this.alert.error('Forbidden');\r\n                break;\r\n\r\n            case 404://Not Found\r\n                this.alert.error('Not Found');\r\n                break;\r\n\r\n            case 402://Payment Required\r\n                this.alert.error('License Payment Required');\r\n                break;\r\n\r\n            case 500://Internal Server Error\r\n                this.alert.error('Internal Server Error');\r\n                break;\r\n\r\n            default:\r\n                break;\r\n        }\r\n    }\r\n\r\n}"]}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-error-handler.service.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/services/http-error-handler.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { Router } from '@angular/router';\r\nimport { Observable, of } from 'rxjs';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { AlertService } from './alert.service';\r\nimport { AlertType } from '../models';\r\nimport { ObjectHelper } from '../utils/object-helper';\r\n\r\n/** Type of the handleError function returned by HttpErrorHandler.createHandleError */\r\nexport type HandleError = <T = any>(operation?: string, result?: T, show?: boolean) => (error: HttpErrorResponse) => Observable<T>;\r\nexport type HandleErrorResult = <T = any>(operation?: string, result?: T, show?: boolean) => (error: HttpErrorResponse) => Observable<T>;\r\n\r\n/** Handles HttpClient errors */\r\n@Injectable()\r\nexport class HttpErrorHandler {\r\n    constructor(\r\n        private readonly alert: AlertService,\r\n        private readonly translate: TranslateService,\r\n        private readonly router: Router) { }\r\n\r\n    /** Create curried handleError function that already knows the service name */\r\n    createHandleError = (serviceName = '') => <T>(operation = 'operation', result = {} as T, show = true) => this.handleError(serviceName, operation, result, show);\r\n    createHandleErrorResult = (serviceName = '') => <T>(operation = 'operation', result = {} as T, show = true) => this.handleErrorResult(serviceName, operation, result, show);\r\n\r\n    /**\r\n     * Returns a function that handles Http operation failures.\r\n     * This error handler lets the app continue to run as if no error occurred.\r\n     * @param serviceName = name of the data service that attempted the operation\r\n     * @param operation - name of the operation that failed\r\n     * @param result - optional value to return as the observable result\r\n     * @param show - optional value to show error\r\n     */\r\n    handleError<T>(serviceName = '', operation = 'operation', result = {} as T, show?: boolean) {\r\n        return (response: HttpErrorResponse): Observable<T> => {\r\n            console.error(response);\r\n\r\n            if (show) {\r\n                this.showError(serviceName, operation, response)\r\n            }\r\n\r\n            return of(result);\r\n        };\r\n    }\r\n\r\n\r\n\r\n    /**\r\n     * Returns a function that handles Http operation failures.\r\n     * This error handler lets the app continue to run as if no error occurred.\r\n     * @param serviceName = name of the data service that attempted the operation\r\n     * @param operation - name of the operation that failed\r\n     * @param show - optional value to show error\r\n     */\r\n    handleErrorResult<T>(serviceName = '', operation = 'operation', result = {} as T, show?: boolean) {\r\n        return (response: HttpErrorResponse): Observable<any> => {\r\n            console.error(response);\r\n\r\n            if (show) {\r\n                this.showError(serviceName, operation, response)\r\n            }\r\n\r\n\r\n            let error: any;           \r\n            if (typeof response.error === 'string' && response.error[0] === '{') {\r\n                error = JSON.parse(response.error);\r\n            } else {\r\n                error = response.error;\r\n            }\r\n\r\n            if (error instanceof ErrorEvent) {\r\n                error = response.error.message;\r\n            }\r\n\r\n            return ObjectHelper.isDefined(error) ? of(error) : of(result);\r\n        };\r\n    }\r\n\r\n\r\n    private showError(serviceName: string, operation: string, response: HttpErrorResponse) {\r\n        switch (response.status) {\r\n            case 0://No Connection\r\n                this.alert.error(`Can't connect to api server.`);\r\n                break;\r\n\r\n            case 400://Bad Request\r\n                let error: any;\r\n                if (typeof response.error === 'string' && response.error[0] === '{') {\r\n                    error = JSON.parse(response.error);\r\n                } else {\r\n                    error = response.error;\r\n                }\r\n\r\n                if (error instanceof ErrorEvent) {\r\n                    this.alert.error(`${serviceName}: ${operation} failed: ${response.error.message}`);\r\n                } if (typeof error === 'string') {\r\n                    this.alert.error(response.error as string);\r\n                } else if (typeof error === 'object') {\r\n                    const errors = error.traceId || error.success === false\r\n                        ? error.errors\r\n                        : error;\r\n\r\n                    const errorMessages: string[] = [];\r\n                    const properties = Object.getOwnPropertyNames(errors);\r\n\r\n                    for (let property of properties) {\r\n                        const messages = errors[property];\r\n                        if (messages instanceof Array) {\r\n                            for (let message of messages) {\r\n                                const messageKey = `Validation.${message}`;\r\n                                let translatedMessage = this.translate.instant(messageKey);\r\n                                // if translation not found then use message\r\n                                if (messageKey == translatedMessage) {\r\n                                    translatedMessage = message;\r\n                                }\r\n\r\n                                if (property) {\r\n                                    const propertyKey = `Fields.${property}`;\r\n                                    let translatedProperty = this.translate.instant(`Fields.${property}`);\r\n                                    // if translation not found then use property\r\n                                    if (propertyKey == translatedProperty) {\r\n                                        translatedProperty = property\r\n                                    }\r\n                                    errorMessages.push(translatedProperty + ' - ' + translatedMessage);\r\n                                }\r\n                                else {\r\n                                    errorMessages.push(translatedMessage);\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                    this.alert.addRange('danger', errorMessages);\r\n                }\r\n                break;\r\n\r\n            case 401://Unauthorized\r\n                this.alert.error('Unauthorized');\r\n                this.router.navigate(['/login']);\r\n                break;\r\n\r\n            case 403://Forbidden\r\n                this.alert.error('Forbidden');\r\n                break;\r\n\r\n            case 404://Not Found\r\n                this.alert.error('Not Found');\r\n                break;\r\n\r\n            case 402://Payment Required\r\n                this.alert.error('License Payment Required');\r\n                break;\r\n\r\n            case 500://Internal Server Error\r\n                this.alert.error('Internal Server Error');\r\n                break;\r\n\r\n            default:\r\n                break;\r\n        }\r\n    }\r\n\r\n}"]}
|
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
import { AlertType } from '../models/alert-type';
|
|
2
|
-
import { StringHelper } from './string-helper';
|
|
3
1
|
export var ComponentType;
|
|
4
2
|
(function (ComponentType) {
|
|
5
3
|
ComponentType[ComponentType["Primary"] = 1] = "Primary";
|
|
@@ -76,34 +74,33 @@ export class BootstrapHelper {
|
|
|
76
74
|
return 'btn-secondary';
|
|
77
75
|
}
|
|
78
76
|
}
|
|
79
|
-
static getAlertType(type) {
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
}
|
|
77
|
+
// static getAlertType(type?: string | null): AlertType | null {
|
|
78
|
+
// if (!type) return null;
|
|
79
|
+
// let v = StringHelper.firstUpper(type);
|
|
80
|
+
// if (!v)
|
|
81
|
+
// return null;
|
|
82
|
+
// var enumValue = (<any>AlertType)[v];
|
|
83
|
+
// if (!enumValue)
|
|
84
|
+
// return null;
|
|
85
|
+
// return enumValue;
|
|
86
|
+
// }
|
|
90
87
|
static cssAlert(type) {
|
|
91
88
|
switch (type) {
|
|
92
|
-
case
|
|
89
|
+
case 'primary':
|
|
93
90
|
return 'alert-primary';
|
|
94
|
-
case
|
|
91
|
+
case 'secondary':
|
|
95
92
|
return 'alert-secondary';
|
|
96
|
-
case
|
|
93
|
+
case 'success':
|
|
97
94
|
return 'alert-success';
|
|
98
|
-
case
|
|
95
|
+
case 'danger':
|
|
99
96
|
return 'alert-danger';
|
|
100
|
-
case
|
|
97
|
+
case 'warning':
|
|
101
98
|
return 'alert-warning';
|
|
102
|
-
case
|
|
99
|
+
case 'info':
|
|
103
100
|
return 'alert-info';
|
|
104
|
-
case
|
|
101
|
+
case 'light':
|
|
105
102
|
return 'alert-light';
|
|
106
|
-
case
|
|
103
|
+
case 'dark':
|
|
107
104
|
return 'alert-dark';
|
|
108
105
|
default:
|
|
109
106
|
return 'alert-secondary';
|
|
@@ -111,17 +108,17 @@ export class BootstrapHelper {
|
|
|
111
108
|
}
|
|
112
109
|
static cssAlertIcon(type) {
|
|
113
110
|
switch (type) {
|
|
114
|
-
case
|
|
111
|
+
case 'success':
|
|
115
112
|
return 'fa-solid fa-circle-check';
|
|
116
|
-
case
|
|
113
|
+
case 'danger':
|
|
117
114
|
return 'fa-solid fa-circle-xmark';
|
|
118
|
-
case
|
|
115
|
+
case 'warning':
|
|
119
116
|
return 'fa-solid fa-circle-exclamation';
|
|
120
|
-
case
|
|
117
|
+
case 'info':
|
|
121
118
|
return 'fa-solid fa-circle-info';
|
|
122
119
|
default:
|
|
123
120
|
return '';
|
|
124
121
|
}
|
|
125
122
|
}
|
|
126
123
|
}
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bootstrap.helper.js","sourceRoot":"","sources":["../../../../../projects/zek/src/lib/utils/bootstrap.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { AlertType } from '../models/alert-type';\r\nimport { StringHelper } from './string-helper';\r\n\r\nexport enum ComponentType {\r\n    Primary = 1,\r\n    // Secondary,\r\n    Success,\r\n    Delete,\r\n    //Danger,\r\n    Warning,\r\n    Info,\r\n    // Light,\r\n    // Dark,\r\n}\r\n\r\nexport enum Color {\r\n    Primary = 1,\r\n    Secondary = 2,\r\n    Success = 3,\r\n    Danger = 4,\r\n    Warning = 5,\r\n    Info = 6,\r\n    Dark = 8,\r\n}\r\n\r\nexport class BootstrapHelper {\r\n    static cssColor(color?: Color | null) {\r\n        switch (color) {\r\n            case Color.Primary:\r\n                return 'bg-primary text-white'\r\n            case Color.Secondary:\r\n                return 'bg-secondary text-white';\r\n            case Color.Success:\r\n                return 'bg-success text-white';\r\n            case Color.Danger:\r\n                return 'bg-danger text-white';\r\n            case Color.Warning:\r\n                return 'bg-warning text-dark';\r\n            case Color.Info:\r\n                return 'bg-info text-dark';\r\n            case Color.Dark:\r\n                return 'bg-dark text-white';\r\n            default:\r\n                return '';\r\n        }\r\n    }\r\n    static cssIcon(type: ComponentType): string | null {\r\n        if (!type) {\r\n            return null;\r\n        }\r\n\r\n        switch (type) {\r\n            case ComponentType.Delete:\r\n                return 'fa-solid fa-trash';\r\n\r\n            // case ComponentType.Danger:\r\n            case ComponentType.Warning:\r\n                return 'fa-solid fa-triangle-exclamation';\r\n\r\n            case ComponentType.Info:\r\n                return 'fa-solid fa-circle-info';\r\n\r\n            default:\r\n                return 'fa-solid fa-check';\r\n        }\r\n    }\r\n\r\n    static cssButton(type: ComponentType): string {\r\n        switch (type) {\r\n            case ComponentType.Primary:\r\n            // case ComponentType.Secondary:\r\n            case ComponentType.Success:\r\n            // case ComponentType.Danger:\r\n            case ComponentType.Warning:\r\n            case ComponentType.Info:\r\n                // case ComponentType.Light:\r\n                // case ComponentType.Dark:\r\n                return `btn-${ComponentType[type].toLowerCase()}`;\r\n\r\n            case ComponentType.Delete:\r\n                return 'btn-danger';\r\n            default:\r\n                return 'btn-secondary';\r\n        }\r\n    }\r\n\r\n\r\n\r\n\r\n    // static getAlertType(type?: string | null): AlertType | null {\r\n    //     if (!type) return null;\r\n\r\n    //     let v = StringHelper.firstUpper(type);\r\n    //     if (!v)\r\n    //         return null;\r\n\r\n    //     var enumValue = (<any>AlertType)[v];\r\n    //     if (!enumValue)\r\n    //         return null;\r\n\r\n\r\n    //     return enumValue;\r\n    // }\r\n    static cssAlert(type?: AlertType | null): string {\r\n        switch (type) {\r\n            case 'primary':\r\n                return 'alert-primary';\r\n            case 'secondary':\r\n                return 'alert-secondary';\r\n            case 'success':\r\n                return 'alert-success';\r\n            case 'danger':\r\n                return 'alert-danger';\r\n            case 'warning':\r\n                return 'alert-warning';\r\n            case 'info':\r\n                return 'alert-info';\r\n            case 'light':\r\n                return 'alert-light';\r\n            case 'dark':\r\n                return 'alert-dark';\r\n            default:\r\n                return 'alert-secondary';\r\n        }\r\n    }\r\n    static cssAlertIcon(type?: AlertType | null): string {\r\n        switch (type) {\r\n            case 'success':\r\n                return 'fa-solid fa-circle-check';\r\n            case 'danger':\r\n                return 'fa-solid fa-circle-xmark';\r\n            case 'warning':\r\n                return 'fa-solid fa-circle-exclamation';\r\n            case 'info':\r\n                return 'fa-solid fa-circle-info';\r\n            default:\r\n                return '';\r\n        }\r\n    }\r\n}"]}
|