zek 16.0.5 → 16.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1,17 +1,30 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { BootstrapHelper } from '../../../utils';
|
|
2
|
+
import { BootstrapHelper, Convert } from '../../../utils';
|
|
3
3
|
import { AlertType } from '../../../models';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "../../../services/alert.service";
|
|
6
6
|
import * as i2 from "@angular/common";
|
|
7
|
+
function clamp(v, min = 100, max = 10000) {
|
|
8
|
+
return Math.max(min, Math.min(max, v));
|
|
9
|
+
}
|
|
7
10
|
class ZekToast {
|
|
11
|
+
get delay() {
|
|
12
|
+
return this._delay;
|
|
13
|
+
}
|
|
14
|
+
set delay(v) {
|
|
15
|
+
let tmp = clamp(Convert.toNumber(v) || 0);
|
|
16
|
+
if (this._delay !== tmp) {
|
|
17
|
+
this._delay = tmp;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
8
20
|
constructor(alertService) {
|
|
9
21
|
this.alertService = alertService;
|
|
22
|
+
this._delay = 3000;
|
|
10
23
|
this.icon = true;
|
|
11
24
|
this.toasts = [];
|
|
12
25
|
}
|
|
13
26
|
ngOnInit() {
|
|
14
|
-
this.
|
|
27
|
+
this._subscription = this.alertService.getToast().subscribe((toast) => {
|
|
15
28
|
if (!toast) {
|
|
16
29
|
// clear alerts when an empty alert is received
|
|
17
30
|
this.toasts = [];
|
|
@@ -20,12 +33,12 @@ class ZekToast {
|
|
|
20
33
|
// add toast to array
|
|
21
34
|
this.cssInit(toast);
|
|
22
35
|
this.toasts.unshift(toast);
|
|
23
|
-
this.
|
|
36
|
+
this._timeout = setTimeout(() => {
|
|
24
37
|
this.remove(toast);
|
|
25
38
|
// let toastEl = document.getElementById(`toast-${toast.id}`);
|
|
26
39
|
// let t = new bootstrap.Toast(toastEl);
|
|
27
40
|
// t.show();
|
|
28
|
-
},
|
|
41
|
+
}, this._delay);
|
|
29
42
|
// let toastElList = [].slice.call(document.querySelectorAll('.toast'))
|
|
30
43
|
// let toastList = toastElList.map(function (toastEl) {
|
|
31
44
|
// return new bootstrap.Toast(toastEl)
|
|
@@ -36,8 +49,8 @@ class ZekToast {
|
|
|
36
49
|
});
|
|
37
50
|
}
|
|
38
51
|
ngOnDestroy() {
|
|
39
|
-
if (this.
|
|
40
|
-
this.
|
|
52
|
+
if (this._subscription) {
|
|
53
|
+
this._subscription.unsubscribe();
|
|
41
54
|
}
|
|
42
55
|
this.clearTimeout();
|
|
43
56
|
}
|
|
@@ -48,9 +61,9 @@ class ZekToast {
|
|
|
48
61
|
this.toasts = this.toasts.filter(x => x !== toast);
|
|
49
62
|
}
|
|
50
63
|
clearTimeout() {
|
|
51
|
-
if (this.
|
|
52
|
-
clearTimeout(this.
|
|
53
|
-
this.
|
|
64
|
+
if (this._timeout) {
|
|
65
|
+
clearTimeout(this._timeout);
|
|
66
|
+
this._timeout = null;
|
|
54
67
|
}
|
|
55
68
|
}
|
|
56
69
|
cssInit(toast) {
|
|
@@ -96,15 +109,15 @@ class ZekToast {
|
|
|
96
109
|
}
|
|
97
110
|
}
|
|
98
111
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekToast, deps: [{ token: i1.AlertService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
99
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekToast, selector: "zek-toast", inputs: {
|
|
112
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekToast, selector: "zek-toast", inputs: { delay: "delay", 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"] }] }); }
|
|
100
113
|
}
|
|
101
114
|
export { ZekToast };
|
|
102
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekToast, decorators: [{
|
|
103
116
|
type: Component,
|
|
104
117
|
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"] }]
|
|
105
|
-
}], ctorParameters: function () { return [{ type: i1.AlertService }]; }, propDecorators: {
|
|
118
|
+
}], ctorParameters: function () { return [{ type: i1.AlertService }]; }, propDecorators: { delay: [{
|
|
106
119
|
type: Input
|
|
107
120
|
}], icon: [{
|
|
108
121
|
type: Input
|
|
109
122
|
}] } });
|
|
110
|
-
//# 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 } 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.css'],\r\n    templateUrl: './toast.html'\r\n})\r\nexport class ZekToast 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>"]}
|
|
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":"AAAA,OAAO,EAAE,SAAS,EAAqB,KAAK,EAAE,MAAM,eAAe,CAAC;AAEpE,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAI1D,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;;;;AAG5C,SAAS,KAAK,CAAC,CAAS,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,KAAK;IAC5C,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;AAC3C,CAAC;AAED,MAKa,QAAQ;IACjB,IACI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IACD,IAAI,KAAK,CAAC,CAAc;QACpB,IAAI,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAC1C,IAAI,IAAI,CAAC,MAAM,KAAK,GAAG,EAAE;YACrB,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;SACrB;IACL,CAAC;IAUD,YAA6B,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;QATvD,WAAM,GAAW,IAAI,CAAC;QAGb,SAAI,GAAG,IAAI,CAAC;QAErB,WAAM,GAAU,EAAE,CAAC;IAIwC,CAAC;IAE5D,QAAQ;QACJ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC,CAAC,KAAY,EAAE,EAAE;YACzE,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,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC5B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACnB,8DAA8D;gBAC9D,wCAAwC;gBACxC,YAAY;YAChB,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAGhB,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,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;SACpC;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,QAAQ,EAAE;YACf,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC5B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;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;8GA7HQ,QAAQ;kGAAR,QAAQ,2FClBrB,4sDA2BM;;SDTO,QAAQ;2FAAR,QAAQ;kBALpB,SAAS;+BACI,WAAW;mGAMjB,KAAK;sBADR,KAAK;gBAaG,IAAI;sBAAZ,KAAK","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>"]}
|
package/fesm2022/zek.mjs
CHANGED
|
@@ -2764,14 +2764,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
2764
2764
|
type: Input
|
|
2765
2765
|
}] } });
|
|
2766
2766
|
|
|
2767
|
+
function clamp$1(v, min = 100, max = 10000) {
|
|
2768
|
+
return Math.max(min, Math.min(max, v));
|
|
2769
|
+
}
|
|
2767
2770
|
class ZekToast {
|
|
2771
|
+
get delay() {
|
|
2772
|
+
return this._delay;
|
|
2773
|
+
}
|
|
2774
|
+
set delay(v) {
|
|
2775
|
+
let tmp = clamp$1(Convert.toNumber(v) || 0);
|
|
2776
|
+
if (this._delay !== tmp) {
|
|
2777
|
+
this._delay = tmp;
|
|
2778
|
+
}
|
|
2779
|
+
}
|
|
2768
2780
|
constructor(alertService) {
|
|
2769
2781
|
this.alertService = alertService;
|
|
2782
|
+
this._delay = 3000;
|
|
2770
2783
|
this.icon = true;
|
|
2771
2784
|
this.toasts = [];
|
|
2772
2785
|
}
|
|
2773
2786
|
ngOnInit() {
|
|
2774
|
-
this.
|
|
2787
|
+
this._subscription = this.alertService.getToast().subscribe((toast) => {
|
|
2775
2788
|
if (!toast) {
|
|
2776
2789
|
// clear alerts when an empty alert is received
|
|
2777
2790
|
this.toasts = [];
|
|
@@ -2780,12 +2793,12 @@ class ZekToast {
|
|
|
2780
2793
|
// add toast to array
|
|
2781
2794
|
this.cssInit(toast);
|
|
2782
2795
|
this.toasts.unshift(toast);
|
|
2783
|
-
this.
|
|
2796
|
+
this._timeout = setTimeout(() => {
|
|
2784
2797
|
this.remove(toast);
|
|
2785
2798
|
// let toastEl = document.getElementById(`toast-${toast.id}`);
|
|
2786
2799
|
// let t = new bootstrap.Toast(toastEl);
|
|
2787
2800
|
// t.show();
|
|
2788
|
-
},
|
|
2801
|
+
}, this._delay);
|
|
2789
2802
|
// let toastElList = [].slice.call(document.querySelectorAll('.toast'))
|
|
2790
2803
|
// let toastList = toastElList.map(function (toastEl) {
|
|
2791
2804
|
// return new bootstrap.Toast(toastEl)
|
|
@@ -2796,8 +2809,8 @@ class ZekToast {
|
|
|
2796
2809
|
});
|
|
2797
2810
|
}
|
|
2798
2811
|
ngOnDestroy() {
|
|
2799
|
-
if (this.
|
|
2800
|
-
this.
|
|
2812
|
+
if (this._subscription) {
|
|
2813
|
+
this._subscription.unsubscribe();
|
|
2801
2814
|
}
|
|
2802
2815
|
this.clearTimeout();
|
|
2803
2816
|
}
|
|
@@ -2808,9 +2821,9 @@ class ZekToast {
|
|
|
2808
2821
|
this.toasts = this.toasts.filter(x => x !== toast);
|
|
2809
2822
|
}
|
|
2810
2823
|
clearTimeout() {
|
|
2811
|
-
if (this.
|
|
2812
|
-
clearTimeout(this.
|
|
2813
|
-
this.
|
|
2824
|
+
if (this._timeout) {
|
|
2825
|
+
clearTimeout(this._timeout);
|
|
2826
|
+
this._timeout = null;
|
|
2814
2827
|
}
|
|
2815
2828
|
}
|
|
2816
2829
|
cssInit(toast) {
|
|
@@ -2856,12 +2869,12 @@ class ZekToast {
|
|
|
2856
2869
|
}
|
|
2857
2870
|
}
|
|
2858
2871
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekToast, deps: [{ token: AlertService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2859
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekToast, selector: "zek-toast", inputs: {
|
|
2872
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ZekToast, selector: "zek-toast", inputs: { delay: "delay", 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: i1$3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
2860
2873
|
}
|
|
2861
2874
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ZekToast, decorators: [{
|
|
2862
2875
|
type: Component,
|
|
2863
2876
|
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"] }]
|
|
2864
|
-
}], ctorParameters: function () { return [{ type: AlertService }]; }, propDecorators: {
|
|
2877
|
+
}], ctorParameters: function () { return [{ type: AlertService }]; }, propDecorators: { delay: [{
|
|
2865
2878
|
type: Input
|
|
2866
2879
|
}], icon: [{
|
|
2867
2880
|
type: Input
|