zek 14.2.74 → 14.2.76
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/base.component.mjs +6 -3
- package/esm2020/lib/components/edit-base.component.mjs +27 -36
- package/esm2020/lib/components/list-base.component.mjs +27 -22
- package/esm2020/lib/modules/alert/alert/alert.component.mjs +11 -3
- package/esm2020/lib/modules/list-toolbar/list-toolbar.component.mjs +3 -2
- package/esm2020/lib/services/http-error-handler.service.mjs +3 -18
- package/fesm2015/zek.mjs +70 -78
- package/fesm2015/zek.mjs.map +1 -1
- package/fesm2020/zek.mjs +70 -78
- package/fesm2020/zek.mjs.map +1 -1
- package/lib/components/base.component.d.ts +1 -0
- package/lib/components/edit-base.component.d.ts +4 -4
- package/lib/components/list-base.component.d.ts +3 -3
- package/lib/modules/alert/alert/alert.component.d.ts +4 -0
- package/package.json +1 -1
|
@@ -62,7 +62,8 @@ export class ListToolbarComponent {
|
|
|
62
62
|
}
|
|
63
63
|
create() {
|
|
64
64
|
const url = UrlHelper.getNoParam(this.router.url);
|
|
65
|
-
this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);
|
|
65
|
+
// this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);
|
|
66
|
+
this.router.navigate([url, 'create'], { queryParams: { returnUrl: url + '?filter=1' } });
|
|
66
67
|
}
|
|
67
68
|
filter() {
|
|
68
69
|
this.onFilter.emit();
|
|
@@ -105,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
105
106
|
}], onExport: [{
|
|
106
107
|
type: Output
|
|
107
108
|
}] } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.ts","../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { BooleanInput } from '../../components';\r\n\r\nimport { PrintType } from '../../models/print.model';\r\nimport { Convert, UrlHelper } from '../../utils';\r\n\r\n@Component({\r\n    selector: 'zek-list-toolbar',\r\n    templateUrl: './list-toolbar.component.html'\r\n})\r\nexport class ListToolbarComponent {\r\n    constructor(private readonly router: Router) {\r\n    }\r\n\r\n    printType = PrintType;\r\n    \r\n    private _isFiltered = false;\r\n    @Input()\r\n    get isFiltered() {\r\n        return this._isFiltered;\r\n    }\r\n    set isFiltered(v: BooleanInput) {\r\n        this._isFiltered = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showCreate = true;\r\n    @Input()\r\n    get showCreate() {\r\n        return this._showCreate;\r\n    }\r\n    set showCreate(v: BooleanInput) {\r\n        this._showCreate = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    private _showFilter = true;\r\n    @Input()\r\n    get showFilter() {\r\n        return this._showFilter;\r\n    }\r\n    set showFilter(v: BooleanInput) {\r\n        this._showFilter = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showPrint = false;\r\n    @Input()\r\n    get showPrint() {\r\n        return this._showPrint;\r\n    }\r\n    set showPrint(v: BooleanInput) {\r\n        this._showPrint = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    private _showSum = false;\r\n    @Input()\r\n    get showSum() {\r\n        return this._showSum;\r\n    }\r\n    set showSum(v: BooleanInput) {\r\n        this._showSum = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showExport: boolean = false;\r\n    @Input()\r\n    get showExport(): boolean {\r\n        return this._showExport;\r\n    }\r\n    set showExport(v: BooleanInput) {\r\n        this._showExport = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    @Output() onRefresh = new EventEmitter();\r\n\r\n    @Output() onFilter = new EventEmitter();\r\n\r\n    refresh() {\r\n        this.onRefresh.emit();\r\n    }\r\n\r\n    create() {\r\n        const url = UrlHelper.getNoParam(this.router.url);\r\n        this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);\r\n    }\r\n\r\n\r\n    filter() {\r\n        this.onFilter.emit();\r\n    }\r\n\r\n    @Output()\r\n    onPrint = new EventEmitter<PrintType>();\r\n    print(printType?: PrintType) {\r\n        this.onPrint.emit(printType);\r\n    }\r\n\r\n    @Output()\r\n    onSum = new EventEmitter();\r\n    sum() {\r\n        this.onSum.emit();\r\n    }\r\n\r\n\r\n    @Output()\r\n    onExport = new EventEmitter<number>();\r\n    exportExcel() {\r\n        this.onExport.emit(1);\r\n    }\r\n}","<div class=\"btn-toolbar\" role=\"toolbar\" aria-label=\"Toolbar\">\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Action group\">\r\n        <button *ngIf=\"showCreate\" type=\"button\" class=\"btn btn-primary\" (click)=\"create()\"><i class=\"fa-solid fa-plus\"></i> {{ 'Action.Create' | translate }}</button>\r\n    </div>\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Filter group\">\r\n        <button *ngIf=\"showFilter\" type=\"button\" class=\"btn btn-secondary\" [ngClass]=\"{'btn-outline-success': isFiltered, 'btn-secondary': !isFiltered }\" (click)=\"filter()\" data-bs-toggle0=\"modal\" data-bs-backdrop0=\"static\" data-bs-target0=\"#filter-modal\"><i class=\"fa-solid fa-filter\"></i> {{ 'Action.Filter' | translate }}</button>\r\n        <button type=\"button\" class=\"btn btn-secondary\" title=\"{{ 'Action.Refresh' | translate }}\" (click)=\"refresh()\"><i class=\"fa-solid fa-rotate\"></i></button>\r\n    </div>\r\n    <div *ngIf=\"showPrint\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Print group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button>\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button type=\"button\" class=\"btn btn-secondary dropdown-toggle dropdown-toggle-split\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n                <span class=\"visually-hidden\">Toggle Dropdown</span>\r\n            </button>\r\n            <ul class=\"dropdown-menu\">\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Show)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button></li>\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-file-pdf\"></i> {{ 'Action.Print' | translate }} PDF</button></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"showSum\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Sum group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"sum()\"><i class=\"fa-solid fa-sigma\"></i> {{ 'Action.Sum' | translate }}</button>\r\n    </div>\r\n    <div *ngIf=\"showExport\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Export group\">\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button id=\"btn-group-export\" type=\"button\" class=\"btn btn-secondary dropdown-toggle\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\"><i class=\"fa-solid fa-download\"></i> {{ 'Action.Export' | translate }}</button>\r\n            <ul class=\"dropdown-menu\" aria-labelledby=\"btn-group-export\">\r\n                <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" (click)=\"exportExcel()\"><i class=\"fa-solid fa-file-excel\"></i> Excel</a></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <ng-content></ng-content>\r\n</div>"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.ts","../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { BooleanInput } from '../../components';\r\n\r\nimport { PrintType } from '../../models/print.model';\r\nimport { Convert, UrlHelper } from '../../utils';\r\n\r\n@Component({\r\n    selector: 'zek-list-toolbar',\r\n    templateUrl: './list-toolbar.component.html'\r\n})\r\nexport class ListToolbarComponent {\r\n    constructor(private readonly router: Router) {\r\n    }\r\n\r\n    printType = PrintType;\r\n\r\n    private _isFiltered = false;\r\n    @Input()\r\n    get isFiltered() {\r\n        return this._isFiltered;\r\n    }\r\n    set isFiltered(v: BooleanInput) {\r\n        this._isFiltered = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showCreate = true;\r\n    @Input()\r\n    get showCreate() {\r\n        return this._showCreate;\r\n    }\r\n    set showCreate(v: BooleanInput) {\r\n        this._showCreate = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    private _showFilter = true;\r\n    @Input()\r\n    get showFilter() {\r\n        return this._showFilter;\r\n    }\r\n    set showFilter(v: BooleanInput) {\r\n        this._showFilter = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showPrint = false;\r\n    @Input()\r\n    get showPrint() {\r\n        return this._showPrint;\r\n    }\r\n    set showPrint(v: BooleanInput) {\r\n        this._showPrint = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    private _showSum = false;\r\n    @Input()\r\n    get showSum() {\r\n        return this._showSum;\r\n    }\r\n    set showSum(v: BooleanInput) {\r\n        this._showSum = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showExport: boolean = false;\r\n    @Input()\r\n    get showExport(): boolean {\r\n        return this._showExport;\r\n    }\r\n    set showExport(v: BooleanInput) {\r\n        this._showExport = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    @Output() onRefresh = new EventEmitter();\r\n\r\n    @Output() onFilter = new EventEmitter();\r\n\r\n    refresh() {\r\n        this.onRefresh.emit();\r\n    }\r\n\r\n    create() {\r\n        const url = UrlHelper.getNoParam(this.router.url);\r\n        // this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);\r\n        this.router.navigate([url, 'create'],\r\n            { queryParams: { returnUrl: url + '?filter=1' } }\r\n        );\r\n    }\r\n\r\n\r\n    filter() {\r\n        this.onFilter.emit();\r\n    }\r\n\r\n    @Output()\r\n    onPrint = new EventEmitter<PrintType>();\r\n    print(printType?: PrintType) {\r\n        this.onPrint.emit(printType);\r\n    }\r\n\r\n    @Output()\r\n    onSum = new EventEmitter();\r\n    sum() {\r\n        this.onSum.emit();\r\n    }\r\n\r\n\r\n    @Output()\r\n    onExport = new EventEmitter<number>();\r\n    exportExcel() {\r\n        this.onExport.emit(1);\r\n    }\r\n}","<div class=\"btn-toolbar\" role=\"toolbar\" aria-label=\"Toolbar\">\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Action group\">\r\n        <button *ngIf=\"showCreate\" type=\"button\" class=\"btn btn-primary\" (click)=\"create()\"><i class=\"fa-solid fa-plus\"></i> {{ 'Action.Create' | translate }}</button>\r\n    </div>\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Filter group\">\r\n        <button *ngIf=\"showFilter\" type=\"button\" class=\"btn btn-secondary\" [ngClass]=\"{'btn-outline-success': isFiltered, 'btn-secondary': !isFiltered }\" (click)=\"filter()\" data-bs-toggle0=\"modal\" data-bs-backdrop0=\"static\" data-bs-target0=\"#filter-modal\"><i class=\"fa-solid fa-filter\"></i> {{ 'Action.Filter' | translate }}</button>\r\n        <button type=\"button\" class=\"btn btn-secondary\" title=\"{{ 'Action.Refresh' | translate }}\" (click)=\"refresh()\"><i class=\"fa-solid fa-rotate\"></i></button>\r\n    </div>\r\n    <div *ngIf=\"showPrint\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Print group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button>\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button type=\"button\" class=\"btn btn-secondary dropdown-toggle dropdown-toggle-split\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n                <span class=\"visually-hidden\">Toggle Dropdown</span>\r\n            </button>\r\n            <ul class=\"dropdown-menu\">\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Show)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button></li>\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-file-pdf\"></i> {{ 'Action.Print' | translate }} PDF</button></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"showSum\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Sum group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"sum()\"><i class=\"fa-solid fa-sigma\"></i> {{ 'Action.Sum' | translate }}</button>\r\n    </div>\r\n    <div *ngIf=\"showExport\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Export group\">\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button id=\"btn-group-export\" type=\"button\" class=\"btn btn-secondary dropdown-toggle\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\"><i class=\"fa-solid fa-download\"></i> {{ 'Action.Export' | translate }}</button>\r\n            <ul class=\"dropdown-menu\" aria-labelledby=\"btn-group-export\">\r\n                <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" (click)=\"exportExcel()\"><i class=\"fa-solid fa-file-excel\"></i> Excel</a></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <ng-content></ng-content>\r\n</div>"]}
|
|
@@ -53,25 +53,10 @@ export class HttpErrorHandler {
|
|
|
53
53
|
else {
|
|
54
54
|
error = response.error;
|
|
55
55
|
}
|
|
56
|
-
let data;
|
|
57
56
|
if (error instanceof ErrorEvent) {
|
|
58
|
-
|
|
59
|
-
errors: [
|
|
60
|
-
{ '': [response.error.message] }
|
|
61
|
-
]
|
|
62
|
-
};
|
|
57
|
+
error = response.error.message;
|
|
63
58
|
}
|
|
64
|
-
|
|
65
|
-
data = {
|
|
66
|
-
errors: [
|
|
67
|
-
{ '': [response.error] }
|
|
68
|
-
]
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
|
-
else if (typeof error === 'object') {
|
|
72
|
-
data = error;
|
|
73
|
-
}
|
|
74
|
-
return ObjectHelper.isDefined(data) ? of(data) : of(result);
|
|
59
|
+
return ObjectHelper.isDefined(error) ? of(error) : of(result);
|
|
75
60
|
};
|
|
76
61
|
}
|
|
77
62
|
showError(serviceName, operation, response) {
|
|
@@ -153,4 +138,4 @@ HttpErrorHandler.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", ver
|
|
|
153
138
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: HttpErrorHandler, decorators: [{
|
|
154
139
|
type: Injectable
|
|
155
140
|
}], ctorParameters: function () { return [{ type: i1.AlertService }, { type: i2.TranslateService }, { type: i3.Router }]; } });
|
|
156
|
-
//# 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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAG3C,OAAO,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AAGtC,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;;;;;AAMtD,gCAAgC;AAEhC,MAAM,OAAO,gBAAgB;IACzB,YACqB,KAAmB,EACnB,SAA2B,EAC3B,MAAc;QAFd,UAAK,GAAL,KAAK,CAAc;QACnB,cAAS,GAAT,SAAS,CAAkB;QAC3B,WAAM,GAAN,MAAM,CAAQ;QAEnC,8EAA8E;QAC9E,sBAAiB,GAAG,CAAC,WAAW,GAAG,EAAE,EAAE,EAAE,CAAC,CAAI,SAAS,GAAG,WAAW,EAAE,SAAS,EAAO,EAAE,IAAI,GAAG,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;QAChK,4BAAuB,GAAG,CAAC,WAAW,GAAG,EAAE,EAAE,EAAE,CAAC,CAAI,SAAS,GAAG,WAAW,EAAE,SAAS,EAAO,EAAE,IAAI,GAAG,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;IAJrI,CAAC;IAMxC;;;;;;;OAOG;IACH,WAAW,CAAI,WAAW,GAAG,EAAE,EAAE,SAAS,GAAG,WAAW,EAAE,SAAS,EAAO,EAAE,IAAc;QACtF,OAAO,CAAC,QAA2B,EAAiB,EAAE;YAClD,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAExB,IAAI,IAAI,EAAE;gBACN,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAA;aACnD;YAED,OAAO,EAAE,CAAC,MAAM,CAAC,CAAC;QACtB,CAAC,CAAC;IACN,CAAC;IAID;;;;;;OAMG;IACH,iBAAiB,CAAI,WAAW,GAAG,EAAE,EAAE,SAAS,GAAG,WAAW,EAAE,SAAS,EAAO,EAAE,IAAc;QAC5F,OAAO,CAAC,QAA2B,EAAmB,EAAE;YACpD,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAExB,IAAI,IAAI,EAAE;gBACN,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAA;aACnD;YAED,IAAI,KAAU,CAAC;YACf,IAAI,OAAO,QAAQ,CAAC,KAAK,KAAK,QAAQ,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;gBACjE,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aACtC;iBAAM;gBACH,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;aAC1B;YAED,IAAI,IAAS,CAAC;YACd,IAAI,KAAK,YAAY,UAAU,EAAE;gBAC7B,IAAI,GAAG;oBACH,MAAM,EAAE;wBACJ,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAiB,CAAC,EAAE;qBAC7C;iBACJ,CAAC;aACL;YAAC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAC7B,IAAI,GAAG;oBACH,MAAM,EAAE;wBACJ,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAe,CAAC,EAAE;qBACrC;iBACJ,CAAA;aACJ;iBAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAClC,IAAI,GAAG,KAAK,CAAC;aAChB;YAED,OAAO,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;QAChE,CAAC,CAAC;IACN,CAAC;IAGO,SAAS,CAAC,WAAmB,EAAE,SAAiB,EAAE,QAA2B;QACjF,QAAQ,QAAQ,CAAC,MAAM,EAAE;YACrB,KAAK,CAAC,EAAC,eAAe;gBAClB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;gBACjD,MAAM;YAEV,KAAK,GAAG,EAAC,aAAa;gBAClB,IAAI,KAAU,CAAC;gBACf,IAAI,OAAO,QAAQ,CAAC,KAAK,KAAK,QAAQ,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;oBACjE,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;iBACtC;qBAAM;oBACH,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;iBAC1B;gBAED,IAAI,KAAK,YAAY,UAAU,EAAE;oBAC7B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,WAAW,KAAK,SAAS,YAAY,QAAQ,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;iBACtF;gBAAC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAC7B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAe,CAAC,CAAC;iBAC9C;qBAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAClC,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,KAAK,KAAK;wBACnD,CAAC,CAAC,KAAK,CAAC,MAAM;wBACd,CAAC,CAAC,KAAK,CAAC;oBAEZ,MAAM,aAAa,GAAa,EAAE,CAAC;oBACnC,MAAM,UAAU,GAAG,MAAM,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;oBAEtD,KAAK,IAAI,QAAQ,IAAI,UAAU,EAAE;wBAC7B,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;wBAClC,IAAI,QAAQ,YAAY,KAAK,EAAE;4BAC3B,KAAK,IAAI,OAAO,IAAI,QAAQ,EAAE;gCAC1B,MAAM,UAAU,GAAG,cAAc,OAAO,EAAE,CAAC;gCAC3C,IAAI,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gCAC3D,4CAA4C;gCAC5C,IAAI,UAAU,IAAI,iBAAiB,EAAE;oCACjC,iBAAiB,GAAG,OAAO,CAAC;iCAC/B;gCAED,IAAI,QAAQ,EAAE;oCACV,MAAM,WAAW,GAAG,UAAU,QAAQ,EAAE,CAAC;oCACzC,IAAI,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,UAAU,QAAQ,EAAE,CAAC,CAAC;oCACtE,6CAA6C;oCAC7C,IAAI,WAAW,IAAI,kBAAkB,EAAE;wCACnC,kBAAkB,GAAG,QAAQ,CAAA;qCAChC;oCACD,aAAa,CAAC,IAAI,CAAC,kBAAkB,GAAG,KAAK,GAAG,iBAAiB,CAAC,CAAC;iCACtE;qCACI;oCACD,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;iCACzC;6BACJ;yBACJ;qBACJ;oBACD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;iBACxD;gBACD,MAAM;YAEV,KAAK,GAAG,EAAC,cAAc;gBACnB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;gBACjC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACjC,MAAM;YAEV,KAAK,GAAG,EAAC,WAAW;gBAChB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;gBAC9B,MAAM;YAEV,KAAK,GAAG,EAAC,WAAW;gBAChB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;gBAC9B,MAAM;YAEV,KAAK,GAAG,EAAC,kBAAkB;gBACvB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;gBAC7C,MAAM;YAEV,KAAK,GAAG,EAAC,uBAAuB;gBAC5B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;gBAC1C,MAAM;YAEV;gBACI,MAAM;SACb;IACL,CAAC;;6GA5JQ,gBAAgB;iHAAhB,gBAAgB;2FAAhB,gBAAgB;kBAD5B,UAAU","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            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            let data: any;\r\n            if (error instanceof ErrorEvent) {\r\n                data = {\r\n                    errors: [\r\n                        { '': [response.error.message as string] }\r\n                    ]\r\n                };\r\n            } if (typeof error === 'string') {\r\n                data = {\r\n                    errors: [\r\n                        { '': [response.error as string] }\r\n                    ]\r\n                }\r\n            } else if (typeof error === 'object') {\r\n                data = error;\r\n            }\r\n\r\n            return ObjectHelper.isDefined(data) ? of(data) : 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(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}"]}
|
package/fesm2015/zek.mjs
CHANGED
|
@@ -1631,25 +1631,10 @@ class HttpErrorHandler {
|
|
|
1631
1631
|
else {
|
|
1632
1632
|
error = response.error;
|
|
1633
1633
|
}
|
|
1634
|
-
let data;
|
|
1635
1634
|
if (error instanceof ErrorEvent) {
|
|
1636
|
-
|
|
1637
|
-
errors: [
|
|
1638
|
-
{ '': [response.error.message] }
|
|
1639
|
-
]
|
|
1640
|
-
};
|
|
1641
|
-
}
|
|
1642
|
-
if (typeof error === 'string') {
|
|
1643
|
-
data = {
|
|
1644
|
-
errors: [
|
|
1645
|
-
{ '': [response.error] }
|
|
1646
|
-
]
|
|
1647
|
-
};
|
|
1635
|
+
error = response.error.message;
|
|
1648
1636
|
}
|
|
1649
|
-
|
|
1650
|
-
data = error;
|
|
1651
|
-
}
|
|
1652
|
-
return ObjectHelper.isDefined(data) ? of(data) : of(result);
|
|
1637
|
+
return ObjectHelper.isDefined(error) ? of(error) : of(result);
|
|
1653
1638
|
};
|
|
1654
1639
|
}
|
|
1655
1640
|
showError(serviceName, operation, response) {
|
|
@@ -1951,15 +1936,18 @@ class BaseComponent extends CoreComponent {
|
|
|
1951
1936
|
getParam(name) {
|
|
1952
1937
|
return this.route.snapshot.paramMap.get(name);
|
|
1953
1938
|
}
|
|
1939
|
+
getQueryParam(name) {
|
|
1940
|
+
return this.route.snapshot.queryParamMap.get(name);
|
|
1941
|
+
}
|
|
1954
1942
|
navigateReturnUrl() {
|
|
1955
|
-
const returnUrl = this.
|
|
1943
|
+
const returnUrl = this.getQueryParam('returnUrl') || this.getParam('returnUrl');
|
|
1956
1944
|
if (returnUrl) {
|
|
1957
1945
|
let urlTree = this.router.parseUrl(returnUrl);
|
|
1958
1946
|
const urlWithoutParams = urlTree.root.children[PRIMARY_OUTLET].segments.map(it => it.path).join('/');
|
|
1959
1947
|
this.router.navigate([urlWithoutParams, urlTree.root.children[PRIMARY_OUTLET].segments[urlTree.root.children[PRIMARY_OUTLET].segments.length - 1].parameters]);
|
|
1960
1948
|
return;
|
|
1961
1949
|
}
|
|
1962
|
-
this.router.navigate([this.router.url.
|
|
1950
|
+
this.router.navigate([this.router.url.substring(0, this.router.url.lastIndexOf('/'))]);
|
|
1963
1951
|
}
|
|
1964
1952
|
cancel() {
|
|
1965
1953
|
this.navigateReturnUrl();
|
|
@@ -2218,10 +2206,10 @@ class EditFormComponent extends BaseComponent {
|
|
|
2218
2206
|
// @ViewChild('submitModal', { static: false }) protected readonly submitModal?: ModalComponent;
|
|
2219
2207
|
init() {
|
|
2220
2208
|
super.init();
|
|
2221
|
-
const idParam = this.getParam('id');
|
|
2209
|
+
const idParam = this.getParam('id') || this.getQueryParam('id');
|
|
2222
2210
|
if (idParam)
|
|
2223
2211
|
this.id = +idParam;
|
|
2224
|
-
const id2Param = this.getParam('id2');
|
|
2212
|
+
const id2Param = this.getParam('id2') || this.getQueryParam('id2');
|
|
2225
2213
|
if (id2Param)
|
|
2226
2214
|
this.id2 = +id2Param;
|
|
2227
2215
|
}
|
|
@@ -2252,18 +2240,9 @@ class EditFormComponent extends BaseComponent {
|
|
|
2252
2240
|
return false;
|
|
2253
2241
|
});
|
|
2254
2242
|
}
|
|
2255
|
-
// saveAndNavigateToReturnUrl(f: NgForm) {
|
|
2256
|
-
// if (!f || f.valid) {
|
|
2257
|
-
// this.internalSave(true);
|
|
2258
|
-
// }
|
|
2259
|
-
// }
|
|
2260
2243
|
internalSave(navigateToReturnUrl) {
|
|
2261
2244
|
throw 'Not implemented internalSave';
|
|
2262
2245
|
}
|
|
2263
|
-
// protected navigateEditUrl() {
|
|
2264
|
-
// if (this.getAction().toLowerCase() === 'create')
|
|
2265
|
-
// this.router.navigate([this.router.url.substr(0, this.router.url.lastIndexOf('/') + 1), this.id]);
|
|
2266
|
-
// }
|
|
2267
2246
|
showApproveModal() {
|
|
2268
2247
|
this.approveModel = {};
|
|
2269
2248
|
if (this.approveModal) {
|
|
@@ -2326,15 +2305,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
2326
2305
|
args: ['disapproveModal', { static: false }]
|
|
2327
2306
|
}] } });
|
|
2328
2307
|
class EditBaseComponent extends EditFormComponent {
|
|
2329
|
-
constructor(service,
|
|
2308
|
+
constructor(service, translate, alert, route, router) {
|
|
2330
2309
|
super(route, router);
|
|
2331
2310
|
this.service = service;
|
|
2332
|
-
this.
|
|
2333
|
-
this.
|
|
2311
|
+
this.translate = translate;
|
|
2312
|
+
this.alert = alert;
|
|
2334
2313
|
}
|
|
2335
2314
|
internalSave(navigateToReturnUrl) {
|
|
2336
2315
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2337
|
-
this.
|
|
2316
|
+
this.alert.clear();
|
|
2338
2317
|
let data = yield firstValueFrom(this.service.save(this.model));
|
|
2339
2318
|
let success = false;
|
|
2340
2319
|
if (typeof data === 'number' && data > 0) {
|
|
@@ -2345,8 +2324,8 @@ class EditBaseComponent extends EditFormComponent {
|
|
|
2345
2324
|
success = true;
|
|
2346
2325
|
}
|
|
2347
2326
|
if (success) {
|
|
2348
|
-
let message = yield firstValueFrom(this.
|
|
2349
|
-
this.
|
|
2327
|
+
let message = yield firstValueFrom(this.translate.get('Alert.SaveSuccess'));
|
|
2328
|
+
this.alert.success(message, null, 'fas fa-save');
|
|
2350
2329
|
if (navigateToReturnUrl === true) {
|
|
2351
2330
|
this.navigateReturnUrl();
|
|
2352
2331
|
}
|
|
@@ -2358,8 +2337,8 @@ class EditBaseComponent extends EditFormComponent {
|
|
|
2358
2337
|
// }
|
|
2359
2338
|
}
|
|
2360
2339
|
else {
|
|
2361
|
-
let message = yield firstValueFrom(this.
|
|
2362
|
-
this.
|
|
2340
|
+
let message = yield firstValueFrom(this.translate.get('Alert.SaveError'));
|
|
2341
|
+
this.alert.error(message, null, 'fas fa-save');
|
|
2363
2342
|
return false;
|
|
2364
2343
|
}
|
|
2365
2344
|
});
|
|
@@ -2368,13 +2347,13 @@ class EditBaseComponent extends EditFormComponent {
|
|
|
2368
2347
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2369
2348
|
let data = yield firstValueFrom(this.service.approve(model));
|
|
2370
2349
|
if (data && data.length > 0) {
|
|
2371
|
-
let message = yield firstValueFrom(this.
|
|
2372
|
-
this.
|
|
2350
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Approved'));
|
|
2351
|
+
this.alert.success(message, null, 'fas fa-save');
|
|
2373
2352
|
return true;
|
|
2374
2353
|
}
|
|
2375
2354
|
else {
|
|
2376
|
-
let message = yield firstValueFrom(this.
|
|
2377
|
-
this.
|
|
2355
|
+
let message = yield firstValueFrom(this.translate.get('Alert.ApproveError'));
|
|
2356
|
+
this.alert.error(message, null, 'fas fa-save');
|
|
2378
2357
|
return false;
|
|
2379
2358
|
}
|
|
2380
2359
|
});
|
|
@@ -2383,13 +2362,13 @@ class EditBaseComponent extends EditFormComponent {
|
|
|
2383
2362
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2384
2363
|
let data = yield firstValueFrom(this.service.disapprove(model));
|
|
2385
2364
|
if (data && data.length > 0) {
|
|
2386
|
-
let message = yield firstValueFrom(this.
|
|
2387
|
-
this.
|
|
2365
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Disapproved'));
|
|
2366
|
+
this.alert.success(message, null, 'fas fa-save');
|
|
2388
2367
|
return true;
|
|
2389
2368
|
}
|
|
2390
2369
|
else {
|
|
2391
|
-
let message = yield firstValueFrom(this.
|
|
2392
|
-
this.
|
|
2370
|
+
let message = yield firstValueFrom(this.translate.get('Alert.DisapproveError'));
|
|
2371
|
+
this.alert.error(message, null, 'fas fa-save');
|
|
2393
2372
|
return false;
|
|
2394
2373
|
}
|
|
2395
2374
|
});
|
|
@@ -2398,13 +2377,13 @@ class EditBaseComponent extends EditFormComponent {
|
|
|
2398
2377
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2399
2378
|
let data = yield firstValueFrom(this.service.approve(model));
|
|
2400
2379
|
if (data && data.length > 0) {
|
|
2401
|
-
let message = yield firstValueFrom(this.
|
|
2402
|
-
this.
|
|
2380
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Submitted'));
|
|
2381
|
+
this.alert.success(message, null, 'fas fa-save');
|
|
2403
2382
|
return true;
|
|
2404
2383
|
}
|
|
2405
2384
|
else {
|
|
2406
|
-
let message = yield firstValueFrom(this.
|
|
2407
|
-
this.
|
|
2385
|
+
let message = yield firstValueFrom(this.translate.get('Alert.SubmitError'));
|
|
2386
|
+
this.alert.error(message, null, 'fas fa-save');
|
|
2408
2387
|
return false;
|
|
2409
2388
|
}
|
|
2410
2389
|
});
|
|
@@ -2427,8 +2406,8 @@ class EditBaseComponent extends EditFormComponent {
|
|
|
2427
2406
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2428
2407
|
let data = yield firstValueFrom(this.service.restore(this.id));
|
|
2429
2408
|
if (data === null || data === void 0 ? void 0 : data.success) {
|
|
2430
|
-
let message = yield firstValueFrom(this.
|
|
2431
|
-
this.
|
|
2409
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Restored'));
|
|
2410
|
+
this.alert.success(message);
|
|
2432
2411
|
this.load();
|
|
2433
2412
|
}
|
|
2434
2413
|
});
|
|
@@ -2445,8 +2424,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
2445
2424
|
type: Directive
|
|
2446
2425
|
}], ctorParameters: function () { return [{ type: undefined }, { type: i1$1.TranslateService }, { type: AlertService }, { type: i1.ActivatedRoute }, { type: i1.Router }]; } });
|
|
2447
2426
|
class EditComponent extends EditBaseComponent {
|
|
2448
|
-
constructor(ctorModel, service,
|
|
2449
|
-
super(service,
|
|
2427
|
+
constructor(ctorModel, service, translate, alert, route, router) {
|
|
2428
|
+
super(service, translate, alert, route, router);
|
|
2450
2429
|
this.ctorModel = ctorModel;
|
|
2451
2430
|
}
|
|
2452
2431
|
initCreate() {
|
|
@@ -2461,11 +2440,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
2461
2440
|
|
|
2462
2441
|
// declare let bootstrap: any;
|
|
2463
2442
|
class ListBaseComponent extends BaseComponent {
|
|
2464
|
-
constructor(service,
|
|
2443
|
+
constructor(service, translate, alert, route, router) {
|
|
2465
2444
|
super(route, router);
|
|
2466
2445
|
this.service = service;
|
|
2467
|
-
this.
|
|
2468
|
-
this.
|
|
2446
|
+
this.translate = translate;
|
|
2447
|
+
this.alert = alert;
|
|
2469
2448
|
this.filter = new FilterBase();
|
|
2470
2449
|
this.saveFilter = true;
|
|
2471
2450
|
this.internalFilter = new FilterBase();
|
|
@@ -2497,7 +2476,7 @@ class ListBaseComponent extends BaseComponent {
|
|
|
2497
2476
|
initDefaultFilter() {
|
|
2498
2477
|
}
|
|
2499
2478
|
initStoredFilter() {
|
|
2500
|
-
let filterParam = this.getParam('filter');
|
|
2479
|
+
let filterParam = this.getQueryParam('filter') || this.getParam('filter');
|
|
2501
2480
|
if (filterParam) {
|
|
2502
2481
|
const tmp = StorageHelper.get('filter');
|
|
2503
2482
|
if (tmp && tmp.url && tmp.url === this.url && tmp.filter) {
|
|
@@ -2556,35 +2535,40 @@ class ListBaseComponent extends BaseComponent {
|
|
|
2556
2535
|
}
|
|
2557
2536
|
create() {
|
|
2558
2537
|
const url = UrlHelper.getNoParam(this.router.url);
|
|
2559
|
-
this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);
|
|
2538
|
+
// this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);
|
|
2539
|
+
this.router.navigate([url, 'create'], { queryParams: { returnUrl: url + '?filter=1' } });
|
|
2560
2540
|
}
|
|
2561
2541
|
delete(id) {
|
|
2562
2542
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2563
|
-
this.
|
|
2543
|
+
this.alert.clear();
|
|
2564
2544
|
let data = yield firstValueFrom(this.service.delete(id));
|
|
2565
2545
|
if (data === null || data === void 0 ? void 0 : data.success) {
|
|
2566
|
-
let message = yield firstValueFrom(this.
|
|
2567
|
-
this.
|
|
2546
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Deleted'));
|
|
2547
|
+
this.alert.error(message, null, 'fas fa-trash');
|
|
2568
2548
|
this.refresh();
|
|
2569
2549
|
}
|
|
2570
2550
|
});
|
|
2571
2551
|
}
|
|
2572
2552
|
delete2(id, id2) {
|
|
2573
2553
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2574
|
-
this.
|
|
2554
|
+
this.alert.clear();
|
|
2575
2555
|
let data = yield firstValueFrom(this.service.delete2(id, id2));
|
|
2576
2556
|
if (data === null || data === void 0 ? void 0 : data.success) {
|
|
2577
|
-
let message = yield firstValueFrom(this.
|
|
2578
|
-
this.
|
|
2557
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Deleted'));
|
|
2558
|
+
this.alert.error(message, null, 'fas fa-trash');
|
|
2579
2559
|
this.refresh();
|
|
2580
2560
|
}
|
|
2581
2561
|
});
|
|
2582
2562
|
}
|
|
2583
2563
|
edit(id) {
|
|
2584
|
-
this.router.navigate([this.url, id,
|
|
2564
|
+
// this.router.navigate([this.url, id],
|
|
2565
|
+
// { queryParams: { returnUrl: this.url + ';filter=1' } }
|
|
2566
|
+
// );
|
|
2567
|
+
this.router.navigate([this.url, id], { queryParams: { returnUrl: this.url + '?filter=1' } });
|
|
2585
2568
|
}
|
|
2586
2569
|
edit2(id, id2) {
|
|
2587
|
-
this.router.navigate([this.url, id, id2, { returnUrl: this.url + ';filter=1' }]);
|
|
2570
|
+
// this.router.navigate([this.url, id, id2, { returnUrl: this.url + ';filter=1' }]);
|
|
2571
|
+
this.router.navigate([this.url, id, id2], { queryParams: { returnUrl: this.url + '?filter=1' } });
|
|
2588
2572
|
}
|
|
2589
2573
|
select(item) {
|
|
2590
2574
|
item.selected = !item.selected;
|
|
@@ -2616,12 +2600,12 @@ class ListBaseComponent extends BaseComponent {
|
|
|
2616
2600
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2617
2601
|
if (!m)
|
|
2618
2602
|
return;
|
|
2619
|
-
this.
|
|
2603
|
+
this.alert.clear();
|
|
2620
2604
|
let data = yield firstValueFrom(this.service.approve(m));
|
|
2621
2605
|
if (!data || data.length === 0)
|
|
2622
2606
|
return;
|
|
2623
|
-
let message = yield firstValueFrom(this.
|
|
2624
|
-
this.
|
|
2607
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Approved'));
|
|
2608
|
+
this.alert.success(message, undefined, 'fas fa-thumbs-up');
|
|
2625
2609
|
this.refresh();
|
|
2626
2610
|
});
|
|
2627
2611
|
}
|
|
@@ -2648,12 +2632,12 @@ class ListBaseComponent extends BaseComponent {
|
|
|
2648
2632
|
if (!m.comment)
|
|
2649
2633
|
delete m.comment;
|
|
2650
2634
|
}
|
|
2651
|
-
this.
|
|
2635
|
+
this.alert.clear();
|
|
2652
2636
|
let data = yield firstValueFrom(this.service.disapprove(m));
|
|
2653
2637
|
if (!data || data.length === 0)
|
|
2654
2638
|
return;
|
|
2655
|
-
let message = yield firstValueFrom(this.
|
|
2656
|
-
this.
|
|
2639
|
+
let message = yield firstValueFrom(this.translate.get('Alert.Disapproved'));
|
|
2640
|
+
this.alert.success(message, undefined, 'fas fa-thumbs-down');
|
|
2657
2641
|
this.refresh();
|
|
2658
2642
|
});
|
|
2659
2643
|
}
|
|
@@ -2677,8 +2661,8 @@ class ListBaseComponent extends BaseComponent {
|
|
|
2677
2661
|
this.showSum();
|
|
2678
2662
|
}
|
|
2679
2663
|
else {
|
|
2680
|
-
let message = yield firstValueFrom(this.
|
|
2681
|
-
this.
|
|
2664
|
+
let message = yield firstValueFrom(this.translate.get('Alert.SumError'));
|
|
2665
|
+
this.alert.error(message);
|
|
2682
2666
|
}
|
|
2683
2667
|
});
|
|
2684
2668
|
}
|
|
@@ -2750,6 +2734,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
2750
2734
|
class AlertComponent {
|
|
2751
2735
|
constructor() {
|
|
2752
2736
|
this._type = AlertType.Info;
|
|
2737
|
+
this._showClose = true;
|
|
2753
2738
|
this.cssAlert = '';
|
|
2754
2739
|
this.cssIcon = '';
|
|
2755
2740
|
}
|
|
@@ -2774,12 +2759,18 @@ class AlertComponent {
|
|
|
2774
2759
|
}
|
|
2775
2760
|
}
|
|
2776
2761
|
}
|
|
2762
|
+
get showClose() {
|
|
2763
|
+
return this._showClose;
|
|
2764
|
+
}
|
|
2765
|
+
set showClose(v) {
|
|
2766
|
+
this._showClose = Convert.toBoolean(v);
|
|
2767
|
+
}
|
|
2777
2768
|
}
|
|
2778
2769
|
AlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
2779
|
-
AlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: AlertComponent, selector: "zek-alert", inputs: { type: "type", title: "title" }, ngImport: i0, template: "<div class=\"alert {{cssAlert}} alert-dismissible fade show\" role=\"alert\">\r\n <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"alert\" aria-label=\"Close\"></button>\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1\" *ngIf=\"cssIcon\">\r\n <span class=\"flex-shrink-0\"><i class=\"{{cssIcon}}\"></i></span>\r\n </div>\r\n <div class=\"col-auto\">\r\n <div *ngIf=\"title\">\r\n <h5 class=\"alert-heading\">{{title}}</h5>\r\n </div>\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1$3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
2770
|
+
AlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: AlertComponent, selector: "zek-alert", inputs: { type: "type", title: "title" }, ngImport: i0, template: "<div class=\"alert {{cssAlert}} alert-dismissible fade show\" role=\"alert\">\r\n <button *ngIf=\"_showClose\" type=\"button\" class=\"btn-close\" data-bs-dismiss=\"alert\" aria-label=\"Close\"></button>\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1\" *ngIf=\"cssIcon\">\r\n <span class=\"flex-shrink-0\"><i class=\"{{cssIcon}}\"></i></span>\r\n </div>\r\n <div class=\"col-auto\">\r\n <div *ngIf=\"title\">\r\n <h5 class=\"alert-heading\">{{title}}</h5>\r\n </div>\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1$3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
2780
2771
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: AlertComponent, decorators: [{
|
|
2781
2772
|
type: Component,
|
|
2782
|
-
args: [{ selector: 'zek-alert', template: "<div class=\"alert {{cssAlert}} alert-dismissible fade show\" role=\"alert\">\r\n <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"alert\" aria-label=\"Close\"></button>\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1\" *ngIf=\"cssIcon\">\r\n <span class=\"flex-shrink-0\"><i class=\"{{cssIcon}}\"></i></span>\r\n </div>\r\n <div class=\"col-auto\">\r\n <div *ngIf=\"title\">\r\n <h5 class=\"alert-heading\">{{title}}</h5>\r\n </div>\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:block}\n"] }]
|
|
2773
|
+
args: [{ selector: 'zek-alert', template: "<div class=\"alert {{cssAlert}} alert-dismissible fade show\" role=\"alert\">\r\n <button *ngIf=\"_showClose\" type=\"button\" class=\"btn-close\" data-bs-dismiss=\"alert\" aria-label=\"Close\"></button>\r\n <div class=\"row\">\r\n <div class=\"col-auto pe-1\" *ngIf=\"cssIcon\">\r\n <span class=\"flex-shrink-0\"><i class=\"{{cssIcon}}\"></i></span>\r\n </div>\r\n <div class=\"col-auto\">\r\n <div *ngIf=\"title\">\r\n <h5 class=\"alert-heading\">{{title}}</h5>\r\n </div>\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:block}\n"] }]
|
|
2783
2774
|
}], propDecorators: { type: [{
|
|
2784
2775
|
type: Input
|
|
2785
2776
|
}], title: [{
|
|
@@ -4637,7 +4628,8 @@ class ListToolbarComponent {
|
|
|
4637
4628
|
}
|
|
4638
4629
|
create() {
|
|
4639
4630
|
const url = UrlHelper.getNoParam(this.router.url);
|
|
4640
|
-
this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);
|
|
4631
|
+
// this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);
|
|
4632
|
+
this.router.navigate([url, 'create'], { queryParams: { returnUrl: url + '?filter=1' } });
|
|
4641
4633
|
}
|
|
4642
4634
|
filter() {
|
|
4643
4635
|
this.onFilter.emit();
|