@sd-angular/core 1.1.61 → 1.1.62
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/assets/scss/core/text.scss +3 -1
- package/bundles/sd-angular-core-header-title.umd.js +1 -1
- package/bundles/sd-angular-core-header-title.umd.js.map +1 -1
- package/bundles/sd-angular-core-header-title.umd.min.js +1 -1
- package/bundles/sd-angular-core-header-title.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-notify.umd.js +99 -58
- package/bundles/sd-angular-core-notify.umd.js.map +1 -1
- package/bundles/sd-angular-core-notify.umd.min.js +2 -2
- package/bundles/sd-angular-core-notify.umd.min.js.map +1 -1
- package/esm2015/header-title/src/lib/header-title.component.js +2 -2
- package/esm2015/notify/src/lib/components/dialog-confirm/dialog-confirm.component.js +15 -8
- package/esm2015/notify/src/lib/notify.module.js +3 -1
- package/esm2015/notify/src/lib/notify.service.js +94 -61
- package/fesm2015/sd-angular-core-header-title.js +1 -1
- package/fesm2015/sd-angular-core-header-title.js.map +1 -1
- package/fesm2015/sd-angular-core-notify.js +99 -58
- package/fesm2015/sd-angular-core-notify.js.map +1 -1
- package/header-title/sd-angular-core-header-title.metadata.json +1 -1
- package/notify/sd-angular-core-notify.metadata.json +1 -1
- package/notify/src/lib/components/dialog-confirm/dialog-confirm.component.d.ts +13 -4
- package/notify/src/lib/notify.service.d.ts +19 -8
- package/package.json +1 -1
- package/{sd-angular-core-1.1.61.tgz → sd-angular-core-1.1.62.tgz} +0 -0
|
@@ -1,19 +1,26 @@
|
|
|
1
|
-
import { Component, Inject } from
|
|
2
|
-
import { MatDialogRef, MAT_DIALOG_DATA } from
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import * as uuid from 'uuid';
|
|
3
4
|
export class DialogConfirmComponent {
|
|
4
5
|
constructor(dialogRef, data) {
|
|
5
|
-
var _a, _b, _c;
|
|
6
|
+
var _a, _b, _c, _d, _e;
|
|
6
7
|
this.dialogRef = dialogRef;
|
|
7
8
|
this.data = data;
|
|
8
9
|
this.isString = false;
|
|
9
|
-
this.
|
|
10
|
-
this.
|
|
10
|
+
this.id = `I${uuid.v4()}`;
|
|
11
|
+
this.isString = typeof ((_a = this.data) === null || _a === void 0 ? void 0 : _a.message) === 'string';
|
|
12
|
+
if (data === null || data === void 0 ? void 0 : data.input) {
|
|
13
|
+
this.value = (_c = (_b = data === null || data === void 0 ? void 0 : data.input) === null || _b === void 0 ? void 0 : _b.defaultValue) !== null && _c !== void 0 ? _c : '';
|
|
14
|
+
}
|
|
15
|
+
if (data === null || data === void 0 ? void 0 : data.date) {
|
|
16
|
+
this.value = (_e = (_d = data === null || data === void 0 ? void 0 : data.date) === null || _d === void 0 ? void 0 : _d.defaultValue) !== null && _e !== void 0 ? _e : '';
|
|
17
|
+
}
|
|
11
18
|
}
|
|
12
19
|
}
|
|
13
20
|
DialogConfirmComponent.decorators = [
|
|
14
21
|
{ type: Component, args: [{
|
|
15
|
-
selector:
|
|
16
|
-
template: "<h1 mat-dialog-title class=\"\">\r\n <mat-icon *ngIf=\"data?.icon\" [ngClass]=\"data?.icon\">\r\n {{ data?.icon }}\r\n </mat-icon>\r\n <span [innerHtml]=\"data?.title || 'Confirm'\"></span>\r\n</h1>\r\n<div mat-dialog-content>\r\n <div *ngIf=\"isString\" [innerHtml]=\"data?.message\"></div>\r\n <div *ngIf=\"!isString\" [innerHtml]=\"data?.message | json\"></div>\r\n <div *ngIf=\"data?.input\">\r\n <mat-form-field appearance=\"outline\">\r\n <textarea
|
|
22
|
+
selector: 'sd-dialog-confirm',
|
|
23
|
+
template: "<h1 mat-dialog-title class=\"\">\r\n <mat-icon *ngIf=\"data?.icon\" [ngClass]=\"data?.icon\">\r\n {{ data?.icon }}\r\n </mat-icon>\r\n <span [innerHtml]=\"data?.title || 'Confirm'\"></span>\r\n</h1>\r\n<div mat-dialog-content>\r\n <div *ngIf=\"isString\" [innerHtml]=\"data?.message\"></div>\r\n <div *ngIf=\"!isString\" [innerHtml]=\"data?.message | json\"></div>\r\n <div *ngIf=\"data?.input\">\r\n <mat-form-field appearance=\"outline\">\r\n <textarea style=\"width: 100%\" matInput [placeholder]=\"data.input?.placeholder\" [(ngModel)]=\"value\"\r\n autocomplete=\"off\" rows=\"5\" [maxlength]=\"data.input?.maxlength\"></textarea>\r\n </mat-form-field>\r\n </div>\r\n <div *ngIf=\"data?.date\">\r\n <mat-form-field class=\"sd-md\" appearance=\"outline\">\r\n <input [id]=\"id\" matInpu [autocomplete]=\"id\" autocorrect=\"off\" [matDatepicker]=\"picker2\"\r\n [placeholder]=\"data.date?.placeholder\" [min]=\"data.date?.min\" [max]=\"data.date?.max\" />\r\n <mat-icon class=\"pointer sd-suffix-icon\" (click)=\"picker2.open()\" #btn matSuffix>today\r\n </mat-icon>\r\n <mat-datepicker #picker2></mat-datepicker>\r\n </mat-form-field>\r\n </div>\r\n</div>\r\n<div mat-dialog-actions align=\"end\">\r\n <sd-button *ngIf=\"data?.noTitle\" [color]=\"data?.noButtonColor || 'secondary'\" [mat-dialog-close]=\"'CANCEL'\"\r\n [title]=\"data?.noTitle\" size=\"sm\"></sd-button>\r\n <sd-button class=\"ml-12\" *ngIf=\"data?.yesTitle\" [mat-dialog-close]=\"value || 'ACCEPT'\"\r\n [color]=\"data?.yesButtonColor || 'primary'\" [disabled]=\"data.input?.required && !value\" cdkFocusInitial\r\n [title]=\"data?.yesTitle\" size=\"sm\"></sd-button>\r\n</div>",
|
|
17
24
|
styles: [":host .mat-dialog-content{margin:0 -16px 16px!important}:host .mat-button{background-color:#f5f5f5}:host>>>.mat-dialog-title{align-items:center;display:flex;justify-content:flex-start}:host>>>.mat-dialog-title .mat-icon{margin-right:5px}:host{display:block;padding:12px 16px}:host>>>.mat-dialog-title .mat-icon.info{color:#2962ff}:host>>>.mat-dialog-title .mat-icon.warning{color:#ffc107}:host>>>.mat-dialog-title .mat-icon.done{color:#4caf50}:host>>>.mat-dialog-title .mat-icon.error{color:#d32f2f}"]
|
|
18
25
|
},] }
|
|
19
26
|
];
|
|
@@ -21,4 +28,4 @@ DialogConfirmComponent.ctorParameters = () => [
|
|
|
21
28
|
{ type: MatDialogRef },
|
|
22
29
|
{ type: undefined, decorators: [{ type: Inject, args: [MAT_DIALOG_DATA,] }] }
|
|
23
30
|
];
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ub3RpZnkvIiwic291cmNlcyI6WyJzcmMvbGliL2NvbXBvbmVudHMvZGlhbG9nLWNvbmZpcm0vZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFekUsT0FBTyxLQUFLLElBQUksTUFBTSxNQUFNLENBQUM7QUErQjdCLE1BQU0sT0FBTyxzQkFBc0I7SUFJakMsWUFDUyxTQUErQyxFQUN0QixJQUFnQjs7UUFEekMsY0FBUyxHQUFULFNBQVMsQ0FBc0M7UUFDdEIsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUpsRCxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLE9BQUUsR0FBRyxJQUFJLElBQUksQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFBO1FBS2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsY0FBTyxJQUFJLENBQUMsSUFBSSwwQ0FBRSxPQUFPLENBQUEsS0FBSyxRQUFRLENBQUM7UUFDdkQsSUFBSSxJQUFJLGFBQUosSUFBSSx1QkFBSixJQUFJLENBQUUsS0FBSyxFQUFFO1lBQ2YsSUFBSSxDQUFDLEtBQUssZUFBRyxJQUFJLGFBQUosSUFBSSx1QkFBSixJQUFJLENBQUUsS0FBSywwQ0FBRSxZQUFZLG1DQUFJLEVBQUUsQ0FBQztTQUM5QztRQUNELElBQUksSUFBSSxhQUFKLElBQUksdUJBQUosSUFBSSxDQUFFLElBQUksRUFBRTtZQUNkLElBQUksQ0FBQyxLQUFLLGVBQUcsSUFBSSxhQUFKLElBQUksdUJBQUosSUFBSSxDQUFFLElBQUksMENBQUUsWUFBWSxtQ0FBSSxFQUFFLENBQUM7U0FDN0M7SUFDSCxDQUFDOzs7WUFwQkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxtQkFBbUI7Z0JBQzdCLHVzREFBNEM7O2FBRTdDOzs7WUFoQ1EsWUFBWTs0Q0F1Q2hCLE1BQU0sU0FBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0RGlhbG9nUmVmLCBNQVRfRElBTE9HX0RBVEEgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBTZEJhZGdlQ29sb3IgfSBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2JhZGdlJztcclxuaW1wb3J0ICogYXMgdXVpZCBmcm9tICd1dWlkJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRGlhbG9nRGF0YSB7XHJcbiAgaWNvbj86IHN0cmluZztcclxuICB0aXRsZT86IHN0cmluZztcclxuICBtZXNzYWdlPzogc3RyaW5nO1xyXG4gIHllc1RpdGxlPzogc3RyaW5nO1xyXG4gIG5vVGl0bGU/OiBzdHJpbmc7XHJcbiAgeWVzQnV0dG9uQ29sb3I/OiBTZEJhZGdlQ29sb3I7XHJcbiAgbm9CdXR0b25Db2xvcj86IFNkQmFkZ2VDb2xvcjtcclxuICBpbnB1dD86IHtcclxuICAgIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xyXG4gICAgbWlubGVuZ3RoPzogbnVtYmVyO1xyXG4gICAgbWF4bGVuZ3RoPzogbnVtYmVyO1xyXG4gICAgcmVxdWlyZWQ/OiBib29sZWFuO1xyXG4gICAgZGVmYXVsdFZhbHVlPzogc3RyaW5nO1xyXG4gIH07XHJcbiAgZGF0ZT86IHtcclxuICAgIHJlcXVpcmVkPzogYm9vbGVhbjtcclxuICAgIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xyXG4gICAgZGVmYXVsdFZhbHVlPzogc3RyaW5nIHwgRGF0ZTtcclxuICAgIG1pbj86IHN0cmluZyB8IERhdGU7XHJcbiAgICBtYXg/OiBzdHJpbmcgfCBEYXRlO1xyXG4gIH1cclxufVxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzZC1kaWFsb2ctY29uZmlybScsXHJcbiAgdGVtcGxhdGVVcmw6ICdkaWFsb2ctY29uZmlybS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50LmNzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGlhbG9nQ29uZmlybUNvbXBvbmVudCB7XHJcbiAgdmFsdWU6IGFueTtcclxuICBpc1N0cmluZyA9IGZhbHNlO1xyXG4gIGlkID0gYEkke3V1aWQudjQoKX1gXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgZGlhbG9nUmVmOiBNYXREaWFsb2dSZWY8RGlhbG9nQ29uZmlybUNvbXBvbmVudD4sXHJcbiAgICBASW5qZWN0KE1BVF9ESUFMT0dfREFUQSkgcHVibGljIGRhdGE6IERpYWxvZ0RhdGFcclxuICApIHtcclxuICAgIHRoaXMuaXNTdHJpbmcgPSB0eXBlb2YgdGhpcy5kYXRhPy5tZXNzYWdlID09PSAnc3RyaW5nJztcclxuICAgIGlmIChkYXRhPy5pbnB1dCkge1xyXG4gICAgICB0aGlzLnZhbHVlID0gZGF0YT8uaW5wdXQ/LmRlZmF1bHRWYWx1ZSA/PyAnJztcclxuICAgIH1cclxuICAgIGlmIChkYXRhPy5kYXRlKSB7XHJcbiAgICAgIHRoaXMudmFsdWUgPSBkYXRhPy5kYXRlPy5kZWZhdWx0VmFsdWUgPz8gJyc7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -10,6 +10,7 @@ import { ToastrModule } from "ngx-toastr";
|
|
|
10
10
|
import { SdButtonModule } from "@sd-angular/core/button";
|
|
11
11
|
import { SdNotifyService } from "./notify.service";
|
|
12
12
|
import { DialogConfirmComponent } from "./components/dialog-confirm/dialog-confirm.component";
|
|
13
|
+
import { MatDatepickerModule } from "@angular/material/datepicker";
|
|
13
14
|
export class SdNotifyModule {
|
|
14
15
|
}
|
|
15
16
|
SdNotifyModule.decorators = [
|
|
@@ -19,6 +20,7 @@ SdNotifyModule.decorators = [
|
|
|
19
20
|
FormsModule,
|
|
20
21
|
MatFormFieldModule,
|
|
21
22
|
MatInputModule,
|
|
23
|
+
MatDatepickerModule,
|
|
22
24
|
MatIconModule,
|
|
23
25
|
MatButtonModule,
|
|
24
26
|
MatDialogModule,
|
|
@@ -31,4 +33,4 @@ SdNotifyModule.decorators = [
|
|
|
31
33
|
providers: [SdNotifyService],
|
|
32
34
|
},] }
|
|
33
35
|
];
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZ5Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvbm90aWZ5LyIsInNvdXJjZXMiOlsic3JjL2xpYi9ub3RpZnkubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFpQixZQUFZLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDekQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRXpELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUM5RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQXFCbkUsTUFBTSxPQUFPLGNBQWM7OztZQW5CMUIsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLFdBQVc7b0JBQ1gsa0JBQWtCO29CQUNsQixjQUFjO29CQUNkLG1CQUFtQjtvQkFDbkIsYUFBYTtvQkFDYixlQUFlO29CQUNmLGVBQWU7b0JBQ2YsWUFBWSxDQUFDLE9BQU8sRUFBRTtvQkFFdEIsY0FBYztpQkFDZjtnQkFDRCxZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztnQkFDdEMsZUFBZSxFQUFFLENBQUMsc0JBQXNCLENBQUM7Z0JBQ3pDLE9BQU8sRUFBRSxFQUFFO2dCQUNYLFNBQVMsRUFBRSxDQUFDLGVBQWUsQ0FBQzthQUM3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nXCI7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvblwiO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uXCI7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XHJcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2lucHV0XCI7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IFRvYXN0clNlcnZpY2UsIFRvYXN0ck1vZHVsZSB9IGZyb20gXCJuZ3gtdG9hc3RyXCI7XHJcbmltcG9ydCB7IFNkQnV0dG9uTW9kdWxlIH0gZnJvbSBcIkBzZC1hbmd1bGFyL2NvcmUvYnV0dG9uXCI7XHJcblxyXG5pbXBvcnQgeyBTZE5vdGlmeVNlcnZpY2UgfSBmcm9tIFwiLi9ub3RpZnkuc2VydmljZVwiO1xyXG5pbXBvcnQgeyBEaWFsb2dDb25maXJtQ29tcG9uZW50IH0gZnJvbSBcIi4vY29tcG9uZW50cy9kaWFsb2ctY29uZmlybS9kaWFsb2ctY29uZmlybS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgTWF0RGF0ZXBpY2tlck1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxyXG4gICAgTWF0SW5wdXRNb2R1bGUsXHJcbiAgICBNYXREYXRlcGlja2VyTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgIE1hdERpYWxvZ01vZHVsZSxcclxuICAgIFRvYXN0ck1vZHVsZS5mb3JSb290KCksXHJcblxyXG4gICAgU2RCdXR0b25Nb2R1bGUsXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtEaWFsb2dDb25maXJtQ29tcG9uZW50XSxcclxuICBlbnRyeUNvbXBvbmVudHM6IFtEaWFsb2dDb25maXJtQ29tcG9uZW50XSxcclxuICBleHBvcnRzOiBbXSxcclxuICBwcm92aWRlcnM6IFtTZE5vdGlmeVNlcnZpY2VdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2ROb3RpZnlNb2R1bGUge31cclxuIl19
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
var _delayDuration, _warningKey, _errorKey, _cache, _notifyWarning, _notifyError, _buildToastMultiMesssage;
|
|
2
2
|
import { __classPrivateFieldGet } from "tslib";
|
|
3
|
-
import
|
|
4
|
-
import { Injectable } from
|
|
5
|
-
import { MatDialog } from
|
|
6
|
-
import { DialogConfirmComponent } from
|
|
7
|
-
import { ToastrService } from
|
|
8
|
-
import { SdTranslateService } from
|
|
9
|
-
import { take, takeUntil } from
|
|
10
|
-
import { timer } from
|
|
3
|
+
import '@sd-angular/core/common';
|
|
4
|
+
import { Injectable } from '@angular/core';
|
|
5
|
+
import { MatDialog } from '@angular/material/dialog';
|
|
6
|
+
import { DialogConfirmComponent } from './components/dialog-confirm/dialog-confirm.component';
|
|
7
|
+
import { ToastrService } from 'ngx-toastr';
|
|
8
|
+
import { SdTranslateService } from '@sd-angular/core/translate';
|
|
9
|
+
import { take, takeUntil } from 'rxjs/operators';
|
|
10
|
+
import { timer } from 'rxjs';
|
|
11
11
|
import * as uuid from 'uuid';
|
|
12
12
|
export class SdNotifyService {
|
|
13
13
|
constructor(dialog, toastr, translateService) {
|
|
@@ -21,45 +21,45 @@ export class SdNotifyService {
|
|
|
21
21
|
this.alert = {
|
|
22
22
|
info: (message, title, yesTitle, icon) => {
|
|
23
23
|
this.dialog.open(DialogConfirmComponent, {
|
|
24
|
-
width:
|
|
24
|
+
width: '400px',
|
|
25
25
|
data: {
|
|
26
|
-
icon: icon ||
|
|
27
|
-
title: title || this.translate(
|
|
28
|
-
message: message ||
|
|
29
|
-
yesTitle: yesTitle || this.translate(
|
|
26
|
+
icon: icon || 'info',
|
|
27
|
+
title: title || this.translate('Notice'),
|
|
28
|
+
message: message || 'Done!',
|
|
29
|
+
yesTitle: yesTitle || this.translate('Ok'),
|
|
30
30
|
},
|
|
31
31
|
});
|
|
32
32
|
},
|
|
33
33
|
success: (message, title, yesTitle, icon) => {
|
|
34
34
|
this.dialog.open(DialogConfirmComponent, {
|
|
35
|
-
width:
|
|
35
|
+
width: '400px',
|
|
36
36
|
data: {
|
|
37
|
-
icon: icon ||
|
|
38
|
-
title: title || this.translate(
|
|
39
|
-
message: message ||
|
|
40
|
-
yesTitle: yesTitle || this.translate(
|
|
37
|
+
icon: icon || 'done',
|
|
38
|
+
title: title || this.translate('Success'),
|
|
39
|
+
message: message || 'Done!',
|
|
40
|
+
yesTitle: yesTitle || this.translate('Ok'),
|
|
41
41
|
},
|
|
42
42
|
});
|
|
43
43
|
},
|
|
44
44
|
warning: (message, title, yesTitle, icon) => {
|
|
45
45
|
this.dialog.open(DialogConfirmComponent, {
|
|
46
|
-
width:
|
|
46
|
+
width: '400px',
|
|
47
47
|
data: {
|
|
48
|
-
icon: icon ||
|
|
49
|
-
title: title || this.translate(
|
|
50
|
-
message: message ||
|
|
51
|
-
yesTitle: yesTitle || this.translate(
|
|
48
|
+
icon: icon || 'warning',
|
|
49
|
+
title: title || this.translate('Warning'),
|
|
50
|
+
message: message || 'Something went wrong!',
|
|
51
|
+
yesTitle: yesTitle || this.translate('Ok'),
|
|
52
52
|
},
|
|
53
53
|
});
|
|
54
54
|
},
|
|
55
55
|
error: (message, title, yesTitle, icon) => {
|
|
56
56
|
this.dialog.open(DialogConfirmComponent, {
|
|
57
|
-
width:
|
|
57
|
+
width: '400px',
|
|
58
58
|
data: {
|
|
59
|
-
icon: icon ||
|
|
60
|
-
title: title || this.translate(
|
|
61
|
-
message: message ||
|
|
62
|
-
yesTitle: yesTitle || this.translate(
|
|
59
|
+
icon: icon || 'error',
|
|
60
|
+
title: title || this.translate('Error'),
|
|
61
|
+
message: message || 'Something went wrong!',
|
|
62
|
+
yesTitle: yesTitle || this.translate('Ok'),
|
|
63
63
|
},
|
|
64
64
|
});
|
|
65
65
|
},
|
|
@@ -69,9 +69,9 @@ export class SdNotifyService {
|
|
|
69
69
|
// tslint:disable-next-line: max-line-length
|
|
70
70
|
// const style = `border-radius: 5px; margin: 0; padding: 12px; z-index: 99999; top: 5px; right: 5px; display: none; position: fixed;color: #4F8A10; background-color: #DFF2BF`;
|
|
71
71
|
// tslint:disable-next-line: max-line-length
|
|
72
|
-
// const html = `<div id=
|
|
72
|
+
// const html = `<div id='${this.notifyId}' style='${style}'><i class='fa fa-check'></i> ${message || this.translate('Success')}</div>`;
|
|
73
73
|
// this.showNotify(html, delay);
|
|
74
|
-
const content = message || this.translate(
|
|
74
|
+
const content = message || this.translate('Success');
|
|
75
75
|
this.toastr.success(content, title, {
|
|
76
76
|
enableHtml: true,
|
|
77
77
|
timeOut: delay || 3000,
|
|
@@ -181,16 +181,16 @@ export class SdNotifyService {
|
|
|
181
181
|
const id = `sd-notify-ckb-${uuid.v4()}`;
|
|
182
182
|
const messageLength = messages.length;
|
|
183
183
|
const messageRests = messages.splice(showNum);
|
|
184
|
-
const messageContainer = `<ul class=
|
|
185
|
-
const messageTemp = `<li class=
|
|
184
|
+
const messageContainer = `<ul class='sd-notify__list'>{0}{1}</ul>`;
|
|
185
|
+
const messageTemp = `<li class='sd-notify__item'>- {0}</li>`;
|
|
186
186
|
let contentRest = '';
|
|
187
187
|
if (messageRests === null || messageRests === void 0 ? void 0 : messageRests.length) {
|
|
188
|
-
contentRest = `<input id=
|
|
189
|
-
<label class=
|
|
190
|
-
<div class=
|
|
188
|
+
contentRest = `<input id='${id}' class='cdk-visually-hidden sd-notify__checkbox' type='checkbox' />
|
|
189
|
+
<label class='sd-notify__text sd-notify__text--show' for='${id}'>${this.translate('Show more')}</label>
|
|
190
|
+
<div class='sd-notify__item--rest'>
|
|
191
191
|
${messageRests.map(m => String.format(messageTemp, m)).join('')}
|
|
192
192
|
</div>
|
|
193
|
-
<label class=
|
|
193
|
+
<label class='sd-notify__text sd-notify__text--less' for='${id}'>${this.translate('Show less')}</label>`;
|
|
194
194
|
}
|
|
195
195
|
const content = String.format(messageContainer, messages.map(m => String.format(messageTemp, m)).join(''), contentRest);
|
|
196
196
|
let toast;
|
|
@@ -227,46 +227,46 @@ export class SdNotifyService {
|
|
|
227
227
|
});
|
|
228
228
|
this.handle = {
|
|
229
229
|
error: (err) => {
|
|
230
|
-
if (typeof err ===
|
|
230
|
+
if (typeof err === 'string') {
|
|
231
231
|
this.notify.warning(err);
|
|
232
232
|
}
|
|
233
|
-
else if (typeof err ===
|
|
233
|
+
else if (typeof err === 'object') {
|
|
234
234
|
let message = (err === null || err === void 0 ? void 0 : err.error) || (err === null || err === void 0 ? void 0 : err.message) || (err === null || err === void 0 ? void 0 : err.ExceptionMessage) || (err === null || err === void 0 ? void 0 : err.Message) ||
|
|
235
|
-
|
|
236
|
-
if (typeof err.json ===
|
|
235
|
+
'Unknown error';
|
|
236
|
+
if (typeof err.json === 'function') {
|
|
237
237
|
err = err.json();
|
|
238
238
|
if (err) {
|
|
239
239
|
message =
|
|
240
240
|
(err === null || err === void 0 ? void 0 : err.error) || (err === null || err === void 0 ? void 0 : err.message) || (err === null || err === void 0 ? void 0 : err.ExceptionMessage) || (err === null || err === void 0 ? void 0 : err.Message) ||
|
|
241
|
-
|
|
241
|
+
'Unknown error';
|
|
242
242
|
}
|
|
243
243
|
}
|
|
244
244
|
this.notify.warning(message);
|
|
245
245
|
}
|
|
246
246
|
else {
|
|
247
|
-
this.notify.warning(
|
|
247
|
+
this.notify.warning('Unknown error');
|
|
248
248
|
}
|
|
249
249
|
},
|
|
250
250
|
};
|
|
251
251
|
this.confirm = (message, option = {}) => {
|
|
252
252
|
const dialogRef = this.dialog.open(DialogConfirmComponent, {
|
|
253
|
-
width:
|
|
253
|
+
width: '400px',
|
|
254
254
|
data: {
|
|
255
|
-
title: (option === null || option === void 0 ? void 0 : option.title) || this.translate(
|
|
255
|
+
title: (option === null || option === void 0 ? void 0 : option.title) || this.translate('Confirm'),
|
|
256
256
|
message,
|
|
257
|
-
yesTitle: (option === null || option === void 0 ? void 0 : option.yesTitle) || this.translate(
|
|
258
|
-
noTitle: (option === null || option === void 0 ? void 0 : option.noTitle) || this.translate(
|
|
259
|
-
noButtonColor: (option === null || option === void 0 ? void 0 : option.noButtonColor) ||
|
|
260
|
-
yesButtonColor: (option === null || option === void 0 ? void 0 : option.yesButtonColor) ||
|
|
257
|
+
yesTitle: (option === null || option === void 0 ? void 0 : option.yesTitle) || this.translate('Yes'),
|
|
258
|
+
noTitle: (option === null || option === void 0 ? void 0 : option.noTitle) || this.translate('No'),
|
|
259
|
+
noButtonColor: (option === null || option === void 0 ? void 0 : option.noButtonColor) || 'secondary',
|
|
260
|
+
yesButtonColor: (option === null || option === void 0 ? void 0 : option.yesButtonColor) || 'primary',
|
|
261
261
|
},
|
|
262
262
|
});
|
|
263
263
|
return new Promise((resolve, reject) => {
|
|
264
264
|
dialogRef.afterClosed().subscribe((result) => {
|
|
265
265
|
if (result) {
|
|
266
|
-
if (result ===
|
|
266
|
+
if (result === 'ACCEPT') {
|
|
267
267
|
resolve(null);
|
|
268
268
|
}
|
|
269
|
-
else if (result ===
|
|
269
|
+
else if (result === 'CANCEL') {
|
|
270
270
|
reject(result);
|
|
271
271
|
}
|
|
272
272
|
else {
|
|
@@ -276,18 +276,18 @@ export class SdNotifyService {
|
|
|
276
276
|
});
|
|
277
277
|
});
|
|
278
278
|
};
|
|
279
|
-
this.confirmDelete = () => this.confirm(this.translate(
|
|
280
|
-
this.confirmApprove = () => this.confirm(this.translate(
|
|
279
|
+
this.confirmDelete = () => this.confirm(this.translate('Delete record(s)'));
|
|
280
|
+
this.confirmApprove = () => this.confirm(this.translate('Approve record(s)'));
|
|
281
281
|
this.confirmWithInput = (title, option = {}) => {
|
|
282
282
|
const dialogRef = this.dialog.open(DialogConfirmComponent, {
|
|
283
|
-
width:
|
|
283
|
+
width: '400px',
|
|
284
284
|
data: {
|
|
285
|
-
title: title || this.translate(
|
|
285
|
+
title: title || this.translate('Confirm'),
|
|
286
286
|
message: option === null || option === void 0 ? void 0 : option.message,
|
|
287
|
-
yesTitle: (option === null || option === void 0 ? void 0 : option.yesTitle) || this.translate(
|
|
288
|
-
noTitle: (option === null || option === void 0 ? void 0 : option.noTitle) || this.translate(
|
|
289
|
-
noButtonColor: (option === null || option === void 0 ? void 0 : option.noButtonColor) ||
|
|
290
|
-
yesButtonColor: (option === null || option === void 0 ? void 0 : option.yesButtonColor) ||
|
|
287
|
+
yesTitle: (option === null || option === void 0 ? void 0 : option.yesTitle) || this.translate('Yes'),
|
|
288
|
+
noTitle: (option === null || option === void 0 ? void 0 : option.noTitle) || this.translate('No'),
|
|
289
|
+
noButtonColor: (option === null || option === void 0 ? void 0 : option.noButtonColor) || 'secondary',
|
|
290
|
+
yesButtonColor: (option === null || option === void 0 ? void 0 : option.yesButtonColor) || 'primary',
|
|
291
291
|
input: {
|
|
292
292
|
maxlength: (option === null || option === void 0 ? void 0 : option.maxlength) || 255,
|
|
293
293
|
required: option === null || option === void 0 ? void 0 : option.required,
|
|
@@ -298,10 +298,43 @@ export class SdNotifyService {
|
|
|
298
298
|
return new Promise((resolve, reject) => {
|
|
299
299
|
dialogRef.afterClosed().subscribe((result) => {
|
|
300
300
|
if (result) {
|
|
301
|
-
if (result ===
|
|
301
|
+
if (result === 'ACCEPT') {
|
|
302
302
|
resolve(result);
|
|
303
303
|
}
|
|
304
|
-
else if (result ===
|
|
304
|
+
else if (result === 'CANCEL') {
|
|
305
|
+
reject(result);
|
|
306
|
+
}
|
|
307
|
+
else {
|
|
308
|
+
resolve(result);
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
});
|
|
312
|
+
});
|
|
313
|
+
};
|
|
314
|
+
this.confirmWithDate = (title, option = {}) => {
|
|
315
|
+
const dialogRef = this.dialog.open(DialogConfirmComponent, {
|
|
316
|
+
width: '400px',
|
|
317
|
+
data: {
|
|
318
|
+
title: title || this.translate('Confirm'),
|
|
319
|
+
message: option === null || option === void 0 ? void 0 : option.message,
|
|
320
|
+
yesTitle: (option === null || option === void 0 ? void 0 : option.yesTitle) || this.translate('Yes'),
|
|
321
|
+
noTitle: (option === null || option === void 0 ? void 0 : option.noTitle) || this.translate('No'),
|
|
322
|
+
noButtonColor: (option === null || option === void 0 ? void 0 : option.noButtonColor) || 'secondary',
|
|
323
|
+
yesButtonColor: (option === null || option === void 0 ? void 0 : option.yesButtonColor) || 'primary',
|
|
324
|
+
date: {
|
|
325
|
+
placeholder: option === null || option === void 0 ? void 0 : option.placeholder,
|
|
326
|
+
required: option === null || option === void 0 ? void 0 : option.required,
|
|
327
|
+
defaultValue: (option === null || option === void 0 ? void 0 : option.defaultValue) || '',
|
|
328
|
+
},
|
|
329
|
+
},
|
|
330
|
+
});
|
|
331
|
+
return new Promise((resolve, reject) => {
|
|
332
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
333
|
+
if (result) {
|
|
334
|
+
if (result === 'ACCEPT') {
|
|
335
|
+
resolve(result);
|
|
336
|
+
}
|
|
337
|
+
else if (result === 'CANCEL') {
|
|
305
338
|
reject(result);
|
|
306
339
|
}
|
|
307
340
|
else {
|
|
@@ -325,4 +358,4 @@ SdNotifyService.ctorParameters = () => [
|
|
|
325
358
|
{ type: ToastrService },
|
|
326
359
|
{ type: SdTranslateService }
|
|
327
360
|
];
|
|
328
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notify.service.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/notify/","sources":["src/lib/notify.service.ts"],"names":[],"mappings":";;AAAA,OAAO,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,sBAAsB,EAAE,MAAM,sDAAsD,CAAC;AAC9F,OAAO,EAAe,aAAa,EAAE,MAAM,YAAY,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAgB,IAAI,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAW,KAAK,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAG7B,MAAM,OAAO,eAAe;IAa1B,YACU,MAAiB,EACjB,MAAqB,EACrB,gBAAoC;QAFpC,WAAM,GAAN,MAAM,CAAW;QACjB,WAAM,GAAN,MAAM,CAAe;QACrB,qBAAgB,GAAhB,gBAAgB,CAAoB;QAf9C,yBAAiB,GAAG,EAAC,CAAC,qEAAqE;QAC3F,sBAAc,IAAI,CAAC,EAAE,EAAE,EAAC;QACxB,oBAAY,IAAI,CAAC,EAAE,EAAE,EAAC;QACtB,iBAQI,EAAE,EAAC;QAOP,UAAK,GAAG;YACN,IAAI,EAAE,CACJ,OAAgB,EAChB,KAAc,EACd,QAAiB,EACjB,IAAa,EACb,EAAE;gBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;oBACvC,KAAK,EAAE,OAAO;oBACd,IAAI,EAAE;wBACJ,IAAI,EAAE,IAAI,IAAI,MAAM;wBACpB,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;wBACxC,OAAO,EAAE,OAAO,IAAI,OAAO;wBAC3B,QAAQ,EAAE,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;qBAC3C;iBACF,CAAC,CAAC;YACL,CAAC;YACD,OAAO,EAAE,CACP,OAAgB,EAChB,KAAc,EACd,QAAiB,EACjB,IAAa,EACb,EAAE;gBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;oBACvC,KAAK,EAAE,OAAO;oBACd,IAAI,EAAE;wBACJ,IAAI,EAAE,IAAI,IAAI,MAAM;wBACpB,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;wBACzC,OAAO,EAAE,OAAO,IAAI,OAAO;wBAC3B,QAAQ,EAAE,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;qBAC3C;iBACF,CAAC,CAAC;YACL,CAAC;YACD,OAAO,EAAE,CACP,OAAgB,EAChB,KAAc,EACd,QAAiB,EACjB,IAAa,EACb,EAAE;gBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;oBACvC,KAAK,EAAE,OAAO;oBACd,IAAI,EAAE;wBACJ,IAAI,EAAE,IAAI,IAAI,SAAS;wBACvB,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;wBACzC,OAAO,EAAE,OAAO,IAAI,uBAAuB;wBAC3C,QAAQ,EAAE,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;qBAC3C;iBACF,CAAC,CAAC;YACL,CAAC;YACD,KAAK,EAAE,CACL,OAAgB,EAChB,KAAc,EACd,QAAiB,EACjB,IAAa,EACb,EAAE;gBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;oBACvC,KAAK,EAAE,OAAO;oBACd,IAAI,EAAE;wBACJ,IAAI,EAAE,IAAI,IAAI,OAAO;wBACrB,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;wBACvC,OAAO,EAAE,OAAO,IAAI,uBAAuB;wBAC3C,QAAQ,EAAE,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;qBAC3C;iBACF,CAAC,CAAC;YACL,CAAC;SACF,CAAC;QAEF,WAAM,GAAG;YACP,OAAO,EAAE,CAAC,OAAgB,EAAE,KAAc,EAAE,KAAc,EAAE,EAAE;gBAC5D,4CAA4C;gBAC5C,gLAAgL;gBAChL,4CAA4C;gBAC5C,wIAAwI;gBACxI,gCAAgC;gBAChC,MAAM,OAAO,GAAG,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;gBACrD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,EAAE;oBAClC,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,KAAK,IAAI,IAAI;oBACtB,WAAW,EAAE,IAAI;iBAClB,CAAC,CAAC;YACL,CAAC;YACD,OAAO,EAAE,CAAC,OAA2B,EAAE,KAAc,EAAE,KAAc,EAAE,EAAE;gBACvE,IAAI,CAAC,+EAA6B,IAAI,IAAI,CAAC,cAAc,CAAC,+EAA6B,CAAC,WAAW,+CAAsB,GAAG,IAAI,IAAI,EAAE,EAAE;oBACtI,+EAA6B,GAAG;wBAC9B,WAAW,EAAE,IAAI,IAAI,EAAE;wBACvB,IAAI,EAAE;4BACJ,KAAK,EAAE,KAAK;4BACZ,QAAQ,EAAE,EAAE;yBACb;qBACF,CAAC;oBACF,KAAK,8CAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;wBACtD,MAAM,QAAQ,GAAG,+EAA6B,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;wBACzE,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;4BACzB,kDAAA,IAAI,EAAgB;gCAClB,KAAK,EAAE,+EAA6B,CAAC,IAAI,CAAC,KAAK;gCAC/C,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC;gCACpB,KAAK;6BACN,CAAC,CAAC;yBACJ;6BAAM;4BACL,kDAAA,IAAI,EAAgB;gCAClB,KAAK,EAAE,+EAA6B,CAAC,IAAI,CAAC,KAAK;gCAC/C,OAAO,EAAE,QAAQ;gCACjB,KAAK;6BACN,CAAC,CAAC;yBACJ;oBACH,CAAC,CAAC,CAAC;iBACJ;gBACD,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oBAC1B,+EAA6B,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,+EAA6B,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,OAAO,CAAC,CAAC;iBAC5G;qBAAM;oBACL,+EAA6B,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;iBAC3D;YACH,CAAC;YACD,KAAK,EAAE,CAAC,OAA2B,EAAE,KAAc,EAAE,KAAc,EAAE,EAAE;gBACrE,IAAI,CAAC,6EAA2B,IAAI,IAAI,CAAC,cAAc,CAAC,6EAA2B,CAAC,WAAW,+CAAsB,GAAG,IAAI,IAAI,EAAE,EAAE;oBAClI,6EAA2B,GAAG;wBAC5B,WAAW,EAAE,IAAI,IAAI,EAAE;wBACvB,IAAI,EAAE;4BACJ,KAAK;4BACL,QAAQ,EAAE,EAAE;yBACb;qBACF,CAAC;oBACF,KAAK,8CAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;wBACtD,MAAM,QAAQ,GAAG,6EAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;wBACvE,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;4BACzB,gDAAA,IAAI,EAAc;gCAChB,KAAK,EAAE,6EAA2B,CAAC,IAAI,CAAC,KAAK;gCAC7C,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC;gCACpB,KAAK;6BACN,CAAC,CAAC;yBACJ;6BAAM;4BACL,gDAAA,IAAI,EAAc;gCAChB,KAAK,EAAE,6EAA2B,CAAC,IAAI,CAAC,KAAK;gCAC7C,OAAO,EAAE,QAAQ;gCACjB,KAAK;6BACN,CAAC,CAAC;yBACJ;oBACH,CAAC,CAAC,CAAC;iBACJ;gBACD,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oBAC1B,6EAA2B,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,6EAA2B,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,OAAO,CAAC,CAAC;iBACxG;qBAAM;oBACL,6EAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;iBACzD;YACH,CAAC;SACF,CAAC;QAEF,yBAAiB,CAAC,IAIjB,EAAE,EAAE;YACH,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;YACvC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC1B,4DAAA,IAAI,EAA0B,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;aACjE;iBACI;gBACH,MAAM,OAAO,GAAG,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;gBACrD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,KAAK,EAAE;oBAClC,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,KAAK,IAAI,IAAI;oBACtB,WAAW,EAAE,IAAI;iBAClB,CAAC,CAAC;aACJ;QACH,CAAC,EAAA;QAED,uBAAe,CAAC,IAIf,EAAE,EAAE;YACH,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;YACvC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC1B,4DAAA,IAAI,EAA0B,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;aAC/D;iBACI;gBACH,MAAM,OAAO,GAAG,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;gBACnD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE;oBAChC,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,KAAK,IAAI,IAAI;oBACtB,WAAW,EAAE,IAAI;iBAClB,CAAC,CAAC;aACJ;QACH,CAAC,EAAA;QAED,mCAA2B,CAAC,IAAyB,EAAE,QAAkB,EAAE,KAAc,EAAE,KAAc,EAAE,EAAE;YAC3G,sCAAsC;YACtC,MAAM,OAAO,GAAG,CAAC,CAAC;YAClB,MAAM,EAAE,GAAG,iBAAiB,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC;YACxC,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC;YACtC,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAC9C,MAAM,gBAAgB,GAAG,yCAAyC,CAAC;YACnE,MAAM,WAAW,GAAG,wCAAwC,CAAC;YAC7D,IAAI,WAAW,GAAG,EAAE,CAAC;YACrB,IAAI,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,MAAM,EAAE;gBACxB,WAAW,GAAG,cAAc,EAAE;kEAC8B,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;;UAE1F,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;;kEAEL,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,UAAU,CAAC;aAC1G;YACD,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,WAAW,CAAC,CAAC;YACxH,IAAI,KAAuB,CAAC;YAC5B,sFAAsF;YACtF,iGAAiG;YACjG,QAAQ,IAAI,EAAE;gBACZ,KAAK,OAAO;oBACV,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,aAAa,GAAG,EAAE;wBAC3F,UAAU,EAAE,IAAI;wBAChB,OAAO,EAAE,KAAK,IAAI,IAAI;wBACtB,YAAY,EAAE,+BAA+B,EAAE,EAAE;wBACjD,WAAW,EAAE,IAAI;wBACjB,YAAY,EAAE,KAAK;qBACpB,CAAC,CAAC;oBACH,MAAM;gBACR,KAAK,SAAS;oBACZ,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,aAAa,GAAG,EAAE;wBAC/F,UAAU,EAAE,IAAI;wBAChB,OAAO,EAAE,KAAK,IAAI,IAAI;wBACtB,YAAY,EAAE,+BAA+B,EAAE,EAAE;wBACjD,WAAW,EAAE,IAAI;wBACjB,YAAY,EAAE,KAAK;qBACpB,CAAC,CAAC;oBACH,MAAM;aACT;YAED,IAAI,KAAK,EAAE;gBACT,KAAK,CAAC,OAAO;qBACV,IAAI,CACH,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,CAC1B;qBACA,SAAS,CAAC,GAAG,EAAE;oBACd,MAAM,UAAU,GAAmB,QAAQ,CAAC,aAAa,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;oBAClF,UAAU,CAAC,SAAS,GAAG,OAAO,CAAC;gBACjC,CAAC,CAAC,CAAA;aACL;QACH,CAAC,EAAA;QAED,WAAM,GAAG;YACP,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE;oBAC3B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;iBAC1B;qBAAM,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE;oBAClC,IAAI,OAAO,GACT,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,MACV,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAA,KACZ,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,gBAAgB,CAAA,KACrB,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAA;wBACZ,eAAe,CAAC;oBAClB,IAAI,OAAO,GAAG,CAAC,IAAI,KAAK,UAAU,EAAE;wBAClC,GAAG,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;wBACjB,IAAI,GAAG,EAAE;4BACP,OAAO;gCACL,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,MACV,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAA,KACZ,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,gBAAgB,CAAA,KACrB,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAA;oCACZ,eAAe,CAAC;yBACnB;qBACF;oBACD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;iBAC9B;qBAAM;oBACL,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;iBACtC;YACH,CAAC;SACF,CAAC;QAEF,YAAO,GAAG,CACR,OAAe,EACf,SAMI,EAAE,EACN,EAAE;YACF,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;gBACzD,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE;oBACJ,KAAK,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,KAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;oBACjD,OAAO;oBACP,QAAQ,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ,KAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;oBACnD,OAAO,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,KAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;oBAChD,aAAa,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,KAAI,WAAW;oBACnD,cAAc,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,KAAI,SAAS;iBACpD;aACF,CAAC,CAAC;YACH,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBACrC,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;oBAC3C,IAAI,MAAM,EAAE;wBACV,IAAI,MAAM,KAAK,QAAQ,EAAE;4BACvB,OAAO,CAAC,IAAI,CAAC,CAAC;yBACf;6BAAM,IAAI,MAAM,KAAK,QAAQ,EAAE;4BAC9B,MAAM,CAAC,MAAM,CAAC,CAAC;yBAChB;6BAAM;4BACL,OAAO,CAAC,IAAI,CAAC,CAAC;yBACf;qBACF;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QAEF,kBAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAEvE,mBAAc,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAEzE,qBAAgB,GAAG,CACjB,KAAa,EACb,SASI,EAAE,EACW,EAAE;YACnB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;gBACzD,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE;oBACJ,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;oBACzC,OAAO,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO;oBACxB,QAAQ,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ,KAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;oBACnD,OAAO,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,KAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;oBAChD,aAAa,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,KAAI,WAAW;oBACnD,cAAc,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,KAAI,SAAS;oBACnD,KAAK,EAAE;wBACL,SAAS,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,KAAI,GAAG;wBACnC,QAAQ,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ;wBAC1B,YAAY,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,YAAY,KAAI,EAAE;qBACzC;iBACF;aACF,CAAC,CAAC;YACH,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBACrC,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;oBAC3C,IAAI,MAAM,EAAE;wBACV,IAAI,MAAM,KAAK,QAAQ,EAAE;4BACvB,OAAO,CAAC,MAAM,CAAC,CAAC;yBACjB;6BAAM,IAAI,MAAM,KAAK,QAAQ,EAAE;4BAC9B,MAAM,CAAC,MAAM,CAAC,CAAC;yBAChB;6BAAM;4BACL,OAAO,CAAC,MAAM,CAAC,CAAC;yBACjB;qBACF;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QAEM,cAAS,GAAG,CAAC,KAAa,EAAU,EAAE;YAC5C,OAAO,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAChD,CAAC,CAAC;IApWE,CAAC;;;;YAlBN,UAAU;;;YARF,SAAS;YAEI,aAAa;YAC1B,kBAAkB","sourcesContent":["import \"@sd-angular/core/common\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { MatDialog } from \"@angular/material/dialog\";\r\nimport { DialogConfirmComponent } from \"./components/dialog-confirm/dialog-confirm.component\";\r\nimport { ActiveToast, ToastrService } from \"ngx-toastr\";\r\nimport { SdTranslateService } from \"@sd-angular/core/translate\";\r\nimport { debounceTime, take, takeUntil } from \"rxjs/operators\";\r\nimport { Subject, timer } from \"rxjs\";\r\nimport * as uuid from 'uuid';\r\n\r\n@Injectable()\r\nexport class SdNotifyService {\r\n  #delayDuration = 500; // Các error/warning message sẽ tự động gộp sau khoảng thời gian trên\r\n  #warningKey = uuid.v4();\r\n  #errorKey = uuid.v4();\r\n  #cache: {\r\n    [key: string]: {\r\n      createdDate: Date;\r\n      data?: {\r\n        title: string,\r\n        messages: string[]\r\n      }\r\n    }\r\n  } = {};\r\n  constructor(\r\n    private dialog: MatDialog,\r\n    private toastr: ToastrService,\r\n    private translateService: SdTranslateService\r\n  ) { }\r\n\r\n  alert = {\r\n    info: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: \"400px\",\r\n        data: {\r\n          icon: icon || \"info\",\r\n          title: title || this.translate(\"Notice\"),\r\n          message: message || \"Done!\",\r\n          yesTitle: yesTitle || this.translate(\"Ok\"),\r\n        },\r\n      });\r\n    },\r\n    success: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: \"400px\",\r\n        data: {\r\n          icon: icon || \"done\",\r\n          title: title || this.translate(\"Success\"),\r\n          message: message || \"Done!\",\r\n          yesTitle: yesTitle || this.translate(\"Ok\"),\r\n        },\r\n      });\r\n    },\r\n    warning: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: \"400px\",\r\n        data: {\r\n          icon: icon || \"warning\",\r\n          title: title || this.translate(\"Warning\"),\r\n          message: message || \"Something went wrong!\",\r\n          yesTitle: yesTitle || this.translate(\"Ok\"),\r\n        },\r\n      });\r\n    },\r\n    error: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: \"400px\",\r\n        data: {\r\n          icon: icon || \"error\",\r\n          title: title || this.translate(\"Error\"),\r\n          message: message || \"Something went wrong!\",\r\n          yesTitle: yesTitle || this.translate(\"Ok\"),\r\n        },\r\n      });\r\n    },\r\n  };\r\n\r\n  notify = {\r\n    success: (message?: string, delay?: number, title?: string) => {\r\n      // tslint:disable-next-line: max-line-length\r\n      // const style = `border-radius: 5px; margin: 0; padding: 12px; z-index: 99999; top: 5px; right: 5px; display: none; position: fixed;color: #4F8A10; background-color: #DFF2BF`;\r\n      // tslint:disable-next-line: max-line-length\r\n      // const html = `<div id=\"${this.notifyId}\" style=\"${style}\"><i class=\"fa fa-check\"></i> ${message || this.translate('Success')}</div>`;\r\n      // this.showNotify(html, delay);\r\n      const content = message || this.translate(\"Success\");\r\n      this.toastr.success(content, title, {\r\n        enableHtml: true,\r\n        timeOut: delay || 3000,\r\n        closeButton: true,\r\n      });\r\n    },\r\n    warning: (message?: string | string[], delay?: number, title?: string) => {\r\n      if (!this.#cache[this.#warningKey] || Date.addMiliseconds(this.#cache[this.#warningKey].createdDate, this.#delayDuration) < new Date()) {\r\n        this.#cache[this.#warningKey] = {\r\n          createdDate: new Date(),\r\n          data: {\r\n            title: title,\r\n            messages: [],\r\n          }\r\n        };\r\n        timer(this.#delayDuration).pipe(take(1)).subscribe(() => {\r\n          const messages = this.#cache[this.#warningKey].data.messages.union(null);\r\n          if (messages.length === 1) {\r\n            this.#notifyWarning({\r\n              title: this.#cache[this.#warningKey].data.title,\r\n              message: messages[0],\r\n              delay\r\n            });\r\n          } else {\r\n            this.#notifyWarning({\r\n              title: this.#cache[this.#warningKey].data.title,\r\n              message: messages,\r\n              delay\r\n            });\r\n          }\r\n        });\r\n      }\r\n      if (Array.isArray(message)) {\r\n        this.#cache[this.#warningKey].data.messages = [...this.#cache[this.#warningKey].data.messages, ...message];\r\n      } else {\r\n        this.#cache[this.#warningKey].data.messages.push(message);\r\n      }\r\n    },\r\n    error: (message?: string | string[], delay?: number, title?: string) => {\r\n      if (!this.#cache[this.#errorKey] || Date.addMiliseconds(this.#cache[this.#errorKey].createdDate, this.#delayDuration) < new Date()) {\r\n        this.#cache[this.#errorKey] = {\r\n          createdDate: new Date(),\r\n          data: {\r\n            title,\r\n            messages: [],\r\n          }\r\n        };\r\n        timer(this.#delayDuration).pipe(take(1)).subscribe(() => {\r\n          const messages = this.#cache[this.#errorKey].data.messages.union(null);\r\n          if (messages.length === 1) {\r\n            this.#notifyError({\r\n              title: this.#cache[this.#errorKey].data.title,\r\n              message: messages[0],\r\n              delay\r\n            });\r\n          } else {\r\n            this.#notifyError({\r\n              title: this.#cache[this.#errorKey].data.title,\r\n              message: messages,\r\n              delay\r\n            });\r\n          }\r\n        });\r\n      }\r\n      if (Array.isArray(message)) {\r\n        this.#cache[this.#errorKey].data.messages = [...this.#cache[this.#errorKey].data.messages, ...message];\r\n      } else {\r\n        this.#cache[this.#errorKey].data.messages.push(message);\r\n      }\r\n    },\r\n  };\r\n\r\n  #notifyWarning = (args: {\r\n    message?: string | string[],\r\n    delay?: number,\r\n    title?: string\r\n  }) => {\r\n    const { message, delay, title } = args;\r\n    if (Array.isArray(message)) {\r\n      this.#buildToastMultiMesssage('warning', message, delay, title);\r\n    }\r\n    else {\r\n      const content = message || this.translate('Warning');\r\n      this.toastr.warning(content, title, {\r\n        enableHtml: true,\r\n        timeOut: delay || 3000,\r\n        closeButton: true,\r\n      });\r\n    }\r\n  }\r\n\r\n  #notifyError = (args: {\r\n    message?: string | string[],\r\n    delay?: number,\r\n    title?: string\r\n  }) => {\r\n    const { message, delay, title } = args;\r\n    if (Array.isArray(message)) {\r\n      this.#buildToastMultiMesssage('error', message, delay, title);\r\n    }\r\n    else {\r\n      const content = message || this.translate('Error');\r\n      this.toastr.error(content, title, {\r\n        enableHtml: true,\r\n        timeOut: delay || 3000,\r\n        closeButton: true,\r\n      });\r\n    }\r\n  }\r\n\r\n  #buildToastMultiMesssage = (type: 'warning' | 'error', messages: string[], delay?: number, title?: string) => {\r\n    /** số lượng item hiển thị mặc định */\r\n    const showNum = 2;\r\n    const id = `sd-notify-ckb-${uuid.v4()}`;\r\n    const messageLength = messages.length;\r\n    const messageRests = messages.splice(showNum);\r\n    const messageContainer = `<ul class=\"sd-notify__list\">{0}{1}</ul>`;\r\n    const messageTemp = `<li class=\"sd-notify__item\">- {0}</li>`;\r\n    let contentRest = '';\r\n    if (messageRests?.length) {\r\n      contentRest = `<input id=\"${id}\" class=\"cdk-visually-hidden sd-notify__checkbox\" type=\"checkbox\" />\r\n      <label class=\"sd-notify__text sd-notify__text--show\" for=\"${id}\">${this.translate('Show more')}</label>\r\n      <div class=\"sd-notify__item--rest\">\r\n        ${messageRests.map(m => String.format(messageTemp, m)).join('')}\r\n      </div>\r\n      <label class=\"sd-notify__text sd-notify__text--less\" for=\"${id}\">${this.translate('Show less')}</label>`;\r\n    }\r\n    const content = String.format(messageContainer, messages.map(m => String.format(messageTemp, m)).join(''), contentRest);\r\n    let toast: ActiveToast<any>;\r\n    // khi truyền message html sẽ bị sanitize nên phải truyền innerHTML khi toast hiện lên\r\n    // @see https://github.com/scttcper/ngx-toastr/blob/v12.1.0/src/lib/toastr/toastr.service.ts#L271\r\n    switch (type) {\r\n      case 'error':\r\n        toast = this.toastr.error(content, `${title || this.translate('Error')} (${messageLength})`, {\r\n          enableHtml: true,\r\n          timeOut: delay || 3000,\r\n          messageClass: `toast-message toast-message-${id}`,\r\n          closeButton: true,\r\n          tapToDismiss: false\r\n        });\r\n        break;\r\n      case 'warning':\r\n        toast = this.toastr.warning(content, `${title || this.translate('Warning')} (${messageLength})`, {\r\n          enableHtml: true,\r\n          timeOut: delay || 3000,\r\n          messageClass: `toast-message toast-message-${id}`,\r\n          closeButton: true,\r\n          tapToDismiss: false\r\n        });\r\n        break;\r\n    }\r\n\r\n    if (toast) {\r\n      toast.onShown\r\n        .pipe(\r\n          takeUntil(toast.onHidden)\r\n        )\r\n        .subscribe(() => {\r\n          const messageEle: HTMLDivElement = document.querySelector(`.toast-message-${id}`);\r\n          messageEle.innerHTML = content;\r\n        })\r\n    }\r\n  }\r\n\r\n  handle = {\r\n    error: (err: any) => {\r\n      if (typeof err === \"string\") {\r\n        this.notify.warning(err);\r\n      } else if (typeof err === \"object\") {\r\n        let message =\r\n          err?.error ||\r\n          err?.message ||\r\n          err?.ExceptionMessage ||\r\n          err?.Message ||\r\n          \"Unknown error\";\r\n        if (typeof err.json === \"function\") {\r\n          err = err.json();\r\n          if (err) {\r\n            message =\r\n              err?.error ||\r\n              err?.message ||\r\n              err?.ExceptionMessage ||\r\n              err?.Message ||\r\n              \"Unknown error\";\r\n          }\r\n        }\r\n        this.notify.warning(message);\r\n      } else {\r\n        this.notify.warning(\"Unknown error\");\r\n      }\r\n    },\r\n  };\r\n\r\n  confirm = (\r\n    message: string,\r\n    option: {\r\n      title?: string;\r\n      yesTitle?: string;\r\n      noTitle?: string;\r\n      yesButtonColor?: string;\r\n      noButtonColor?: string;\r\n    } = {}\r\n  ) => {\r\n    const dialogRef = this.dialog.open(DialogConfirmComponent, {\r\n      width: \"400px\",\r\n      data: {\r\n        title: option?.title || this.translate(\"Confirm\"),\r\n        message,\r\n        yesTitle: option?.yesTitle || this.translate(\"Yes\"),\r\n        noTitle: option?.noTitle || this.translate(\"No\"),\r\n        noButtonColor: option?.noButtonColor || \"secondary\",\r\n        yesButtonColor: option?.yesButtonColor || \"primary\",\r\n      },\r\n    });\r\n    return new Promise((resolve, reject) => {\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n        if (result) {\r\n          if (result === \"ACCEPT\") {\r\n            resolve(null);\r\n          } else if (result === \"CANCEL\") {\r\n            reject(result);\r\n          } else {\r\n            resolve(null);\r\n          }\r\n        }\r\n      });\r\n    });\r\n  };\r\n\r\n  confirmDelete = () => this.confirm(this.translate(\"Delete record(s)\"));\r\n\r\n  confirmApprove = () => this.confirm(this.translate(\"Approve record(s)\"));\r\n\r\n  confirmWithInput = (\r\n    title: string,\r\n    option: {\r\n      message?: string;\r\n      yesTitle?: string;\r\n      noTitle?: string;\r\n      required?: boolean;\r\n      maxlength?: number;\r\n      yesButtonColor?: string;\r\n      noButtonColor?: string;\r\n      defaultValue?: string;\r\n    } = {}\r\n  ): Promise<string> => {\r\n    const dialogRef = this.dialog.open(DialogConfirmComponent, {\r\n      width: \"400px\",\r\n      data: {\r\n        title: title || this.translate(\"Confirm\"),\r\n        message: option?.message,\r\n        yesTitle: option?.yesTitle || this.translate(\"Yes\"),\r\n        noTitle: option?.noTitle || this.translate(\"No\"),\r\n        noButtonColor: option?.noButtonColor || \"secondary\",\r\n        yesButtonColor: option?.yesButtonColor || \"primary\",\r\n        input: {\r\n          maxlength: option?.maxlength || 255,\r\n          required: option?.required,\r\n          defaultValue: option?.defaultValue || ''\r\n        },\r\n      },\r\n    });\r\n    return new Promise((resolve, reject) => {\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n        if (result) {\r\n          if (result === \"ACCEPT\") {\r\n            resolve(result);\r\n          } else if (result === \"CANCEL\") {\r\n            reject(result);\r\n          } else {\r\n            resolve(result);\r\n          }\r\n        }\r\n      });\r\n    });\r\n  };\r\n\r\n  private translate = (value: string): string => {\r\n    return this.translateService.translate(value);\r\n  };\r\n}\r\n"]}
|
|
361
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notify.service.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/notify/","sources":["src/lib/notify.service.ts"],"names":[],"mappings":"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","sourcesContent":["import '@sd-angular/core/common';\r\nimport { Injectable } from '@angular/core';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { DialogConfirmComponent } from './components/dialog-confirm/dialog-confirm.component';\r\nimport { ActiveToast, ToastrService } from 'ngx-toastr';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { debounceTime, take, takeUntil } from 'rxjs/operators';\r\nimport { Subject, timer } from 'rxjs';\r\nimport * as uuid from 'uuid';\r\nimport { SdBadgeColor } from '@sd-angular/core/badge';\r\n\r\n@Injectable()\r\nexport class SdNotifyService {\r\n  #delayDuration = 500; // Các error/warning message sẽ tự động gộp sau khoảng thời gian trên\r\n  #warningKey = uuid.v4();\r\n  #errorKey = uuid.v4();\r\n  #cache: {\r\n    [key: string]: {\r\n      createdDate: Date;\r\n      data?: {\r\n        title: string,\r\n        messages: string[]\r\n      }\r\n    }\r\n  } = {};\r\n  constructor(\r\n    private dialog: MatDialog,\r\n    private toastr: ToastrService,\r\n    private translateService: SdTranslateService\r\n  ) { }\r\n\r\n  alert = {\r\n    info: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: '400px',\r\n        data: {\r\n          icon: icon || 'info',\r\n          title: title || this.translate('Notice'),\r\n          message: message || 'Done!',\r\n          yesTitle: yesTitle || this.translate('Ok'),\r\n        },\r\n      });\r\n    },\r\n    success: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: '400px',\r\n        data: {\r\n          icon: icon || 'done',\r\n          title: title || this.translate('Success'),\r\n          message: message || 'Done!',\r\n          yesTitle: yesTitle || this.translate('Ok'),\r\n        },\r\n      });\r\n    },\r\n    warning: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: '400px',\r\n        data: {\r\n          icon: icon || 'warning',\r\n          title: title || this.translate('Warning'),\r\n          message: message || 'Something went wrong!',\r\n          yesTitle: yesTitle || this.translate('Ok'),\r\n        },\r\n      });\r\n    },\r\n    error: (\r\n      message?: string,\r\n      title?: string,\r\n      yesTitle?: string,\r\n      icon?: string\r\n    ) => {\r\n      this.dialog.open(DialogConfirmComponent, {\r\n        width: '400px',\r\n        data: {\r\n          icon: icon || 'error',\r\n          title: title || this.translate('Error'),\r\n          message: message || 'Something went wrong!',\r\n          yesTitle: yesTitle || this.translate('Ok'),\r\n        },\r\n      });\r\n    },\r\n  };\r\n\r\n  notify = {\r\n    success: (message?: string, delay?: number, title?: string) => {\r\n      // tslint:disable-next-line: max-line-length\r\n      // const style = `border-radius: 5px; margin: 0; padding: 12px; z-index: 99999; top: 5px; right: 5px; display: none; position: fixed;color: #4F8A10; background-color: #DFF2BF`;\r\n      // tslint:disable-next-line: max-line-length\r\n      // const html = `<div id='${this.notifyId}' style='${style}'><i class='fa fa-check'></i> ${message || this.translate('Success')}</div>`;\r\n      // this.showNotify(html, delay);\r\n      const content = message || this.translate('Success');\r\n      this.toastr.success(content, title, {\r\n        enableHtml: true,\r\n        timeOut: delay || 3000,\r\n        closeButton: true,\r\n      });\r\n    },\r\n    warning: (message?: string | string[], delay?: number, title?: string) => {\r\n      if (!this.#cache[this.#warningKey] || Date.addMiliseconds(this.#cache[this.#warningKey].createdDate, this.#delayDuration) < new Date()) {\r\n        this.#cache[this.#warningKey] = {\r\n          createdDate: new Date(),\r\n          data: {\r\n            title: title,\r\n            messages: [],\r\n          }\r\n        };\r\n        timer(this.#delayDuration).pipe(take(1)).subscribe(() => {\r\n          const messages = this.#cache[this.#warningKey].data.messages.union(null);\r\n          if (messages.length === 1) {\r\n            this.#notifyWarning({\r\n              title: this.#cache[this.#warningKey].data.title,\r\n              message: messages[0],\r\n              delay\r\n            });\r\n          } else {\r\n            this.#notifyWarning({\r\n              title: this.#cache[this.#warningKey].data.title,\r\n              message: messages,\r\n              delay\r\n            });\r\n          }\r\n        });\r\n      }\r\n      if (Array.isArray(message)) {\r\n        this.#cache[this.#warningKey].data.messages = [...this.#cache[this.#warningKey].data.messages, ...message];\r\n      } else {\r\n        this.#cache[this.#warningKey].data.messages.push(message);\r\n      }\r\n    },\r\n    error: (message?: string | string[], delay?: number, title?: string) => {\r\n      if (!this.#cache[this.#errorKey] || Date.addMiliseconds(this.#cache[this.#errorKey].createdDate, this.#delayDuration) < new Date()) {\r\n        this.#cache[this.#errorKey] = {\r\n          createdDate: new Date(),\r\n          data: {\r\n            title,\r\n            messages: [],\r\n          }\r\n        };\r\n        timer(this.#delayDuration).pipe(take(1)).subscribe(() => {\r\n          const messages = this.#cache[this.#errorKey].data.messages.union(null);\r\n          if (messages.length === 1) {\r\n            this.#notifyError({\r\n              title: this.#cache[this.#errorKey].data.title,\r\n              message: messages[0],\r\n              delay\r\n            });\r\n          } else {\r\n            this.#notifyError({\r\n              title: this.#cache[this.#errorKey].data.title,\r\n              message: messages,\r\n              delay\r\n            });\r\n          }\r\n        });\r\n      }\r\n      if (Array.isArray(message)) {\r\n        this.#cache[this.#errorKey].data.messages = [...this.#cache[this.#errorKey].data.messages, ...message];\r\n      } else {\r\n        this.#cache[this.#errorKey].data.messages.push(message);\r\n      }\r\n    },\r\n  };\r\n\r\n  #notifyWarning = (args: {\r\n    message?: string | string[],\r\n    delay?: number,\r\n    title?: string\r\n  }) => {\r\n    const { message, delay, title } = args;\r\n    if (Array.isArray(message)) {\r\n      this.#buildToastMultiMesssage('warning', message, delay, title);\r\n    }\r\n    else {\r\n      const content = message || this.translate('Warning');\r\n      this.toastr.warning(content, title, {\r\n        enableHtml: true,\r\n        timeOut: delay || 3000,\r\n        closeButton: true,\r\n      });\r\n    }\r\n  }\r\n\r\n  #notifyError = (args: {\r\n    message?: string | string[],\r\n    delay?: number,\r\n    title?: string\r\n  }) => {\r\n    const { message, delay, title } = args;\r\n    if (Array.isArray(message)) {\r\n      this.#buildToastMultiMesssage('error', message, delay, title);\r\n    }\r\n    else {\r\n      const content = message || this.translate('Error');\r\n      this.toastr.error(content, title, {\r\n        enableHtml: true,\r\n        timeOut: delay || 3000,\r\n        closeButton: true,\r\n      });\r\n    }\r\n  }\r\n\r\n  #buildToastMultiMesssage = (type: 'warning' | 'error', messages: string[], delay?: number, title?: string) => {\r\n    /** số lượng item hiển thị mặc định */\r\n    const showNum = 2;\r\n    const id = `sd-notify-ckb-${uuid.v4()}`;\r\n    const messageLength = messages.length;\r\n    const messageRests = messages.splice(showNum);\r\n    const messageContainer = `<ul class='sd-notify__list'>{0}{1}</ul>`;\r\n    const messageTemp = `<li class='sd-notify__item'>- {0}</li>`;\r\n    let contentRest = '';\r\n    if (messageRests?.length) {\r\n      contentRest = `<input id='${id}' class='cdk-visually-hidden sd-notify__checkbox' type='checkbox' />\r\n      <label class='sd-notify__text sd-notify__text--show' for='${id}'>${this.translate('Show more')}</label>\r\n      <div class='sd-notify__item--rest'>\r\n        ${messageRests.map(m => String.format(messageTemp, m)).join('')}\r\n      </div>\r\n      <label class='sd-notify__text sd-notify__text--less' for='${id}'>${this.translate('Show less')}</label>`;\r\n    }\r\n    const content = String.format(messageContainer, messages.map(m => String.format(messageTemp, m)).join(''), contentRest);\r\n    let toast: ActiveToast<any>;\r\n    // khi truyền message html sẽ bị sanitize nên phải truyền innerHTML khi toast hiện lên\r\n    // @see https://github.com/scttcper/ngx-toastr/blob/v12.1.0/src/lib/toastr/toastr.service.ts#L271\r\n    switch (type) {\r\n      case 'error':\r\n        toast = this.toastr.error(content, `${title || this.translate('Error')} (${messageLength})`, {\r\n          enableHtml: true,\r\n          timeOut: delay || 3000,\r\n          messageClass: `toast-message toast-message-${id}`,\r\n          closeButton: true,\r\n          tapToDismiss: false\r\n        });\r\n        break;\r\n      case 'warning':\r\n        toast = this.toastr.warning(content, `${title || this.translate('Warning')} (${messageLength})`, {\r\n          enableHtml: true,\r\n          timeOut: delay || 3000,\r\n          messageClass: `toast-message toast-message-${id}`,\r\n          closeButton: true,\r\n          tapToDismiss: false\r\n        });\r\n        break;\r\n    }\r\n\r\n    if (toast) {\r\n      toast.onShown\r\n        .pipe(\r\n          takeUntil(toast.onHidden)\r\n        )\r\n        .subscribe(() => {\r\n          const messageEle: HTMLDivElement = document.querySelector(`.toast-message-${id}`);\r\n          messageEle.innerHTML = content;\r\n        })\r\n    }\r\n  }\r\n\r\n  handle = {\r\n    error: (err: any) => {\r\n      if (typeof err === 'string') {\r\n        this.notify.warning(err);\r\n      } else if (typeof err === 'object') {\r\n        let message =\r\n          err?.error ||\r\n          err?.message ||\r\n          err?.ExceptionMessage ||\r\n          err?.Message ||\r\n          'Unknown error';\r\n        if (typeof err.json === 'function') {\r\n          err = err.json();\r\n          if (err) {\r\n            message =\r\n              err?.error ||\r\n              err?.message ||\r\n              err?.ExceptionMessage ||\r\n              err?.Message ||\r\n              'Unknown error';\r\n          }\r\n        }\r\n        this.notify.warning(message);\r\n      } else {\r\n        this.notify.warning('Unknown error');\r\n      }\r\n    },\r\n  };\r\n\r\n  confirm = (\r\n    message: string,\r\n    option: {\r\n      title?: string;\r\n      yesTitle?: string;\r\n      noTitle?: string;\r\n      yesButtonColor?: SdBadgeColor;\r\n      noButtonColor?: SdBadgeColor;\r\n    } = {}\r\n  ) => {\r\n    const dialogRef = this.dialog.open(DialogConfirmComponent, {\r\n      width: '400px',\r\n      data: {\r\n        title: option?.title || this.translate('Confirm'),\r\n        message,\r\n        yesTitle: option?.yesTitle || this.translate('Yes'),\r\n        noTitle: option?.noTitle || this.translate('No'),\r\n        noButtonColor: option?.noButtonColor || 'secondary',\r\n        yesButtonColor: option?.yesButtonColor || 'primary',\r\n      },\r\n    });\r\n    return new Promise((resolve, reject) => {\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n        if (result) {\r\n          if (result === 'ACCEPT') {\r\n            resolve(null);\r\n          } else if (result === 'CANCEL') {\r\n            reject(result);\r\n          } else {\r\n            resolve(null);\r\n          }\r\n        }\r\n      });\r\n    });\r\n  };\r\n\r\n  confirmDelete = () => this.confirm(this.translate('Delete record(s)'));\r\n\r\n  confirmApprove = () => this.confirm(this.translate('Approve record(s)'));\r\n\r\n  confirmWithInput = (\r\n    title: string,\r\n    option: {\r\n      message?: string;\r\n      yesTitle?: string;\r\n      noTitle?: string;\r\n      required?: boolean;\r\n      maxlength?: number;\r\n      yesButtonColor?: SdBadgeColor;\r\n      noButtonColor?: SdBadgeColor;\r\n      defaultValue?: string;\r\n    } = {}\r\n  ): Promise<string> => {\r\n    const dialogRef = this.dialog.open(DialogConfirmComponent, {\r\n      width: '400px',\r\n      data: {\r\n        title: title || this.translate('Confirm'),\r\n        message: option?.message,\r\n        yesTitle: option?.yesTitle || this.translate('Yes'),\r\n        noTitle: option?.noTitle || this.translate('No'),\r\n        noButtonColor: option?.noButtonColor || 'secondary',\r\n        yesButtonColor: option?.yesButtonColor || 'primary',\r\n        input: {\r\n          maxlength: option?.maxlength || 255,\r\n          required: option?.required,\r\n          defaultValue: option?.defaultValue || ''\r\n        },\r\n      },\r\n    });\r\n    return new Promise((resolve, reject) => {\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n        if (result) {\r\n          if (result === 'ACCEPT') {\r\n            resolve(result);\r\n          } else if (result === 'CANCEL') {\r\n            reject(result);\r\n          } else {\r\n            resolve(result);\r\n          }\r\n        }\r\n      });\r\n    });\r\n  };\r\n\r\n  confirmWithDate = (\r\n    title: string,\r\n    option: {\r\n      message?: string;\r\n      yesTitle?: string;\r\n      noTitle?: string;\r\n      required?: boolean;\r\n      yesButtonColor?: SdBadgeColor;\r\n      noButtonColor?: SdBadgeColor;\r\n      defaultValue?: string | Date;\r\n      placeholder?: string\r\n    } = {}\r\n  ): Promise<string> => {\r\n    const dialogRef = this.dialog.open(DialogConfirmComponent, {\r\n      width: '400px',\r\n      data: {\r\n        title: title || this.translate('Confirm'),\r\n        message: option?.message,\r\n        yesTitle: option?.yesTitle || this.translate('Yes'),\r\n        noTitle: option?.noTitle || this.translate('No'),\r\n        noButtonColor: option?.noButtonColor || 'secondary',\r\n        yesButtonColor: option?.yesButtonColor || 'primary',\r\n        date: {\r\n          placeholder: option?.placeholder,\r\n          required: option?.required,\r\n          defaultValue: option?.defaultValue || '',\r\n        },\r\n      },\r\n    });\r\n    return new Promise((resolve, reject) => {\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n        if (result) {\r\n          if (result === 'ACCEPT') {\r\n            resolve(result);\r\n          } else if (result === 'CANCEL') {\r\n            reject(result);\r\n          } else {\r\n            resolve(result);\r\n          }\r\n        }\r\n      });\r\n    });\r\n  };\r\n\r\n  private translate = (value: string): string => {\r\n    return this.translateService.translate(value);\r\n  };\r\n}\r\n"]}
|
|
@@ -11,7 +11,7 @@ class SdHeaderTitleComponent {
|
|
|
11
11
|
SdHeaderTitleComponent.decorators = [
|
|
12
12
|
{ type: Component, args: [{
|
|
13
13
|
selector: 'sd-header-title',
|
|
14
|
-
template: "<div class=\"d-flex\">\r\n <div *ngIf=\"icon\" class=\"flex-shrink-1 c-header-icon\">\r\n <mat-icon
|
|
14
|
+
template: "<div class=\"d-flex\">\r\n <div *ngIf=\"icon\" class=\"flex-shrink-1 c-header-icon\">\r\n <mat-icon class=\"material-symbols-outlined text-grey\">{{icon}}</mat-icon>\r\n </div>\r\n <div class=\"d-flex flex-column w-100 overflow-hidden\">\r\n <div class=\"d-flex\">\r\n <span class=\"T16M\">{{title}}</span>\r\n <ng-container *ngIf=\"tooltip\">\r\n <mat-icon\r\n [matTooltip]=\"tooltip\"\r\n class=\"material-icons-outlined c-header-icon-tooltip\"> info </mat-icon>\r\n </ng-container>\r\n </div>\r\n <span *ngIf=\"description\" class=\"c-header-description\">{{description}}</span>\r\n </div>\r\n <div class=\"flex-shrink-1\">\r\n <ng-content select=\"[sdHeaderRight]\"></ng-content>\r\n </div>\r\n</div>\r\n",
|
|
15
15
|
styles: [".c-header-icon{align-items:center;display:flex;height:28px;margin-right:8px;width:28px}.c-header-icon-tooltip{align-items:center;color:#757575;display:flex;font-size:20px;height:28px!important;margin-left:10px}.c-header-description{font-size:14px;line-height:20px}"]
|
|
16
16
|
},] }
|
|
17
17
|
];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-angular-core-header-title.js","sources":["../../../../projects/sd-core/header-title/src/lib/header-title.component.ts","../../../../projects/sd-core/header-title/src/lib/header-title.module.ts","../../../../projects/sd-core/header-title/sd-angular-core-header-title.ts"],"sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'sd-header-title',\r\n templateUrl: './header-title.component.html',\r\n styleUrls: ['./header-title.component.scss']\r\n})\r\nexport class SdHeaderTitleComponent implements OnInit {\r\n\r\n @Input() title: string;\r\n @Input() icon: string;\r\n @Input() description: string;\r\n @Input() tooltip: string;\r\n\r\n constructor() { }\r\n\r\n ngOnInit(): void {\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { SdHeaderTitleComponent } from './header-title.component';\r\nimport {MatTooltipModule} from '@angular/material/tooltip';\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n MatIconModule,\r\n MatTooltipModule\r\n ],\r\n declarations: [SdHeaderTitleComponent],\r\n exports: [SdHeaderTitleComponent]\r\n})\r\nexport class SdHeaderTitleModule { }\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n\nexport {SdHeaderTitleComponent as ɵa} from './src/lib/header-title.component';"],"names":[],"mappings":";;;;;MAOa,sBAAsB;IAOjC,iBAAiB;IAEjB,QAAQ;KACP;;;YAfF,SAAS,SAAC;gBACT,QAAQ,EAAE,iBAAiB;gBAC3B,
|
|
1
|
+
{"version":3,"file":"sd-angular-core-header-title.js","sources":["../../../../projects/sd-core/header-title/src/lib/header-title.component.ts","../../../../projects/sd-core/header-title/src/lib/header-title.module.ts","../../../../projects/sd-core/header-title/sd-angular-core-header-title.ts"],"sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'sd-header-title',\r\n templateUrl: './header-title.component.html',\r\n styleUrls: ['./header-title.component.scss']\r\n})\r\nexport class SdHeaderTitleComponent implements OnInit {\r\n\r\n @Input() title: string;\r\n @Input() icon: string;\r\n @Input() description: string;\r\n @Input() tooltip: string;\r\n\r\n constructor() { }\r\n\r\n ngOnInit(): void {\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { SdHeaderTitleComponent } from './header-title.component';\r\nimport {MatTooltipModule} from '@angular/material/tooltip';\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n MatIconModule,\r\n MatTooltipModule\r\n ],\r\n declarations: [SdHeaderTitleComponent],\r\n exports: [SdHeaderTitleComponent]\r\n})\r\nexport class SdHeaderTitleModule { }\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n\nexport {SdHeaderTitleComponent as ɵa} from './src/lib/header-title.component';"],"names":[],"mappings":";;;;;MAOa,sBAAsB;IAOjC,iBAAiB;IAEjB,QAAQ;KACP;;;YAfF,SAAS,SAAC;gBACT,QAAQ,EAAE,iBAAiB;gBAC3B,6wBAA4C;;aAE7C;;;;oBAGE,KAAK;mBACL,KAAK;0BACL,KAAK;sBACL,KAAK;;;MCEK,mBAAmB;;;YAT/B,QAAQ,SAAC;gBACR,OAAO,EAAE;oBACP,YAAY;oBACZ,aAAa;oBACb,gBAAgB;iBACjB;gBACD,YAAY,EAAE,CAAC,sBAAsB,CAAC;gBACtC,OAAO,EAAE,CAAC,sBAAsB,CAAC;aAClC;;;ACbD;;;;;;"}
|