@sd-angular/core 0.0.903 → 0.0.907
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/bundles/sd-angular-core-grid-material.umd.js +196 -27
- package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js +2 -2
- package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-tab-router.umd.js +33 -18
- package/bundles/sd-angular-core-tab-router.umd.js.map +1 -1
- package/bundles/sd-angular-core-tab-router.umd.min.js +2 -2
- package/bundles/sd-angular-core-tab-router.umd.min.js.map +1 -1
- package/esm2015/grid-material/sd-angular-core-grid-material.js +20 -18
- package/esm2015/grid-material/src/lib/components/desktop-cell-view/desktop-cell-view.component.js +2 -2
- package/esm2015/grid-material/src/lib/components/dynamic-column/dynamic-column.component.js +98 -0
- package/esm2015/grid-material/src/lib/components/popup-grid-configuration/popup-grid-configuration.component.js +23 -5
- package/esm2015/grid-material/src/lib/grid-material.component.js +1 -2
- package/esm2015/grid-material/src/lib/grid-material.module.js +8 -2
- package/esm2015/grid-material/src/lib/models/grid-config.model.js +1 -1
- package/esm2015/grid-material/src/lib/pipes/column-badge.pipe.js +4 -1
- package/esm2015/grid-material/src/lib/pipes/column-transform.pipe.js +1 -1
- package/esm2015/grid-material/src/lib/services/generated-column/generated-column.model.js +2 -0
- package/esm2015/grid-material/src/lib/services/generated-column/generated-column.service.js +57 -0
- package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js +30 -24
- package/fesm2015/sd-angular-core-grid-material.js +172 -8
- package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
- package/fesm2015/sd-angular-core-tab-router.js +20 -14
- package/fesm2015/sd-angular-core-tab-router.js.map +1 -1
- package/grid-material/sd-angular-core-grid-material.d.ts +19 -17
- package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
- package/grid-material/src/lib/components/dynamic-column/dynamic-column.component.d.ts +32 -0
- package/grid-material/src/lib/components/popup-grid-configuration/popup-grid-configuration.component.d.ts +9 -0
- package/grid-material/src/lib/models/grid-config.model.d.ts +11 -0
- package/grid-material/src/lib/services/generated-column/generated-column.model.d.ts +8 -0
- package/grid-material/src/lib/services/generated-column/generated-column.service.d.ts +10 -0
- package/package.json +1 -1
- package/{sd-angular-core-0.0.903.tgz → sd-angular-core-0.0.907.tgz} +0 -0
- package/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.d.ts +7 -7
|
@@ -5,6 +5,9 @@ export class SdColumnBadgePipe {
|
|
|
5
5
|
if (column.type === 'string' && (column === null || column === void 0 ? void 0 : column.badge)) {
|
|
6
6
|
return column.badge(value, rowData);
|
|
7
7
|
}
|
|
8
|
+
if (column.type === 'bool' && (column === null || column === void 0 ? void 0 : column.badge)) {
|
|
9
|
+
return column.badge(value, rowData);
|
|
10
|
+
}
|
|
8
11
|
return null;
|
|
9
12
|
}
|
|
10
13
|
}
|
|
@@ -14,4 +17,4 @@ SdColumnBadgePipe.decorators = [
|
|
|
14
17
|
},] }
|
|
15
18
|
];
|
|
16
19
|
SdColumnBadgePipe.ctorParameters = () => [];
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLWJhZGdlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiQzovVXNlcnMvdXNlci9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLW1hdGVyaWFsLyIsInNvdXJjZXMiOlsic3JjL2xpYi9waXBlcy9jb2x1bW4tYmFkZ2UucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUtwRCxNQUFNLE9BQU8saUJBQWlCO0lBQzVCLGdCQUFnQixDQUFDO0lBQ2pCLFNBQVMsQ0FBQyxLQUFVLEVBQUUsT0FBWSxFQUFFLE1BQTRCO1FBQzlELElBQUksTUFBTSxDQUFDLElBQUksS0FBSyxRQUFRLEtBQUksTUFBTSxhQUFOLE1BQU0sdUJBQU4sTUFBTSxDQUFFLEtBQUssQ0FBQSxFQUFFO1lBQzdDLE9BQU8sTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7U0FDckM7UUFDRCxJQUFJLE1BQU0sQ0FBQyxJQUFJLEtBQUssTUFBTSxLQUFJLE1BQU0sYUFBTixNQUFNLHVCQUFOLE1BQU0sQ0FBRSxLQUFLLENBQUEsRUFBRTtZQUMzQyxPQUFPLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1NBQ3JDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDOzs7WUFiRixJQUFJLFNBQUM7Z0JBQ0osSUFBSSxFQUFFLGFBQWE7YUFDcEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNkR3JpZE1hdGVyaWFsQ29sdW1uIH0gZnJvbSAnLi4vbW9kZWxzL2dyaWQtY29sdW1uLm1vZGVsJztcclxuQFBpcGUoe1xyXG4gIG5hbWU6ICdjb2x1bW5CYWRnZSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFNkQ29sdW1uQmFkZ2VQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuICB0cmFuc2Zvcm0odmFsdWU6IGFueSwgcm93RGF0YTogYW55LCBjb2x1bW46IFNkR3JpZE1hdGVyaWFsQ29sdW1uKTogc3RyaW5nIHtcclxuICAgIGlmIChjb2x1bW4udHlwZSA9PT0gJ3N0cmluZycgJiYgY29sdW1uPy5iYWRnZSkge1xyXG4gICAgICByZXR1cm4gY29sdW1uLmJhZGdlKHZhbHVlLCByb3dEYXRhKTtcclxuICAgIH1cclxuICAgIGlmIChjb2x1bW4udHlwZSA9PT0gJ2Jvb2wnICYmIGNvbHVtbj8uYmFkZ2UpIHtcclxuICAgICAgcmV0dXJuIGNvbHVtbi5iYWRnZSh2YWx1ZSwgcm93RGF0YSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gbnVsbDtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -26,4 +26,4 @@ SdColumnTransformPipe.decorators = [
|
|
|
26
26
|
SdColumnTransformPipe.ctorParameters = () => [
|
|
27
27
|
{ type: DecimalPipe }
|
|
28
28
|
];
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLXRyYW5zZm9ybS5waXBlLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL3VzZXIvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC1tYXRlcmlhbC8iLCJzb3VyY2VzIjpbInNyYy9saWIvcGlwZXMvY29sdW1uLXRyYW5zZm9ybS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM5QyxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUtwRCxNQUFNLE9BQU8scUJBQXFCO0lBQ2hDLFlBQW9CLFdBQXdCO1FBQXhCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO0lBQUksQ0FBQztJQUNqRCxTQUFTLENBQUMsS0FBVSxFQUFFLE9BQVksRUFBRSxNQUE0Qjs7UUFDOUQsSUFBSSxNQUFNLGFBQU4sTUFBTSx1QkFBTixNQUFNLENBQUUsU0FBUyxFQUFFO1lBQ3JCLE9BQU8sTUFBTSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7U0FDekM7UUFDRCxJQUFJLE1BQU0sQ0FBQyxJQUFJLEtBQUssUUFBUSxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDdEQsT0FBTyxNQUFNLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsOENBQThDO1NBQ2xGO1FBQ0QsSUFBSSxNQUFNLENBQUMsSUFBSSxLQUFLLE1BQU0sRUFBRTtZQUMxQixPQUFPLEtBQUssS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBQSxNQUFNLENBQUMsTUFBTSwwQ0FBRSxhQUFhLEtBQUksTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBQSxNQUFNLENBQUMsTUFBTSwwQ0FBRSxhQUFhLEtBQUksT0FBTyxDQUFDLENBQUM7U0FDOUc7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7OztZQWhCRixJQUFJLFNBQUM7Z0JBQ0osSUFBSSxFQUFFLGlCQUFpQjthQUN4Qjs7O1lBTFEsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlY2ltYWxQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTZEdyaWRNYXRlcmlhbENvbHVtbiB9IGZyb20gJy4uL21vZGVscy9ncmlkLWNvbHVtbi5tb2RlbCc7XHJcbkBQaXBlKHtcclxuICBuYW1lOiAnY29sdW1uVHJhbnNmb3JtJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RDb2x1bW5UcmFuc2Zvcm1QaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBkZWNpbWFsUGlwZTogRGVjaW1hbFBpcGUpIHsgfVxyXG4gIHRyYW5zZm9ybSh2YWx1ZTogYW55LCByb3dEYXRhOiBhbnksIGNvbHVtbjogU2RHcmlkTWF0ZXJpYWxDb2x1bW4pOiBzdHJpbmcge1xyXG4gICAgaWYgKGNvbHVtbj8udHJhbnNmb3JtKSB7XHJcbiAgICAgIHJldHVybiBjb2x1bW4udHJhbnNmb3JtKHZhbHVlLCByb3dEYXRhKTtcclxuICAgIH1cclxuICAgIGlmIChjb2x1bW4udHlwZSA9PT0gJ251bWJlcicgJiYgTnVtYmVyLmlzTnVtYmVyKHZhbHVlKSkge1xyXG4gICAgICByZXR1cm4gTnVtYmVyLnRvVk5DdXJyZW5jeSh2YWx1ZSk7IC8vIHRoaXMuZGVjaW1hbFBpcGUudHJhbnNmb3JtKHZhbHVlLCAnMS4wLTInKTtcclxuICAgIH1cclxuICAgIGlmIChjb2x1bW4udHlwZSA9PT0gJ2Jvb2wnKSB7XHJcbiAgICAgIHJldHVybiB2YWx1ZSA9PT0gdHJ1ZSA/IChjb2x1bW4ub3B0aW9uPy5kaXNwbGF5T25UcnVlIHx8ICdUcnVlJykgOiAoY29sdW1uLm9wdGlvbj8uZGlzcGxheU9uVHJ1ZSB8fCAnRmFsc2UnKTtcclxuICAgIH1cclxuICAgIHJldHVybiB2YWx1ZTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVkLWNvbHVtbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy91c2VyL0RvY3VtZW50cy9saWItY29yZS11aS9wcm9qZWN0cy9zZC1jb3JlL2dyaWQtbWF0ZXJpYWwvIiwic291cmNlcyI6WyJzcmMvbGliL3NlcnZpY2VzL2dlbmVyYXRlZC1jb2x1bW4vZ2VuZXJhdGVkLWNvbHVtbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2RHcmlkTWF0ZXJpYWxDb2x1bW4gfSBmcm9tICcuLi8uLi9tb2RlbHMvZ3JpZC1jb2x1bW4ubW9kZWwnO1xyXG5cclxuLy8gZXhwb3J0IGNsYXNzIFNkR2VuZXJhdGVkQ29sdW1uPFQgPSBhbnk+IGV4dGVuZHMgU2RHcmlkTWF0ZXJpYWxDb2x1bW48VD4ge1xyXG4vLyAgIHRpdGxlPzogc3RyaW5nO1xyXG4vLyAgIHdpZHRoPzogc3RyaW5nO1xyXG4vLyAgIHR5cGU/OiAnc3RyaW5nJyB8ICdudW1iZXInIHwgJ2Jvb2wnIHwgJ2RhdGUnIHwgJ2RhdGV0aW1lJyB8ICdpbWFnZScgfCAnJ1xyXG4vLyAgIGludmlzaWJsZT86IHN0cmluZztcclxuLy8gICBmaXhlZD86IHN0cmluZztcclxuLy8gICBodG1sVGVtcGxhdGU/OiBzdHJpbmc7XHJcbi8vICAgZmllbGRzPzogc3RyaW5nW107XHJcbi8vIH1cclxuXHJcbmV4cG9ydCB0eXBlIFNkR2VuZXJhdGVkQ29sdW1uPFQgPSBhbnk+ID0gU2RHcmlkTWF0ZXJpYWxDb2x1bW48VD4gJiB7XHJcbiAgaWQ/OiBzdHJpbmc7XHJcbiAgaXNTeXN0ZW0/OiBib29sZWFuO1xyXG4gIHVzZVRlbXBsYXRlPzogYm9vbGVhbjtcclxuICB0ZW1wbGF0ZT86IHN0cmluZztcclxuICBmaWVsZHM/OiBzdHJpbmdbXTtcclxufTtcclxuIl19
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
var _cache;
|
|
2
|
+
import { __classPrivateFieldGet } from "tslib";
|
|
3
|
+
import { Injectable } from '@angular/core';
|
|
4
|
+
import hash from 'object-hash';
|
|
5
|
+
import { SdSettingService } from '@sd-angular/core/setting';
|
|
6
|
+
export class SdGeneratedColumnService {
|
|
7
|
+
constructor(settingService) {
|
|
8
|
+
this.settingService = settingService;
|
|
9
|
+
_cache.set(this, {});
|
|
10
|
+
this.load = (configuration) => {
|
|
11
|
+
if (!(configuration === null || configuration === void 0 ? void 0 : configuration.key)) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
const key = hash({
|
|
15
|
+
prefix: '260f5e94-5865-4425-8ced-b9c083c390dd',
|
|
16
|
+
key: configuration.key
|
|
17
|
+
});
|
|
18
|
+
if (!__classPrivateFieldGet(this, _cache)[key]) {
|
|
19
|
+
__classPrivateFieldGet(this, _cache)[key] = this.settingService.create(key, {
|
|
20
|
+
type: configuration === null || configuration === void 0 ? void 0 : configuration.storage,
|
|
21
|
+
args: configuration === null || configuration === void 0 ? void 0 : configuration.args,
|
|
22
|
+
default: []
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
return __classPrivateFieldGet(this, _cache)[key];
|
|
26
|
+
};
|
|
27
|
+
this.loadSystem = (configuration) => {
|
|
28
|
+
var _a;
|
|
29
|
+
if (!(configuration === null || configuration === void 0 ? void 0 : configuration.key)) {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
if (!(configuration === null || configuration === void 0 ? void 0 : configuration.systemColumn)) {
|
|
33
|
+
return null;
|
|
34
|
+
}
|
|
35
|
+
const key = hash({
|
|
36
|
+
prefix: '8b8050ca-1f44-4860-bad3-20e646c0d68f',
|
|
37
|
+
key: configuration.key
|
|
38
|
+
});
|
|
39
|
+
if (!__classPrivateFieldGet(this, _cache)[key]) {
|
|
40
|
+
__classPrivateFieldGet(this, _cache)[key] = this.settingService.create(key, {
|
|
41
|
+
type: 'server',
|
|
42
|
+
args: (_a = configuration === null || configuration === void 0 ? void 0 : configuration.systemColumn) === null || _a === void 0 ? void 0 : _a.args,
|
|
43
|
+
default: []
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
return __classPrivateFieldGet(this, _cache)[key];
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
_cache = new WeakMap();
|
|
51
|
+
SdGeneratedColumnService.decorators = [
|
|
52
|
+
{ type: Injectable }
|
|
53
|
+
];
|
|
54
|
+
SdGeneratedColumnService.ctorParameters = () => [
|
|
55
|
+
{ type: SdSettingService }
|
|
56
|
+
];
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVkLWNvbHVtbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL3VzZXIvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC1tYXRlcmlhbC8iLCJzb3VyY2VzIjpbInNyYy9saWIvc2VydmljZXMvZ2VuZXJhdGVkLWNvbHVtbi9nZW5lcmF0ZWQtY29sdW1uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQVUsVUFBVSxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sSUFBSSxNQUFNLGFBQWEsQ0FBQztBQUMvQixPQUFPLEVBQWEsZ0JBQWdCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUt2RSxNQUFNLE9BQU8sd0JBQXdCO0lBSW5DLFlBQ1UsY0FBZ0M7UUFBaEMsbUJBQWMsR0FBZCxjQUFjLENBQWtCO1FBSjFDLGlCQUVJLEVBQUUsRUFBQztRQUtQLFNBQUksR0FBRyxDQUFDLGFBQXlDLEVBQUUsRUFBRTtZQUNuRCxJQUFJLEVBQUMsYUFBYSxhQUFiLGFBQWEsdUJBQWIsYUFBYSxDQUFFLEdBQUcsQ0FBQSxFQUFFO2dCQUN2QixPQUFPLElBQUksQ0FBQzthQUNiO1lBQ0QsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDO2dCQUNmLE1BQU0sRUFBRSxzQ0FBc0M7Z0JBQzlDLEdBQUcsRUFBRSxhQUFhLENBQUMsR0FBRzthQUN2QixDQUFDLENBQUM7WUFFSCxJQUFJLENBQUMscUNBQVksR0FBRyxDQUFDLEVBQUU7Z0JBQ3JCLHFDQUFZLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFzQixHQUFHLEVBQUU7b0JBQ3RFLElBQUksRUFBRSxhQUFhLGFBQWIsYUFBYSx1QkFBYixhQUFhLENBQUUsT0FBTztvQkFDNUIsSUFBSSxFQUFFLGFBQWEsYUFBYixhQUFhLHVCQUFiLGFBQWEsQ0FBRSxJQUFJO29CQUN6QixPQUFPLEVBQUUsRUFBRTtpQkFDWixDQUFDLENBQUM7YUFDSjtZQUNELE9BQU8scUNBQVksR0FBRyxDQUFDLENBQUM7UUFDMUIsQ0FBQyxDQUFBO1FBRUQsZUFBVSxHQUFHLENBQUMsYUFBeUMsRUFBRSxFQUFFOztZQUN6RCxJQUFJLEVBQUMsYUFBYSxhQUFiLGFBQWEsdUJBQWIsYUFBYSxDQUFFLEdBQUcsQ0FBQSxFQUFFO2dCQUN2QixPQUFPLElBQUksQ0FBQzthQUNiO1lBQ0QsSUFBSSxFQUFDLGFBQWEsYUFBYixhQUFhLHVCQUFiLGFBQWEsQ0FBRSxZQUFZLENBQUEsRUFBRTtnQkFDaEMsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUNELE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQztnQkFDZixNQUFNLEVBQUUsc0NBQXNDO2dCQUM5QyxHQUFHLEVBQUUsYUFBYSxDQUFDLEdBQUc7YUFDdkIsQ0FBQyxDQUFDO1lBRUgsSUFBSSxDQUFDLHFDQUFZLEdBQUcsQ0FBQyxFQUFFO2dCQUNyQixxQ0FBWSxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBc0IsR0FBRyxFQUFFO29CQUN0RSxJQUFJLEVBQUUsUUFBUTtvQkFDZCxJQUFJLFFBQUUsYUFBYSxhQUFiLGFBQWEsdUJBQWIsYUFBYSxDQUFFLFlBQVksMENBQUUsSUFBSTtvQkFDdkMsT0FBTyxFQUFFLEVBQUU7aUJBQ1osQ0FBQyxDQUFDO2FBQ0o7WUFDRCxPQUFPLHFDQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQzFCLENBQUMsQ0FBQTtJQXpDRCxDQUFDOzs7O1lBUEYsVUFBVTs7O1lBSlMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlLCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgaGFzaCBmcm9tICdvYmplY3QtaGFzaCc7XHJcbmltcG9ydCB7IFNkU2V0dGluZywgU2RTZXR0aW5nU2VydmljZSB9IGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvc2V0dGluZyc7XHJcbmltcG9ydCB7IFNkR3JpZE1hdGVyaWFsQ29uZmlnT3B0aW9uIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2dyaWQtY29uZmlnLm1vZGVsJztcclxuaW1wb3J0IHsgU2RHZW5lcmF0ZWRDb2x1bW4gfSBmcm9tICcuL2dlbmVyYXRlZC1jb2x1bW4ubW9kZWwnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgU2RHZW5lcmF0ZWRDb2x1bW5TZXJ2aWNlIHtcclxuICAjY2FjaGU6IHtcclxuICAgIFtrZXk6IHN0cmluZ106IFNkU2V0dGluZzxTZEdlbmVyYXRlZENvbHVtbltdPlxyXG4gIH0gPSB7fTtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgc2V0dGluZ1NlcnZpY2U6IFNkU2V0dGluZ1NlcnZpY2UpIHtcclxuICB9XHJcblxyXG4gIGxvYWQgPSAoY29uZmlndXJhdGlvbjogU2RHcmlkTWF0ZXJpYWxDb25maWdPcHRpb24pID0+IHtcclxuICAgIGlmICghY29uZmlndXJhdGlvbj8ua2V5KSB7XHJcbiAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgY29uc3Qga2V5ID0gaGFzaCh7XHJcbiAgICAgIHByZWZpeDogJzI2MGY1ZTk0LTU4NjUtNDQyNS04Y2VkLWI5YzA4M2MzOTBkZCcsXHJcbiAgICAgIGtleTogY29uZmlndXJhdGlvbi5rZXlcclxuICAgIH0pO1xyXG5cclxuICAgIGlmICghdGhpcy4jY2FjaGVba2V5XSkge1xyXG4gICAgICB0aGlzLiNjYWNoZVtrZXldID0gdGhpcy5zZXR0aW5nU2VydmljZS5jcmVhdGU8U2RHZW5lcmF0ZWRDb2x1bW5bXT4oa2V5LCB7XHJcbiAgICAgICAgdHlwZTogY29uZmlndXJhdGlvbj8uc3RvcmFnZSxcclxuICAgICAgICBhcmdzOiBjb25maWd1cmF0aW9uPy5hcmdzLFxyXG4gICAgICAgIGRlZmF1bHQ6IFtdXHJcbiAgICAgIH0pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRoaXMuI2NhY2hlW2tleV07XHJcbiAgfVxyXG5cclxuICBsb2FkU3lzdGVtID0gKGNvbmZpZ3VyYXRpb246IFNkR3JpZE1hdGVyaWFsQ29uZmlnT3B0aW9uKSA9PiB7XHJcbiAgICBpZiAoIWNvbmZpZ3VyYXRpb24/LmtleSkge1xyXG4gICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIGlmICghY29uZmlndXJhdGlvbj8uc3lzdGVtQ29sdW1uKSB7XHJcbiAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgY29uc3Qga2V5ID0gaGFzaCh7XHJcbiAgICAgIHByZWZpeDogJzhiODA1MGNhLTFmNDQtNDg2MC1iYWQzLTIwZTY0NmMwZDY4ZicsXHJcbiAgICAgIGtleTogY29uZmlndXJhdGlvbi5rZXlcclxuICAgIH0pO1xyXG5cclxuICAgIGlmICghdGhpcy4jY2FjaGVba2V5XSkge1xyXG4gICAgICB0aGlzLiNjYWNoZVtrZXldID0gdGhpcy5zZXR0aW5nU2VydmljZS5jcmVhdGU8U2RHZW5lcmF0ZWRDb2x1bW5bXT4oa2V5LCB7XHJcbiAgICAgICAgdHlwZTogJ3NlcnZlcicsXHJcbiAgICAgICAgYXJnczogY29uZmlndXJhdGlvbj8uc3lzdGVtQ29sdW1uPy5hcmdzLFxyXG4gICAgICAgIGRlZmF1bHQ6IFtdXHJcbiAgICAgIH0pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRoaXMuI2NhY2hlW2tleV07XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
var _rootRoute, _subscription, _firstLoad, _closeTab, _activeRoute, _getActivatedRouteSnapshot, _getActivatedRoute;
|
|
2
2
|
import { __awaiter, __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
-
import { ChangeDetectorRef, Compiler, Component, Injector, ViewChild, } from
|
|
4
|
-
import { ActivatedRoute, NavigationEnd, Router, RoutesRecognized, } from
|
|
5
|
-
import { SdNotifyService } from
|
|
6
|
-
import { SdTabActivated, SdTabDeactivated, } from
|
|
7
|
-
import { SdTabRouterService } from
|
|
8
|
-
import { Subscription } from
|
|
9
|
-
import { SdTabDecoratorService } from
|
|
10
|
-
import { filter } from
|
|
11
|
-
import * as hash from
|
|
3
|
+
import { ChangeDetectorRef, Compiler, Component, Injector, ViewChild, } from '@angular/core';
|
|
4
|
+
import { ActivatedRoute, NavigationEnd, Router, RoutesRecognized, } from '@angular/router';
|
|
5
|
+
import { SdNotifyService } from '@sd-angular/core/notify';
|
|
6
|
+
import { SdTabActivated, SdTabDeactivated, } from '../../events/tab-router.event';
|
|
7
|
+
import { SdTabRouterService } from '../../services/tab-router.service';
|
|
8
|
+
import { Subscription } from 'rxjs';
|
|
9
|
+
import { SdTabDecoratorService } from '../../services/tab-decorator.service';
|
|
10
|
+
import { filter } from 'rxjs/operators';
|
|
11
|
+
import * as hash from 'object-hash';
|
|
12
12
|
export class SdTabRouterOutletComponent {
|
|
13
13
|
constructor(router, activatedRoute, cd, injector, compiler, tabDecoratorService, tabRouterService, sdNotifyService) {
|
|
14
14
|
this.router = router;
|
|
@@ -25,19 +25,24 @@ export class SdTabRouterOutletComponent {
|
|
|
25
25
|
_firstLoad.set(this, true);
|
|
26
26
|
_closeTab.set(this, (tab) => {
|
|
27
27
|
var _a;
|
|
28
|
-
|
|
29
|
-
if (
|
|
30
|
-
const
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
28
|
+
const { isActive, key: activeKey } = tab;
|
|
29
|
+
if (isActive) {
|
|
30
|
+
const activeIndex = this.tabs.findIndex(({ key }) => key === activeKey);
|
|
31
|
+
const nextTab = this.tabs[activeIndex + 1] || this.tabs[activeIndex - 1];
|
|
32
|
+
if (nextTab) {
|
|
33
|
+
const { url: nextUrl } = nextTab;
|
|
34
|
+
const nextQueryParams = Object.assign({}, (nextTab.queryParams || {}));
|
|
35
|
+
this.tabs = this.tabs.filter(({ key }) => key !== activeKey);
|
|
36
|
+
this.router.navigate([nextUrl], {
|
|
37
|
+
queryParams: nextQueryParams,
|
|
34
38
|
state: {
|
|
35
39
|
switchTab: true,
|
|
36
40
|
},
|
|
37
41
|
});
|
|
38
42
|
}
|
|
39
43
|
else {
|
|
40
|
-
this.
|
|
44
|
+
this.tabs = this.tabs.filter(({ key }) => key !== activeKey);
|
|
45
|
+
this.router.navigateByUrl('/', {
|
|
41
46
|
state: {
|
|
42
47
|
switchTab: true,
|
|
43
48
|
},
|
|
@@ -45,6 +50,7 @@ export class SdTabRouterOutletComponent {
|
|
|
45
50
|
}
|
|
46
51
|
}
|
|
47
52
|
else {
|
|
53
|
+
this.tabs = this.tabs.filter(({ key }) => key !== tab.key);
|
|
48
54
|
(_a = this.tabRouterNav) === null || _a === void 0 ? void 0 : _a.checkUI();
|
|
49
55
|
this.cd.markForCheck();
|
|
50
56
|
}
|
|
@@ -57,8 +63,8 @@ export class SdTabRouterOutletComponent {
|
|
|
57
63
|
const component = route.component;
|
|
58
64
|
const queryParams = Object.assign({}, (route.queryParams || {}));
|
|
59
65
|
const params = Object.assign({}, (route.params || {}));
|
|
60
|
-
const
|
|
61
|
-
const
|
|
66
|
+
const [url] = fullUrl.split('?');
|
|
67
|
+
const key = hash({ url, queryParams });
|
|
62
68
|
let existedIndex = -1;
|
|
63
69
|
this.tabs.forEach((tab, index) => {
|
|
64
70
|
if (tab.key === key) {
|
|
@@ -79,7 +85,7 @@ export class SdTabRouterOutletComponent {
|
|
|
79
85
|
this.tabRouterService.pushEvent(existedTab, SdTabActivated);
|
|
80
86
|
}
|
|
81
87
|
else {
|
|
82
|
-
if (typeof ((_d = (_c = route === null || route === void 0 ? void 0 : route.parent) === null || _c === void 0 ? void 0 : _c.routeConfig) === null || _d === void 0 ? void 0 : _d.loadChildren) ===
|
|
88
|
+
if (typeof ((_d = (_c = route === null || route === void 0 ? void 0 : route.parent) === null || _c === void 0 ? void 0 : _c.routeConfig) === null || _d === void 0 ? void 0 : _d.loadChildren) === 'function') {
|
|
83
89
|
const module = yield route.parent.routeConfig.loadChildren();
|
|
84
90
|
const factory = yield this.compiler.compileModuleAsync(module);
|
|
85
91
|
const injector = factory.create(this.injector);
|
|
@@ -104,7 +110,7 @@ export class SdTabRouterOutletComponent {
|
|
|
104
110
|
}
|
|
105
111
|
(_g = this.tabRouterNav) === null || _g === void 0 ? void 0 : _g.checkUI();
|
|
106
112
|
if (this.tabs.length > 10) {
|
|
107
|
-
this.sdNotifyService.notify.warning(
|
|
113
|
+
this.sdNotifyService.notify.warning('Bạn đã mở quá nhiều tab. Vui lòng tắt các tab không dùng để hệ thống hoạt động tốt hơn.');
|
|
108
114
|
}
|
|
109
115
|
if (this.tabs.length > 12) {
|
|
110
116
|
this.tabs.splice(0, this.tabs.length - 10);
|
|
@@ -154,7 +160,7 @@ export class SdTabRouterOutletComponent {
|
|
|
154
160
|
}
|
|
155
161
|
})));
|
|
156
162
|
__classPrivateFieldGet(this, _subscription).add(tabRouterService.actions.subscribe((event) => {
|
|
157
|
-
if (event && event.type ===
|
|
163
|
+
if (event && event.type === 'close') {
|
|
158
164
|
__classPrivateFieldGet(this, _closeTab).call(this, event.tab);
|
|
159
165
|
}
|
|
160
166
|
}));
|
|
@@ -166,7 +172,7 @@ export class SdTabRouterOutletComponent {
|
|
|
166
172
|
_rootRoute = new WeakMap(), _subscription = new WeakMap(), _firstLoad = new WeakMap(), _closeTab = new WeakMap(), _activeRoute = new WeakMap(), _getActivatedRouteSnapshot = new WeakMap(), _getActivatedRoute = new WeakMap();
|
|
167
173
|
SdTabRouterOutletComponent.decorators = [
|
|
168
174
|
{ type: Component, args: [{
|
|
169
|
-
selector:
|
|
175
|
+
selector: 'sd-tab-router-outlet',
|
|
170
176
|
template: "<sd-tab-router-nav [tabs]=\"tabs\" #tabRouterNav></sd-tab-router-nav>\r\n\r\n<div class=\"tab-router__list\">\r\n <ng-container *ngFor=\"let tab of tabs\">\r\n <div class=\"tab-router__pane\" [class.active]=\"tab.isActive\" [id]=\"tab.key\">\r\n <div class=\"tab-router__content\">\r\n <ng-container\r\n *ngComponentOutlet=\"tab.component; injector: tab.injector\"\r\n ></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n",
|
|
171
177
|
styles: [":host{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%}::ng-deep page-layout{height:100%!important}.tab-router__list{flex:1}.tab-router__pane{display:none;height:100%;position:relative;width:100%}.tab-router__pane.active{display:block}.tab-router__content{bottom:0;height:100%;left:0;overflow:auto;position:absolute;right:0;top:0;width:100%}"]
|
|
172
178
|
},] }
|
|
@@ -182,7 +188,7 @@ SdTabRouterOutletComponent.ctorParameters = () => [
|
|
|
182
188
|
{ type: SdNotifyService }
|
|
183
189
|
];
|
|
184
190
|
SdTabRouterOutletComponent.propDecorators = {
|
|
185
|
-
tabRouterNav: [{ type: ViewChild, args: [
|
|
191
|
+
tabRouterNav: [{ type: ViewChild, args: ['tabRouterNav',] }]
|
|
186
192
|
};
|
|
187
193
|
class SdOutletInjector {
|
|
188
194
|
constructor(route,
|
|
@@ -201,4 +207,4 @@ class SdOutletInjector {
|
|
|
201
207
|
return this.parent.get(token, notFoundValue);
|
|
202
208
|
}
|
|
203
209
|
}
|
|
204
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-router-outlet.component.js","sourceRoot":"C:/Users/user/Documents/lib-core-ui/projects/sd-core/tab-router/","sources":["src/lib/components/tab-router-outlet/tab-router-outlet.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Compiler,\r\n  Component,\r\n  Injector,\r\n  NgModuleRef,\r\n  OnDestroy,\r\n  OnInit,\r\n  Type,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport {\r\n  ActivatedRoute,\r\n  ActivatedRouteSnapshot,\r\n  ChildrenOutletContexts,\r\n  // ChildrenOutletContexts,\r\n  Event,\r\n  NavigationEnd,\r\n  PRIMARY_OUTLET,\r\n  Router,\r\n  RoutesRecognized,\r\n} from \"@angular/router\";\r\nimport { SdNotifyService } from \"@sd-angular/core/notify\";\r\nimport {\r\n  SdTabActivated,\r\n  SdTabDeactivated,\r\n} from \"../../events/tab-router.event\";\r\n\r\nimport { SdTab } from \"../../models/tab-router.model\";\r\nimport { SdTabAction } from \"../../actions/tab-router.action\";\r\nimport { SdTabRouterService } from \"../../services/tab-router.service\";\r\nimport { SdTabRouterNavComponent } from \"../tab-router-nav/tab-router-nav.component\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { SdTabDecoratorService } from \"../../services/tab-decorator.service\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport * as hash from \"object-hash\";\r\n\r\n@Component({\r\n  selector: \"sd-tab-router-outlet\",\r\n  templateUrl: \"./tab-router-outlet.component.html\",\r\n  styleUrls: [\"./tab-router-outlet.component.scss\"],\r\n  // changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SdTabRouterOutletComponent implements OnDestroy {\r\n  @ViewChild(\"tabRouterNav\") tabRouterNav: SdTabRouterNavComponent;\r\n  tabs: SdTab[] = [];\r\n\r\n  #rootRoute: ActivatedRoute;\r\n  #subscription = new Subscription();\r\n  #firstLoad = true;\r\n  constructor(\r\n    private router: Router,\r\n    private activatedRoute: ActivatedRoute,\r\n    private cd: ChangeDetectorRef,\r\n    private injector: Injector,\r\n    private compiler: Compiler,\r\n    private tabDecoratorService: SdTabDecoratorService,\r\n    private tabRouterService: SdTabRouterService,\r\n    private sdNotifyService: SdNotifyService\r\n  ) {\r\n    this.#subscription.add(\r\n      router.events\r\n        .pipe(\r\n          filter(\r\n            (event) =>\r\n              event instanceof RoutesRecognized ||\r\n              event instanceof NavigationEnd\r\n          )\r\n        )\r\n        .subscribe(async (event: RoutesRecognized | NavigationEnd) => {\r\n          if (this.#firstLoad && event instanceof NavigationEnd) {\r\n            this.#firstLoad = false;\r\n            const route = this.#getActivatedRouteSnapshot(\r\n              this.activatedRoute.snapshot\r\n            );\r\n            this.#rootRoute = this.router.routerState.root;\r\n            await this.#activeRoute(\r\n              event.urlAfterRedirects || event.url,\r\n              route\r\n            );\r\n            return;\r\n          }\r\n          if (!this.#firstLoad && event instanceof RoutesRecognized) {\r\n            const route = this.#getActivatedRouteSnapshot(event.state.root);\r\n            this.#rootRoute = this.router.routerState.root;\r\n            await this.#activeRoute(\r\n              event.urlAfterRedirects || event.url,\r\n              route\r\n            );\r\n          }\r\n        })\r\n    );\r\n\r\n    this.#subscription.add(\r\n      tabRouterService.actions.subscribe((event: SdTabAction | null) => {\r\n        if (event && event.type === \"close\") {\r\n          this.#closeTab(event.tab);\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #closeTab = (tab: SdTab) => {\r\n    this.tabs = this.tabs.filter(({ key }) => key !== tab.key);\r\n    if (tab.isActive) {\r\n      const lastTab = this.tabs[this.tabs.length - 1];\r\n      if (lastTab) {\r\n        this.router.navigateByUrl(lastTab.url, {\r\n          queryParams: lastTab.queryParams || {},\r\n          state: {\r\n            switchTab: true,\r\n          },\r\n        });\r\n      } else {\r\n        this.router.navigateByUrl(\"/\", {\r\n          state: {\r\n            switchTab: true,\r\n          },\r\n        });\r\n      }\r\n    } else {\r\n      this.tabRouterNav?.checkUI();\r\n      this.cd.markForCheck();\r\n    }\r\n  };\r\n\r\n  #activeRoute = async (\r\n    fullUrl: string,\r\n    route: ActivatedRouteSnapshot | null\r\n  ) => {\r\n    if (!route?.component) {\r\n      return;\r\n    }\r\n    const component = route.component as Type<any>;\r\n    const queryParams = {\r\n      ...(route.queryParams || {}),\r\n    };\r\n    const params = {\r\n      ...(route.params || {}),\r\n    };\r\n    const key = hash({ url: fullUrl });\r\n    const [url] = fullUrl.split(\"?\");\r\n\r\n    let existedIndex = -1;\r\n    this.tabs.forEach((tab: SdTab, index: number) => {\r\n      if (tab.key === key) {\r\n        tab.isActive = true;\r\n        existedIndex = index;\r\n      } else {\r\n        if (tab.isActive) {\r\n          this.tabRouterService.pushEvent(tab, SdTabDeactivated);\r\n        }\r\n        tab.isActive = false;\r\n      }\r\n    });\r\n\r\n    const currentNavigation = this.router.getCurrentNavigation();\r\n    if (existedIndex >= 0 && currentNavigation?.extras?.state?.switchTab) {\r\n      const existedTab = this.tabs[existedIndex];\r\n      this.tabRouterService.setCurrentTab(existedTab);\r\n      this.tabRouterService.pushEvent(existedTab, SdTabActivated);\r\n    } else {\r\n      if (typeof route?.parent?.routeConfig?.loadChildren === \"function\") {\r\n        const module = await route.parent.routeConfig.loadChildren();\r\n        const factory = await this.compiler.compileModuleAsync(module);\r\n        const injector = factory.create(this.injector);\r\n        const activatedRoute = this.#getActivatedRoute(\r\n          this.#rootRoute,\r\n          component\r\n        );\r\n\r\n        const tab = {\r\n          key,\r\n          component,\r\n          injector: new SdOutletInjector(activatedRoute, injector),\r\n          isActive: true,\r\n          name: url,\r\n          url,\r\n          params,\r\n          queryParams,\r\n        };\r\n\r\n        this.tabRouterService.setCurrentTab(tab);\r\n        if (existedIndex >= 0 && !currentNavigation?.extras?.state?.switchTab) {\r\n          this.tabs[existedIndex] = tab;\r\n        } else {\r\n          this.tabs.push(tab);\r\n        }\r\n      }\r\n\r\n      this.tabRouterNav?.checkUI();\r\n      if (this.tabs.length > 10) {\r\n        this.sdNotifyService.notify.warning(\r\n          \"Bạn đã mở quá nhiều tab. Vui lòng tắt các tab không dùng để hệ thống hoạt động tốt hơn.\"\r\n        );\r\n      }\r\n      if (this.tabs.length > 12) {\r\n        this.tabs.splice(0, this.tabs.length - 10);\r\n      }\r\n    }\r\n    this.cd.markForCheck();\r\n  };\r\n\r\n  #getActivatedRouteSnapshot = (\r\n    activatedRouteSnapshot: ActivatedRouteSnapshot\r\n  ): ActivatedRouteSnapshot | null => {\r\n    if (!activatedRouteSnapshot) {\r\n      return null;\r\n    }\r\n    while (activatedRouteSnapshot.firstChild) {\r\n      activatedRouteSnapshot = activatedRouteSnapshot.firstChild;\r\n    }\r\n    return activatedRouteSnapshot;\r\n  };\r\n\r\n  #getActivatedRoute = (\r\n    activatedRoute: ActivatedRoute,\r\n    component: any\r\n  ): ActivatedRoute | null => {\r\n    if (!activatedRoute) {\r\n      return null;\r\n    }\r\n\r\n    if (activatedRoute.component && activatedRoute.component === component) {\r\n      return activatedRoute;\r\n    }\r\n    while (activatedRoute.firstChild) {\r\n      activatedRoute = activatedRoute.firstChild;\r\n      if (activatedRoute.component && activatedRoute.component === component) {\r\n        return activatedRoute;\r\n      }\r\n    }\r\n    return null;\r\n  };\r\n}\r\n\r\nclass SdOutletInjector implements Injector {\r\n  constructor(\r\n    private route: ActivatedRoute | null,\r\n    // private childContexts: ChildrenOutletContexts,\r\n    private parent: any\r\n  ) {}\r\n\r\n  get(token: any, notFoundValue?: any): any {\r\n    if (token === ActivatedRoute && this.route) {\r\n      return this.route;\r\n    }\r\n\r\n    // if (token === ChildrenOutletContexts) {\r\n    //   return this.childContexts;\r\n    // }\r\n\r\n    return this.parent.get(token, notFoundValue);\r\n  }\r\n}\r\n"]}
|
|
210
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-router-outlet.component.js","sourceRoot":"C:/Users/user/Documents/lib-core-ui/projects/sd-core/tab-router/","sources":["src/lib/components/tab-router-outlet/tab-router-outlet.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Compiler,\r\n  Component,\r\n  Injector,\r\n  NgModuleRef,\r\n  OnDestroy,\r\n  OnInit,\r\n  Type,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ActivatedRoute,\r\n  ActivatedRouteSnapshot,\r\n  ChildrenOutletContexts,\r\n  // ChildrenOutletContexts,\r\n  Event,\r\n  NavigationEnd,\r\n  PRIMARY_OUTLET,\r\n  Router,\r\n  RoutesRecognized,\r\n} from '@angular/router';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport {\r\n  SdTabActivated,\r\n  SdTabDeactivated,\r\n} from '../../events/tab-router.event';\r\n\r\nimport { SdTab } from '../../models/tab-router.model';\r\nimport { SdTabAction } from '../../actions/tab-router.action';\r\nimport { SdTabRouterService } from '../../services/tab-router.service';\r\nimport { SdTabRouterNavComponent } from '../tab-router-nav/tab-router-nav.component';\r\nimport { Subscription } from 'rxjs';\r\nimport { SdTabDecoratorService } from '../../services/tab-decorator.service';\r\nimport { filter } from 'rxjs/operators';\r\nimport * as hash from 'object-hash';\r\n\r\n@Component({\r\n  selector: 'sd-tab-router-outlet',\r\n  templateUrl: './tab-router-outlet.component.html',\r\n  styleUrls: ['./tab-router-outlet.component.scss'],\r\n  // changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SdTabRouterOutletComponent implements OnDestroy {\r\n  @ViewChild('tabRouterNav') tabRouterNav: SdTabRouterNavComponent;\r\n  tabs: SdTab[] = [];\r\n\r\n  #rootRoute: ActivatedRoute;\r\n  #subscription = new Subscription();\r\n  #firstLoad = true;\r\n  constructor(\r\n    private router: Router,\r\n    private activatedRoute: ActivatedRoute,\r\n    private cd: ChangeDetectorRef,\r\n    private injector: Injector,\r\n    private compiler: Compiler,\r\n    private tabDecoratorService: SdTabDecoratorService,\r\n    private tabRouterService: SdTabRouterService,\r\n    private sdNotifyService: SdNotifyService\r\n  ) {\r\n    this.#subscription.add(\r\n      router.events\r\n        .pipe(\r\n          filter(\r\n            (event) =>\r\n              event instanceof RoutesRecognized ||\r\n              event instanceof NavigationEnd\r\n          )\r\n        )\r\n        .subscribe(async (event: RoutesRecognized | NavigationEnd) => {\r\n          if (this.#firstLoad && event instanceof NavigationEnd) {\r\n            this.#firstLoad = false;\r\n            const route = this.#getActivatedRouteSnapshot(\r\n              this.activatedRoute.snapshot\r\n            );\r\n            this.#rootRoute = this.router.routerState.root;\r\n            await this.#activeRoute(\r\n              event.urlAfterRedirects || event.url,\r\n              route\r\n            );\r\n            return;\r\n          }\r\n          if (!this.#firstLoad && event instanceof RoutesRecognized) {\r\n            const route = this.#getActivatedRouteSnapshot(event.state.root);\r\n            this.#rootRoute = this.router.routerState.root;\r\n            await this.#activeRoute(\r\n              event.urlAfterRedirects || event.url,\r\n              route\r\n            );\r\n          }\r\n        })\r\n    );\r\n\r\n    this.#subscription.add(\r\n      tabRouterService.actions.subscribe((event: SdTabAction | null) => {\r\n        if (event && event.type === 'close') {\r\n          this.#closeTab(event.tab);\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #closeTab = (tab: SdTab) => {\r\n    const { isActive, key: activeKey } = tab;\r\n\r\n    if (isActive) {\r\n      const activeIndex = this.tabs.findIndex(({ key }) => key === activeKey);\r\n      const nextTab = this.tabs[activeIndex + 1] || this.tabs[activeIndex - 1];\r\n      if (nextTab) {\r\n        const { url: nextUrl } = nextTab;\r\n        const nextQueryParams = {\r\n          ...(nextTab.queryParams || {}),\r\n        };\r\n\r\n        this.tabs = this.tabs.filter(({ key }) => key !== activeKey);\r\n        this.router.navigate([nextUrl], {\r\n          queryParams: nextQueryParams,\r\n          state: {\r\n            switchTab: true,\r\n          },\r\n        });\r\n      } else {\r\n        this.tabs = this.tabs.filter(({ key }) => key !== activeKey);\r\n        this.router.navigateByUrl('/', {\r\n          state: {\r\n            switchTab: true,\r\n          },\r\n        });\r\n      }\r\n    } else {\r\n      this.tabs = this.tabs.filter(({ key }) => key !== tab.key);\r\n      this.tabRouterNav?.checkUI();\r\n      this.cd.markForCheck();\r\n    }\r\n  };\r\n\r\n  #activeRoute = async (\r\n    fullUrl: string,\r\n    route: ActivatedRouteSnapshot | null\r\n  ) => {\r\n    if (!route?.component) {\r\n      return;\r\n    }\r\n    const component = route.component as Type<any>;\r\n    const queryParams = {\r\n      ...(route.queryParams || {}),\r\n    };\r\n    const params = {\r\n      ...(route.params || {}),\r\n    };\r\n\r\n    const [url] = fullUrl.split('?');\r\n    const key = hash({ url, queryParams });\r\n\r\n    let existedIndex = -1;\r\n    this.tabs.forEach((tab: SdTab, index: number) => {\r\n      if (tab.key === key) {\r\n        tab.isActive = true;\r\n        existedIndex = index;\r\n      } else {\r\n        if (tab.isActive) {\r\n          this.tabRouterService.pushEvent(tab, SdTabDeactivated);\r\n        }\r\n        tab.isActive = false;\r\n      }\r\n    });\r\n\r\n    const currentNavigation = this.router.getCurrentNavigation();\r\n    if (existedIndex >= 0 && currentNavigation?.extras?.state?.switchTab) {\r\n      const existedTab = this.tabs[existedIndex];\r\n      this.tabRouterService.setCurrentTab(existedTab);\r\n      this.tabRouterService.pushEvent(existedTab, SdTabActivated);\r\n    } else {\r\n      if (typeof route?.parent?.routeConfig?.loadChildren === 'function') {\r\n        const module = await route.parent.routeConfig.loadChildren();\r\n        const factory = await this.compiler.compileModuleAsync(module);\r\n        const injector = factory.create(this.injector);\r\n        const activatedRoute = this.#getActivatedRoute(\r\n          this.#rootRoute,\r\n          component\r\n        );\r\n\r\n        const tab = {\r\n          key,\r\n          component,\r\n          injector: new SdOutletInjector(activatedRoute, injector),\r\n          isActive: true,\r\n          name: url,\r\n          url,\r\n          params,\r\n          queryParams,\r\n        };\r\n\r\n        this.tabRouterService.setCurrentTab(tab);\r\n        if (existedIndex >= 0 && !currentNavigation?.extras?.state?.switchTab) {\r\n          this.tabs[existedIndex] = tab;\r\n        } else {\r\n          this.tabs.push(tab);\r\n        }\r\n      }\r\n\r\n      this.tabRouterNav?.checkUI();\r\n      if (this.tabs.length > 10) {\r\n        this.sdNotifyService.notify.warning(\r\n          'Bạn đã mở quá nhiều tab. Vui lòng tắt các tab không dùng để hệ thống hoạt động tốt hơn.'\r\n        );\r\n      }\r\n      if (this.tabs.length > 12) {\r\n        this.tabs.splice(0, this.tabs.length - 10);\r\n      }\r\n    }\r\n    this.cd.markForCheck();\r\n  };\r\n\r\n  #getActivatedRouteSnapshot = (\r\n    activatedRouteSnapshot: ActivatedRouteSnapshot\r\n  ): ActivatedRouteSnapshot | null => {\r\n    if (!activatedRouteSnapshot) {\r\n      return null;\r\n    }\r\n    while (activatedRouteSnapshot.firstChild) {\r\n      activatedRouteSnapshot = activatedRouteSnapshot.firstChild;\r\n    }\r\n    return activatedRouteSnapshot;\r\n  };\r\n\r\n  #getActivatedRoute = (\r\n    activatedRoute: ActivatedRoute,\r\n    component: any\r\n  ): ActivatedRoute | null => {\r\n    if (!activatedRoute) {\r\n      return null;\r\n    }\r\n\r\n    if (activatedRoute.component && activatedRoute.component === component) {\r\n      return activatedRoute;\r\n    }\r\n    while (activatedRoute.firstChild) {\r\n      activatedRoute = activatedRoute.firstChild;\r\n      if (activatedRoute.component && activatedRoute.component === component) {\r\n        return activatedRoute;\r\n      }\r\n    }\r\n    return null;\r\n  };\r\n}\r\n\r\nclass SdOutletInjector implements Injector {\r\n  constructor(\r\n    private route: ActivatedRoute | null,\r\n    // private childContexts: ChildrenOutletContexts,\r\n    private parent: any\r\n  ) {}\r\n\r\n  get(token: any, notFoundValue?: any): any {\r\n    if (token === ActivatedRoute && this.route) {\r\n      return this.route;\r\n    }\r\n\r\n    // if (token === ChildrenOutletContexts) {\r\n    //   return this.childContexts;\r\n    // }\r\n\r\n    return this.parent.get(token, notFoundValue);\r\n  }\r\n}\r\n"]}
|