@tiba-spark/client-shared-lib 25.3.0-620 → 25.3.0-629
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/libraries/components/index.mjs +14 -12
- package/esm2022/libraries/components/message-bar/message-bar-container/message-bar-container.component.mjs +4 -3
- package/esm2022/libraries/components/overlay-loading-container/{empty-resutls/empty-resutls.component.mjs → empty-results/empty-results.component.mjs} +1 -1
- package/esm2022/libraries/components/overlay-loading-container/error-results/error-results.component.mjs +26 -0
- package/esm2022/libraries/components/overlay-loading-container/index.mjs +3 -2
- package/esm2022/libraries/components/overlay-loading-container/loading-overlay.component.mjs +7 -9
- package/esm2022/libraries/components/restart-link/restart-link.component.mjs +41 -0
- package/esm2022/libraries/components/restart-link/restart-link.module.mjs +28 -0
- package/esm2022/libraries/constants/global-constants.mjs +3 -1
- package/esm2022/libraries/modules/auth/refresh-token.state.mjs +1 -1
- package/esm2022/libraries/pipes/humanize.pipe.mjs +25 -0
- package/esm2022/libraries/pipes/index.mjs +2 -1
- package/esm2022/libraries/pipes/shared-pipes.module.mjs +11 -6
- package/esm2022/libraries/resolvers/version.resolver.mjs +4 -1
- package/esm2022/libraries/services/refresh-token.service.mjs +35 -6
- package/esm2022/libraries/services/smartpark.service.mjs +18 -5
- package/fesm2022/tiba-spark-client-shared-lib.mjs +863 -723
- package/fesm2022/tiba-spark-client-shared-lib.mjs.map +1 -1
- package/libraries/components/index.d.ts +13 -11
- package/libraries/components/index.d.ts.map +1 -1
- package/libraries/components/message-bar/message-bar-container/message-bar-container.component.d.ts +1 -0
- package/libraries/components/message-bar/message-bar-container/message-bar-container.component.d.ts.map +1 -1
- package/libraries/components/overlay-loading-container/{empty-resutls/empty-resutls.component.d.ts → empty-results/empty-results.component.d.ts} +1 -1
- package/libraries/components/overlay-loading-container/{empty-resutls/empty-resutls.component.d.ts.map → empty-results/empty-results.component.d.ts.map} +1 -1
- package/libraries/components/overlay-loading-container/error-results/error-results.component.d.ts +10 -0
- package/libraries/components/overlay-loading-container/error-results/error-results.component.d.ts.map +1 -0
- package/libraries/components/overlay-loading-container/index.d.ts +2 -1
- package/libraries/components/overlay-loading-container/index.d.ts.map +1 -1
- package/libraries/components/overlay-loading-container/loading-overlay.component.d.ts +0 -2
- package/libraries/components/overlay-loading-container/loading-overlay.component.d.ts.map +1 -1
- package/libraries/components/restart-link/restart-link.component.d.ts +19 -0
- package/libraries/components/restart-link/restart-link.component.d.ts.map +1 -0
- package/libraries/components/restart-link/restart-link.module.d.ts +10 -0
- package/libraries/components/restart-link/restart-link.module.d.ts.map +1 -0
- package/libraries/constants/global-constants.d.ts +2 -0
- package/libraries/constants/global-constants.d.ts.map +1 -1
- package/libraries/pipes/humanize.pipe.d.ts +16 -0
- package/libraries/pipes/humanize.pipe.d.ts.map +1 -0
- package/libraries/pipes/index.d.ts +1 -0
- package/libraries/pipes/index.d.ts.map +1 -1
- package/libraries/pipes/shared-pipes.module.d.ts +2 -1
- package/libraries/pipes/shared-pipes.module.d.ts.map +1 -1
- package/libraries/resolvers/version.resolver.d.ts.map +1 -1
- package/libraries/services/refresh-token.service.d.ts +6 -2
- package/libraries/services/refresh-token.service.d.ts.map +1 -1
- package/libraries/services/smartpark.service.d.ts +3 -1
- package/libraries/services/smartpark.service.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libraries/theme/_expansion-panel.scss +6 -1
- package/src/libraries/theme/mat-components/_mat-nav-list.scss +13 -0
|
@@ -13,6 +13,7 @@ export * from './filter-numbers.pipe';
|
|
|
13
13
|
export * from './filter.pipe';
|
|
14
14
|
export * from './format.pipe';
|
|
15
15
|
export * from './group-permission.pipe';
|
|
16
|
+
export * from './humanize.pipe';
|
|
16
17
|
export * from './order-by.pipe';
|
|
17
18
|
export * from './orphan-facilities.pipe';
|
|
18
19
|
export * from './smartpark-time.pipe';
|
|
@@ -27,4 +28,4 @@ export * from './translate-local.pipe';
|
|
|
27
28
|
export * from './tree-filter-keys.pipe';
|
|
28
29
|
export * from './wrap-fn.pipe';
|
|
29
30
|
export * from './zerofy-negative.pipe';
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtc2hhcmVkLWxpYi9zcmMvbGlicmFyaWVzL3BpcGVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFNBQVM7QUFDVCxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsdUJBQXVCLENBQUM7QUFFdEMsUUFBUTtBQUNSLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIE1vZHVsZVxuZXhwb3J0ICogZnJvbSAnLi9kZXZpY2UtcGlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zaGFyZWQtcGlwZXMubW9kdWxlJztcblxuLy8gUGlwZXNcbmV4cG9ydCAqIGZyb20gJy4vYy1sb2ctaXQucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2NlbnQtdG8tY29pbi5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vY3VybHktdG8tYm9sZC5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vZGVjaW1hbC10by1hbW91bnQucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2RlY2ltYWwtdG8tY3VycmVuY3kucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2VudW1zLXRvLWFycmF5LnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9maWx0ZXIta2V5cy5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVyLW51bWJlcnMucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlci5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybWF0LnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9ncm91cC1wZXJtaXNzaW9uLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9odW1hbml6ZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vb3JkZXItYnkucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL29ycGhhbi1mYWNpbGl0aWVzLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zbWFydHBhcmstdGltZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vc29ydC5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vc3BlY2lhbC1kYXkucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3N0cmluZy1pdC5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vc3Vic3RyLWhpZ2hsaWdodC5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vdGltZS1hZ28ucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3RpbWUtZWxhcHNlZC5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vdGltZS1yYW5nZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNsYXRlLWxvY2FsLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi90cmVlLWZpbHRlci1rZXlzLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi93cmFwLWZuLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi96ZXJvZnktbmVnYXRpdmUucGlwZSc7XG4iXX0=
|
|
@@ -9,7 +9,11 @@ import { FilterKeysPipe } from './filter-keys.pipe';
|
|
|
9
9
|
import { FilterNumbersPipe } from './filter-numbers.pipe';
|
|
10
10
|
import { FilterPipe } from './filter.pipe';
|
|
11
11
|
import { TBFormatPipe } from './format.pipe';
|
|
12
|
+
import { GroupPermissionsPipe } from './group-permission.pipe';
|
|
13
|
+
import { HumanizePipe } from './humanize.pipe';
|
|
12
14
|
import { OrderByPipe } from './order-by.pipe';
|
|
15
|
+
import { OrphanFacilitiesPipe } from './orphan-facilities.pipe';
|
|
16
|
+
import { SmartparkDateTimePipe } from './smartpark-time.pipe';
|
|
13
17
|
import { SortPipe } from './sort.pipe';
|
|
14
18
|
import { StringItPipe } from './string-it.pipe';
|
|
15
19
|
import { SubstrHightlightPipe } from './substr-highlight.pipe';
|
|
@@ -20,9 +24,6 @@ import { TranslateLocalPipe } from './translate-local.pipe';
|
|
|
20
24
|
import { TreeFilterKeysPipe } from './tree-filter-keys.pipe';
|
|
21
25
|
import { WrapFnPipe } from './wrap-fn.pipe';
|
|
22
26
|
import { ZerofyNegativePipe } from './zerofy-negative.pipe';
|
|
23
|
-
import { SmartparkDateTimePipe } from './smartpark-time.pipe';
|
|
24
|
-
import { OrphanFacilitiesPipe } from './orphan-facilities.pipe';
|
|
25
|
-
import { GroupPermissionsPipe } from './group-permission.pipe';
|
|
26
27
|
import * as i0 from "@angular/core";
|
|
27
28
|
export class SharedPipesModule {
|
|
28
29
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SharedPipesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
@@ -49,7 +50,8 @@ export class SharedPipesModule {
|
|
|
49
50
|
ZerofyNegativePipe,
|
|
50
51
|
SubstrHightlightPipe,
|
|
51
52
|
GroupPermissionsPipe,
|
|
52
|
-
OrphanFacilitiesPipe
|
|
53
|
+
OrphanFacilitiesPipe,
|
|
54
|
+
HumanizePipe], exports: [SmartparkDateTimePipe,
|
|
53
55
|
CLogItPipe,
|
|
54
56
|
CentToCoinPipe,
|
|
55
57
|
CurlyToBoldPipe,
|
|
@@ -72,7 +74,8 @@ export class SharedPipesModule {
|
|
|
72
74
|
ZerofyNegativePipe,
|
|
73
75
|
SubstrHightlightPipe,
|
|
74
76
|
GroupPermissionsPipe,
|
|
75
|
-
OrphanFacilitiesPipe
|
|
77
|
+
OrphanFacilitiesPipe,
|
|
78
|
+
HumanizePipe] }); }
|
|
76
79
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SharedPipesModule }); }
|
|
77
80
|
}
|
|
78
81
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SharedPipesModule, decorators: [{
|
|
@@ -104,6 +107,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
104
107
|
SubstrHightlightPipe,
|
|
105
108
|
GroupPermissionsPipe,
|
|
106
109
|
OrphanFacilitiesPipe,
|
|
110
|
+
HumanizePipe,
|
|
107
111
|
],
|
|
108
112
|
exports: [
|
|
109
113
|
SmartparkDateTimePipe,
|
|
@@ -130,7 +134,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
130
134
|
SubstrHightlightPipe,
|
|
131
135
|
GroupPermissionsPipe,
|
|
132
136
|
OrphanFacilitiesPipe,
|
|
137
|
+
HumanizePipe,
|
|
133
138
|
],
|
|
134
139
|
}]
|
|
135
140
|
}] });
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLXBpcGVzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC1zaGFyZWQtbGliL3NyYy9saWJyYXJpZXMvcGlwZXMvc2hhcmVkLXBpcGVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ25FLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDL0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM5QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsUUFBUSxF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TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDTG9nSXRQaXBlIH0gZnJvbSAnLi9jLWxvZy1pdC5waXBlJztcbmltcG9ydCB7IENlbnRUb0NvaW5QaXBlIH0gZnJvbSAnLi9jZW50LXRvLWNvaW4ucGlwZSc7XG5pbXBvcnQgeyBDdXJseVRvQm9sZFBpcGUgfSBmcm9tICcuL2N1cmx5LXRvLWJvbGQucGlwZSc7XG5pbXBvcnQgeyBEZWNpbWFsVG9BbW91bnRQaXBlIH0gZnJvbSAnLi9kZWNpbWFsLXRvLWFtb3VudC5waXBlJztcbmltcG9ydCB7IERlY2ltYWxUb0N1cnJlbmN5UGlwZSB9IGZyb20gJy4vZGVjaW1hbC10by1jdXJyZW5jeS5waXBlJztcbmltcG9ydCB7IEVudW1zVG9BcnJheVBpcGUgfSBmcm9tICcuL2VudW1zLXRvLWFycmF5LnBpcGUnO1xuaW1wb3J0IHsgRmlsdGVyS2V5c1BpcGUgfSBmcm9tICcuL2ZpbHRlci1rZXlzLnBpcGUnO1xuaW1wb3J0IHsgRmlsdGVyTnVtYmVyc1BpcGUgfSBmcm9tICcuL2ZpbHRlci1udW1iZXJzLnBpcGUnO1xuaW1wb3J0IHsgRmlsdGVyUGlwZSB9IGZyb20gJy4vZmlsdGVyLnBpcGUnO1xuaW1wb3J0IHsgVEJGb3JtYXRQaXBlIH0gZnJvbSAnLi9mb3JtYXQucGlwZSc7XG5pbXBvcnQgeyBHcm91cFBlcm1pc3Npb25zUGlwZSB9IGZyb20gJy4vZ3JvdXAtcGVybWlzc2lvbi5waXBlJztcbmltcG9ydCB7IEh1bWFuaXplUGlwZSB9IGZyb20gJy4vaHVtYW5pemUucGlwZSc7XG5pbXBvcnQgeyBPcmRlckJ5UGlwZSB9IGZyb20gJy4vb3JkZXItYnkucGlwZSc7XG5pbXBvcnQgeyBPcnBoYW5GYWNpbGl0aWVzUGlwZSB9IGZyb20gJy4vb3JwaGFuLWZhY2lsaXRpZXMucGlwZSc7XG5pbXBvcnQgeyBTbWFydHBhcmtEYXRlVGltZVBpcGUgfSBmcm9tICcuL3NtYXJ0cGFyay10aW1lLnBpcGUnO1xuaW1wb3J0IHsgU29ydFBpcGUgfSBmcm9tICcuL3NvcnQucGlwZSc7XG5pbXBvcnQgeyBTdHJpbmdJdFBpcGUgfSBmcm9tICcuL3N0cmluZy1pdC5waXBlJztcbmltcG9ydCB7IFN1YnN0ckhpZ2h0bGlnaHRQaXBlIH0gZnJvbSAnLi9zdWJzdHItaGlnaGxpZ2h0LnBpcGUnO1xuaW1wb3J0IHsgVGltZUFnb1BpcGUgfSBmcm9tICcuL3RpbWUtYWdvLnBpcGUnO1xuaW1wb3J0IHsgVGltZUVsYXBzZWRQaXBlIH0gZnJvbSAnLi90aW1lLWVsYXBzZWQucGlwZSc7XG5pbXBvcnQgeyBUaW1lUmFuZ2VQaXBlIH0gZnJvbSAnLi90aW1lLXJhbmdlLnBpcGUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTG9jYWxQaXBlIH0gZnJvbSAnLi90cmFuc2xhdGUtbG9jYWwucGlwZSc7XG5pbXBvcnQgeyBUcmVlRmlsdGVyS2V5c1BpcGUgfSBmcm9tICcuL3RyZWUtZmlsdGVyLWtleXMucGlwZSc7XG5pbXBvcnQgeyBXcmFwRm5QaXBlIH0gZnJvbSAnLi93cmFwLWZuLnBpcGUnO1xuaW1wb3J0IHsgWmVyb2Z5TmVnYXRpdmVQaXBlIH0gZnJvbSAnLi96ZXJvZnktbmVnYXRpdmUucGlwZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgU21hcnRwYXJrRGF0ZVRpbWVQaXBlLFxuICAgIENMb2dJdFBpcGUsXG4gICAgQ2VudFRvQ29pblBpcGUsXG4gICAgQ3VybHlUb0JvbGRQaXBlLFxuICAgIERlY2ltYWxUb0Ftb3VudFBpcGUsXG4gICAgRGVjaW1hbFRvQ3VycmVuY3lQaXBlLFxuICAgIEVudW1zVG9BcnJheVBpcGUsXG4gICAgRmlsdGVyS2V5c1BpcGUsXG4gICAgRmlsdGVyTnVtYmVyc1BpcGUsXG4gICAgRmlsdGVyUGlwZSxcbiAgICBUQkZvcm1hdFBpcGUsXG4gICAgT3JkZXJCeVBpcGUsXG4gICAgU29ydFBpcGUsXG4gICAgU3RyaW5nSXRQaXBlLFxuICAgIFRpbWVBZ29QaXBlLFxuICAgIFRpbWVFbGFwc2VkUGlwZSxcbiAgICBUaW1lUmFuZ2VQaXBlLFxuICAgIFRyYW5zbGF0ZUxvY2FsUGlwZSxcbiAgICBUcmVlRmlsdGVyS2V5c1BpcGUsXG4gICAgV3JhcEZuUGlwZSxcbiAgICBaZXJvZnlOZWdhdGl2ZVBpcGUsXG4gICAgU3Vic3RySGlnaHRsaWdodFBpcGUsXG4gICAgR3JvdXBQZXJtaXNzaW9uc1BpcGUsXG4gICAgT3JwaGFuRmFjaWxpdGllc1BpcGUsXG4gICAgSHVtYW5pemVQaXBlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgU21hcnRwYXJrRGF0ZVRpbWVQaXBlLFxuICAgIENMb2dJdFBpcGUsXG4gICAgQ2VudFRvQ29pblBpcGUsXG4gICAgQ3VybHlUb0JvbGRQaXBlLFxuICAgIERlY2ltYWxUb0Ftb3VudFBpcGUsXG4gICAgRGVjaW1hbFRvQ3VycmVuY3lQaXBlLFxuICAgIEVudW1zVG9BcnJheVBpcGUsXG4gICAgRmlsdGVyS2V5c1BpcGUsXG4gICAgRmlsdGVyTnVtYmVyc1BpcGUsXG4gICAgRmlsdGVyUGlwZSxcbiAgICBUQkZvcm1hdFBpcGUsXG4gICAgT3JkZXJCeVBpcGUsXG4gICAgU29ydFBpcGUsXG4gICAgU3RyaW5nSXRQaXBlLFxuICAgIFRpbWVBZ29QaXBlLFxuICAgIFRpbWVFbGFwc2VkUGlwZSxcbiAgICBUaW1lUmFuZ2VQaXBlLFxuICAgIFRyYW5zbGF0ZUxvY2FsUGlwZSxcbiAgICBUcmVlRmlsdGVyS2V5c1BpcGUsXG4gICAgV3JhcEZuUGlwZSxcbiAgICBaZXJvZnlOZWdhdGl2ZVBpcGUsXG4gICAgU3Vic3RySGlnaHRsaWdodFBpcGUsXG4gICAgR3JvdXBQZXJtaXNzaW9uc1BpcGUsXG4gICAgT3JwaGFuRmFjaWxpdGllc1BpcGUsXG4gICAgSHVtYW5pemVQaXBlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBTaGFyZWRQaXBlc01vZHVsZSB7IH1cbiJdfQ==
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
+
import { catchError, of } from 'rxjs';
|
|
2
3
|
import { tap } from 'rxjs/operators';
|
|
3
4
|
import { SetSmartParkVersionsAction } from '../modules/smartparks/smartpark.actions';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
@@ -12,6 +13,8 @@ export class VersionResolver {
|
|
|
12
13
|
resolve() {
|
|
13
14
|
return this.smartparkServiceProxy.versions().pipe(tap(versionsMap => {
|
|
14
15
|
this.store.dispatch(new SetSmartParkVersionsAction(versionsMap.data));
|
|
16
|
+
}), catchError(() => {
|
|
17
|
+
return of(null);
|
|
15
18
|
}));
|
|
16
19
|
}
|
|
17
20
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: VersionResolver, deps: [{ token: i1.SmartparkServiceProxy }, { token: i2.Store }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
@@ -20,4 +23,4 @@ export class VersionResolver {
|
|
|
20
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: VersionResolver, decorators: [{
|
|
21
24
|
type: Injectable
|
|
22
25
|
}], ctorParameters: () => [{ type: i1.SmartparkServiceProxy }, { type: i2.Store }] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5yZXNvbHZlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC1zaGFyZWQtbGliL3NyYy9saWJyYXJpZXMvcmVzb2x2ZXJzL3ZlcnNpb24ucmVzb2x2ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsVUFBVSxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNsRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUNBQXlDLENBQUM7Ozs7QUFJckYsTUFBTSxPQUFPLGVBQWU7SUFFMUIsWUFBb0IscUJBQTRDLEVBQVUsS0FBWTtRQUFsRSwwQkFBcUIsR0FBckIscUJBQXFCLENBQXVCO1FBQVUsVUFBSyxHQUFMLEtBQUssQ0FBTztJQUN0RixDQUFDO0lBRUQsT0FBTztRQUNMLE9BQU8sSUFBSSxDQUFDLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksQ0FDL0MsR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUFFO1lBQ2hCLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksMEJBQTBCLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDeEUsQ0FBQyxDQUFDLEVBQ0YsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2xCLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDOytHQWRVLGVBQWU7bUhBQWYsZUFBZTs7NEZBQWYsZUFBZTtrQkFEM0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN0b3JlIH0gZnJvbSAnQG5neHMvc3RvcmUnO1xuaW1wb3J0IHsgY2F0Y2hFcnJvciwgT2JzZXJ2YWJsZSwgb2YgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IFNldFNtYXJ0UGFya1ZlcnNpb25zQWN0aW9uIH0gZnJvbSAnLi4vbW9kdWxlcy9zbWFydHBhcmtzL3NtYXJ0cGFyay5hY3Rpb25zJztcbmltcG9ydCB7IFNtYXJ0cGFya1NlcnZpY2VQcm94eSwgU3RyaW5nU3RyaW5nSURpY3Rpb25hcnlIdHRwUmVzcG9uc2VEYXRhIH0gZnJvbSAnLi4vc2VydmljZS1wcm94eS9jbG91ZC1zZXJ2aWNlLXByb3hpZXMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgVmVyc2lvblJlc29sdmVyIHtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHNtYXJ0cGFya1NlcnZpY2VQcm94eTogU21hcnRwYXJrU2VydmljZVByb3h5LCBwcml2YXRlIHN0b3JlOiBTdG9yZSkge1xuICB9XG5cbiAgcmVzb2x2ZSgpOiBPYnNlcnZhYmxlPFN0cmluZ1N0cmluZ0lEaWN0aW9uYXJ5SHR0cFJlc3BvbnNlRGF0YT4ge1xuICAgIHJldHVybiB0aGlzLnNtYXJ0cGFya1NlcnZpY2VQcm94eS52ZXJzaW9ucygpLnBpcGUoXG4gICAgICB0YXAodmVyc2lvbnNNYXAgPT4ge1xuICAgICAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKG5ldyBTZXRTbWFydFBhcmtWZXJzaW9uc0FjdGlvbih2ZXJzaW9uc01hcC5kYXRhKSk7XG4gICAgICB9KSxcbiAgICAgIGNhdGNoRXJyb3IoKCkgPT4ge1xuICAgICAgICByZXR1cm4gb2YobnVsbCk7XG4gICAgICB9KVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,30 +1,36 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { ofActionDispatched } from '@ngxs/store';
|
|
3
|
+
import { first, Subject, throwError } from 'rxjs';
|
|
3
4
|
import { catchError, filter, finalize, switchMap, take, tap } from 'rxjs/operators';
|
|
4
5
|
import { VERSION_V1 } from '../constants/version-constants';
|
|
5
|
-
import { SetStateAction } from '../modules/auth/session.actions';
|
|
6
|
+
import { LogoutAction, LogoutMobileAction, SetStateAction } from '../modules/auth/session.actions';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@ngxs/store";
|
|
8
9
|
import * as i2 from "../service-proxy/identity-service-proxies";
|
|
9
10
|
import * as i3 from "./session-storage.service";
|
|
10
11
|
import * as i4 from "../service-proxy";
|
|
11
12
|
export class RefreshTokenService {
|
|
12
|
-
constructor(store, usersServiceProxyIdentity, sessionStorageService, mobileServiceProxyIdentity) {
|
|
13
|
+
constructor(store, usersServiceProxyIdentity, sessionStorageService, actions$, mobileServiceProxyIdentity) {
|
|
13
14
|
this.store = store;
|
|
14
15
|
this.usersServiceProxyIdentity = usersServiceProxyIdentity;
|
|
15
16
|
this.sessionStorageService = sessionStorageService;
|
|
17
|
+
this.actions$ = actions$;
|
|
16
18
|
this.mobileServiceProxyIdentity = mobileServiceProxyIdentity;
|
|
17
19
|
this.isRefreshing = false;
|
|
18
20
|
this.refreshTokenSubject = new Subject();
|
|
19
21
|
}
|
|
20
22
|
handleRefreshToken(request, next) {
|
|
21
23
|
if (!this.isRefreshing) {
|
|
24
|
+
const subscription = this.listenToLogoutAction();
|
|
22
25
|
this.isRefreshing = true;
|
|
23
26
|
const refreshInfo = this.sessionStorageService.getAuth;
|
|
24
27
|
return this.usersServiceProxyIdentity.refreshToken(refreshInfo?.refreshToken).pipe(switchMap(tokenResult => {
|
|
25
28
|
this.setAuthSession(tokenResult.data);
|
|
26
29
|
return next.handle(this.addToken(request, tokenResult.data.accessToken));
|
|
27
30
|
}), catchError((error) => throwError(() => error)), finalize(() => {
|
|
31
|
+
if (subscription) {
|
|
32
|
+
subscription.unsubscribe();
|
|
33
|
+
}
|
|
28
34
|
this.isRefreshing = false;
|
|
29
35
|
// Process the request queue after token refresh completes
|
|
30
36
|
this.refreshTokenSubject.next(this.sessionStorageService.accessToken);
|
|
@@ -37,12 +43,16 @@ export class RefreshTokenService {
|
|
|
37
43
|
}
|
|
38
44
|
handleMobileRefreshToken(request, next) {
|
|
39
45
|
if (!this.isRefreshing) {
|
|
46
|
+
const subscription = this.listenToLogoutMobileAction();
|
|
40
47
|
this.isRefreshing = true;
|
|
41
48
|
const refreshInfo = this.sessionStorageService.getAuth;
|
|
42
49
|
return this.mobileServiceProxyIdentity.mobileRefreshToken(refreshInfo?.refreshToken, VERSION_V1).pipe(switchMap(tokenResult => {
|
|
43
50
|
this.setAuthSession(tokenResult.data);
|
|
44
51
|
return next.handle(this.addToken(request, tokenResult.data.accessToken));
|
|
45
52
|
}), catchError((error) => throwError(() => error)), finalize(() => {
|
|
53
|
+
if (subscription) {
|
|
54
|
+
subscription.unsubscribe();
|
|
55
|
+
}
|
|
46
56
|
this.isRefreshing = false;
|
|
47
57
|
// Process the request queue after token refresh completes
|
|
48
58
|
this.refreshTokenSubject.next(this.sessionStorageService.accessToken);
|
|
@@ -73,6 +83,25 @@ export class RefreshTokenService {
|
|
|
73
83
|
this.sessionStorageService.setAuthSession(tokenResult.accessToken, newRefreshData);
|
|
74
84
|
this.store.dispatch(new SetStateAction(tokenResult.accessToken, newRefreshData));
|
|
75
85
|
}
|
|
86
|
+
listenToLogoutAction() {
|
|
87
|
+
return this.actions$
|
|
88
|
+
.pipe(ofActionDispatched(LogoutAction), first())
|
|
89
|
+
.subscribe(() => {
|
|
90
|
+
this.clearRefreshTokenQueue();
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
listenToLogoutMobileAction() {
|
|
94
|
+
return this.actions$
|
|
95
|
+
.pipe(ofActionDispatched(LogoutMobileAction), first())
|
|
96
|
+
.subscribe(() => {
|
|
97
|
+
this.clearRefreshTokenQueue();
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
clearRefreshTokenQueue() {
|
|
101
|
+
this.refreshTokenSubject.complete();
|
|
102
|
+
this.refreshTokenSubject = new Subject();
|
|
103
|
+
this.isRefreshing = false;
|
|
104
|
+
}
|
|
76
105
|
handleRefreshTokenQueue(request, next) {
|
|
77
106
|
return this.refreshTokenSubject.pipe(filter((token) => !this.isRefreshing && !!token), take(1), switchMap((token) => next.handle(this.addToken(request, token))));
|
|
78
107
|
}
|
|
@@ -83,10 +112,10 @@ export class RefreshTokenService {
|
|
|
83
112
|
}
|
|
84
113
|
});
|
|
85
114
|
}
|
|
86
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RefreshTokenService, deps: [{ token: i1.Store }, { token: i2.UsersServiceProxyIdentity }, { token: i3.SessionStorageService }, { token: i4.Identity.MobileServiceProxyIdentity }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
115
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RefreshTokenService, deps: [{ token: i1.Store }, { token: i2.UsersServiceProxyIdentity }, { token: i3.SessionStorageService }, { token: i1.Actions }, { token: i4.Identity.MobileServiceProxyIdentity }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
87
116
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RefreshTokenService }); }
|
|
88
117
|
}
|
|
89
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RefreshTokenService, decorators: [{
|
|
90
119
|
type: Injectable
|
|
91
|
-
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.UsersServiceProxyIdentity }, { type: i3.SessionStorageService }, { type: i4.Identity.MobileServiceProxyIdentity }] });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refresh-token.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/refresh-token.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpHandler, HttpRequest } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Store } from '@ngxs/store';\nimport { Observable, Subject, throwError } from 'rxjs';\nimport { catchError, filter, finalize, switchMap, take, tap } from 'rxjs/operators';\nimport { VERSION_V1 } from '../constants/version-constants';\nimport { RefreshInfo } from '../modules/auth/model/refresh-info.interface';\nimport { SetStateAction } from '../modules/auth/session.actions';\nimport { Identity } from '../service-proxy';\nimport { RefreshTokenDto, UsersServiceProxyIdentity } from '../service-proxy/identity-service-proxies';\nimport { SessionStorageService } from './session-storage.service';\n\n@Injectable()\nexport class RefreshTokenService {\n\n  private isRefreshing = false;\n  private refreshTokenSubject: Subject<any> = new Subject<any>();\n\n  constructor(private store: Store, private usersServiceProxyIdentity: UsersServiceProxyIdentity, private sessionStorageService: SessionStorageService,\n    private mobileServiceProxyIdentity: Identity.MobileServiceProxyIdentity,\n  ) {\n  }\n\n  public handleRefreshToken(request: HttpRequest<any>, next: HttpHandler): Observable<any> {\n    if (!this.isRefreshing) {\n      this.isRefreshing = true;\n      const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n      return this.usersServiceProxyIdentity.refreshToken(refreshInfo?.refreshToken).pipe(\n        switchMap(tokenResult => {\n          this.setAuthSession(tokenResult.data);\n\n          return next.handle(this.addToken(request, tokenResult.data.accessToken));\n        }),\n        catchError((error) => throwError(() => error)),\n        finalize(() => {\n          this.isRefreshing = false;\n          // Process the request queue after token refresh completes\n          this.refreshTokenSubject.next(this.sessionStorageService.accessToken);\n        })\n      );\n\n    } else {\n      // Queue the failed request\n      return this.handleRefreshTokenQueue(request, next);\n    }\n  }\n\n  public handleMobileRefreshToken(request: HttpRequest<any>, next: HttpHandler): Observable<any> {\n    if (!this.isRefreshing) {\n      this.isRefreshing = true;\n      const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n      return this.mobileServiceProxyIdentity.mobileRefreshToken(refreshInfo?.refreshToken, VERSION_V1).pipe(\n        switchMap(tokenResult => {\n          this.setAuthSession(tokenResult.data);\n\n          return next.handle(this.addToken(request, tokenResult.data.accessToken));\n        }),\n        catchError((error) => throwError(() => error)),\n        finalize(() => {\n          this.isRefreshing = false;\n          // Process the request queue after token refresh completes\n          this.refreshTokenSubject.next(this.sessionStorageService.accessToken);\n        })\n      );\n\n    } else {\n      // Queue the failed request\n      return this.handleRefreshTokenQueue(request, next);\n    }\n  }\n\n  public getRefreshToken(): Observable<any> {\n    const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n    return this.usersServiceProxyIdentity.refreshToken(refreshInfo?.refreshToken).pipe(tap({\n      next: tokenResult => this.setAuthSession(tokenResult.data)\n    }));\n  }\n\n  public getNewRefreshInfo(tokenResult: RefreshTokenDto): RefreshInfo {\n    const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n    const newRefreshData: RefreshInfo = {\n      refreshToken: tokenResult.refreshToken,\n      expiration: tokenResult.expiration,\n      refreshInterval: refreshInfo.refreshInterval,\n    };\n\n    return newRefreshData;\n  }\n\n  public setAuthSession(tokenResult: RefreshTokenDto) {\n    const newRefreshData: RefreshInfo = this.getNewRefreshInfo(tokenResult);\n    this.sessionStorageService.setAuthSession(tokenResult.accessToken, newRefreshData);\n    this.store.dispatch(new SetStateAction(tokenResult.accessToken, newRefreshData));\n  }\n\n  private handleRefreshTokenQueue(request: HttpRequest<any>, next: HttpHandler): Observable<any> {\n    return this.refreshTokenSubject.pipe(\n      filter((token) => !this.isRefreshing && !!token),\n      take(1),\n      switchMap((token: string) => next.handle(this.addToken(request, token)))\n    );\n  }\n\n  private addToken(request: HttpRequest<any>, token: string): HttpRequest<any> {\n    return request.clone({\n      setHeaders: {\n        Authorization: `Bearer ${token}`\n      }\n    });\n  }\n}\n"]}
|
|
120
|
+
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.UsersServiceProxyIdentity }, { type: i3.SessionStorageService }, { type: i1.Actions }, { type: i4.Identity.MobileServiceProxyIdentity }] });
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refresh-token.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/refresh-token.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpHandler, HttpRequest } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Actions, ofActionDispatched, Store } from '@ngxs/store';\nimport { first, Observable, Subject, Subscription, throwError } from 'rxjs';\nimport { catchError, filter, finalize, switchMap, take, tap } from 'rxjs/operators';\nimport { VERSION_V1 } from '../constants/version-constants';\nimport { RefreshInfo } from '../modules/auth/model/refresh-info.interface';\nimport { LogoutAction, LogoutMobileAction, SetStateAction } from '../modules/auth/session.actions';\nimport { Identity } from '../service-proxy';\nimport { RefreshTokenDto, UsersServiceProxyIdentity } from '../service-proxy/identity-service-proxies';\nimport { SessionStorageService } from './session-storage.service';\n\n@Injectable()\nexport class RefreshTokenService {\n\n  private isRefreshing = false;\n  private refreshTokenSubject: Subject<any> = new Subject<any>();\n\n  constructor(private store: Store, private usersServiceProxyIdentity: UsersServiceProxyIdentity, private sessionStorageService: SessionStorageService,\n    private actions$: Actions, private mobileServiceProxyIdentity: Identity.MobileServiceProxyIdentity,\n  ) {\n\n  }\n\n  public handleRefreshToken(request: HttpRequest<any>, next: HttpHandler): Observable<any> {\n    if (!this.isRefreshing) {\n      const subscription = this.listenToLogoutAction();\n      this.isRefreshing = true;\n      const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n      return this.usersServiceProxyIdentity.refreshToken(refreshInfo?.refreshToken).pipe(\n        switchMap(tokenResult => {\n          this.setAuthSession(tokenResult.data);\n\n          return next.handle(this.addToken(request, tokenResult.data.accessToken));\n        }),\n        catchError((error) => throwError(() => error)),\n        finalize(() => {\n          if (subscription) {\n            subscription.unsubscribe();\n          }\n\n          this.isRefreshing = false;\n          // Process the request queue after token refresh completes\n          this.refreshTokenSubject.next(this.sessionStorageService.accessToken);\n        })\n      );\n\n    } else {\n      // Queue the failed request\n      return this.handleRefreshTokenQueue(request, next);\n    }\n  }\n\n  public handleMobileRefreshToken(request: HttpRequest<any>, next: HttpHandler): Observable<any> {\n    if (!this.isRefreshing) {\n      const subscription = this.listenToLogoutMobileAction();\n      this.isRefreshing = true;\n      const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n      return this.mobileServiceProxyIdentity.mobileRefreshToken(refreshInfo?.refreshToken, VERSION_V1).pipe(\n        switchMap(tokenResult => {\n          this.setAuthSession(tokenResult.data);\n\n          return next.handle(this.addToken(request, tokenResult.data.accessToken));\n        }),\n        catchError((error) => throwError(() => error)),\n        finalize(() => {\n          if (subscription) {\n            subscription.unsubscribe();\n          }\n\n          this.isRefreshing = false;\n          // Process the request queue after token refresh completes\n          this.refreshTokenSubject.next(this.sessionStorageService.accessToken);\n        })\n      );\n\n    } else {\n      // Queue the failed request\n      return this.handleRefreshTokenQueue(request, next);\n    }\n  }\n\n  public getRefreshToken(): Observable<any> {\n    const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n    return this.usersServiceProxyIdentity.refreshToken(refreshInfo?.refreshToken).pipe(tap({\n      next: tokenResult => this.setAuthSession(tokenResult.data)\n    }));\n  }\n\n  public getNewRefreshInfo(tokenResult: RefreshTokenDto): RefreshInfo {\n    const refreshInfo: RefreshInfo = this.sessionStorageService.getAuth;\n    const newRefreshData: RefreshInfo = {\n      refreshToken: tokenResult.refreshToken,\n      expiration: tokenResult.expiration,\n      refreshInterval: refreshInfo.refreshInterval,\n    };\n\n    return newRefreshData;\n  }\n\n  public setAuthSession(tokenResult: RefreshTokenDto) {\n    const newRefreshData: RefreshInfo = this.getNewRefreshInfo(tokenResult);\n    this.sessionStorageService.setAuthSession(tokenResult.accessToken, newRefreshData);\n    this.store.dispatch(new SetStateAction(tokenResult.accessToken, newRefreshData));\n  }\n\n  private listenToLogoutAction(): Subscription {\n    return this.actions$\n      .pipe(ofActionDispatched(LogoutAction), first())\n      .subscribe(() => {\n        this.clearRefreshTokenQueue();\n      });\n  }\n\n  private listenToLogoutMobileAction(): Subscription {\n    return this.actions$\n      .pipe(ofActionDispatched(LogoutMobileAction), first())\n      .subscribe(() => {\n        this.clearRefreshTokenQueue();\n      });\n  }\n\n  private clearRefreshTokenQueue() {\n    this.refreshTokenSubject.complete();\n    this.refreshTokenSubject = new Subject<any>();\n    this.isRefreshing = false;\n  }\n\n  private handleRefreshTokenQueue(request: HttpRequest<any>, next: HttpHandler): Observable<any> {\n    return this.refreshTokenSubject.pipe(\n      filter((token) => !this.isRefreshing && !!token),\n      take(1),\n      switchMap((token: string) => next.handle(this.addToken(request, token)))\n    );\n  }\n\n  private addToken(request: HttpRequest<any>, token: string): HttpRequest<any> {\n    return request.clone({\n      setHeaders: {\n        Authorization: `Bearer ${token}`\n      }\n    });\n  }\n}\n"]}
|
|
@@ -1,25 +1,29 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { BehaviorSubject, catchError, combineLatest } from 'rxjs';
|
|
3
3
|
import { delay, map, startWith, tap } from 'rxjs/operators';
|
|
4
|
+
import { RestartLinkComponent } from '../components';
|
|
4
5
|
import { ONE_SECOND_IN_MILLISECONDS } from '../constants/global-constants';
|
|
5
6
|
import { ClearFacilityDictionaryAction, SetSmartparkBasicAllAction } from '../modules/facility/facility.actions';
|
|
6
7
|
import { ClearSmartparksBasicAction, SetSmartParkTableAction } from '../modules/smartparks/smartpark.actions';
|
|
7
8
|
import { SmartparkState } from '../modules/smartparks/smartpark.state';
|
|
9
|
+
import { HttpStatusCode } from '../service-proxy/cloud-service-proxies';
|
|
8
10
|
import * as i0 from "@angular/core";
|
|
9
11
|
import * as i1 from "@ngxs/store";
|
|
10
12
|
import * as i2 from "../service-proxy/edge-service-proxies";
|
|
11
13
|
import * as i3 from "../utils/ngxs/action-status.service";
|
|
14
|
+
import * as i4 from "../components";
|
|
12
15
|
export class SmartparkService {
|
|
13
16
|
get loading$() {
|
|
14
17
|
return this.loading.asObservable();
|
|
15
18
|
}
|
|
16
19
|
get hasError$() {
|
|
17
|
-
return this.
|
|
20
|
+
return this.hasError.asObservable();
|
|
18
21
|
}
|
|
19
|
-
constructor(store, facilityServiceProxy, actionStatusService) {
|
|
22
|
+
constructor(store, facilityServiceProxy, actionStatusService, messageBarService) {
|
|
20
23
|
this.store = store;
|
|
21
24
|
this.facilityServiceProxy = facilityServiceProxy;
|
|
22
25
|
this.actionStatusService = actionStatusService;
|
|
26
|
+
this.messageBarService = messageBarService;
|
|
23
27
|
this.loading = new BehaviorSubject(false);
|
|
24
28
|
this.hasError = new BehaviorSubject(false);
|
|
25
29
|
}
|
|
@@ -41,6 +45,15 @@ export class SmartparkService {
|
|
|
41
45
|
}), catchError(e => {
|
|
42
46
|
this.hasError.next(true);
|
|
43
47
|
this.loading.next(false);
|
|
48
|
+
if (e.status !== HttpStatusCode.RequestTimeout) {
|
|
49
|
+
const messageInfo = {
|
|
50
|
+
duration: ONE_SECOND_IN_MILLISECONDS * 15,
|
|
51
|
+
action: {
|
|
52
|
+
component: RestartLinkComponent
|
|
53
|
+
},
|
|
54
|
+
};
|
|
55
|
+
this.messageBarService.warn("", messageInfo);
|
|
56
|
+
}
|
|
44
57
|
throw e;
|
|
45
58
|
}));
|
|
46
59
|
}
|
|
@@ -71,10 +84,10 @@ export class SmartparkService {
|
|
|
71
84
|
}
|
|
72
85
|
return loadingOverlayOptions;
|
|
73
86
|
}
|
|
74
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SmartparkService, deps: [{ token: i1.Store }, { token: i2.FacilityServiceProxy }, { token: i3.ActionStatusService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
87
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SmartparkService, deps: [{ token: i1.Store }, { token: i2.FacilityServiceProxy }, { token: i3.ActionStatusService }, { token: i4.MessageBarService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
75
88
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SmartparkService }); }
|
|
76
89
|
}
|
|
77
90
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SmartparkService, decorators: [{
|
|
78
91
|
type: Injectable
|
|
79
|
-
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.FacilityServiceProxy }, { type: i3.ActionStatusService }] });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartpark.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/smartpark.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { ActionType, Store } from '@ngxs/store';\nimport { BehaviorSubject, catchError, combineLatest, Observable } from 'rxjs';\nimport { delay, map, startWith, tap } from 'rxjs/operators';\nimport { ONE_SECOND_IN_MILLISECONDS } from '../constants/global-constants';\nimport { LoadingOverlayOptions } from '../interfaces/loading-overlay-options';\nimport { ClearFacilityDictionaryAction, SetSmartparkBasicAllAction } from '../modules/facility/facility.actions';\nimport { ClearSmartparksBasicAction, SetSmartParkTableAction } from '../modules/smartparks/smartpark.actions';\nimport { SmartparkState } from '../modules/smartparks/smartpark.state';\nimport { AppModule } from '../service-proxy/cloud-service-proxies';\nimport { FacilityServiceProxy, SmartParkWrapperDtoHttpResponseData } from '../service-proxy/edge-service-proxies';\nimport { ActionStatusService } from '../utils/ngxs/action-status.service';\n\n@Injectable()\nexport class SmartparkService {\n\n  get loading$(): Observable<boolean> {\n    return this.loading.asObservable();\n  }\n\n  get hasError$(): Observable<boolean> {\n    return this.loading.asObservable();\n  }\n\n  private loading: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  private hasError: BehaviorSubject<boolean> = new BehaviorSubject(false);\n\n  constructor(\n    private store: Store,\n    private facilityServiceProxy: FacilityServiceProxy,\n    private actionStatusService: ActionStatusService\n  ) {\n  }\n\n  public getSmartparkBasicAll(appModule: AppModule, setSmartparkBasic = true): Observable<SmartParkWrapperDtoHttpResponseData> {\n    this.hasError.next(false);\n    this.loading.next(true);\n\n    if (setSmartparkBasic) {\n      this.store.dispatch(new SetSmartParkTableAction(null));\n      this.store.dispatch(new ClearSmartparksBasicAction());\n      this.store.dispatch(new ClearFacilityDictionaryAction());\n    }\n\n    // the subModule sent in the header by the CloudAuthTokenInterceptor\n    const response: Observable<SmartParkWrapperDtoHttpResponseData> = this.facilityServiceProxy.getSmartparkBasicAll(appModule);\n    return response.pipe(tap(smartparkBasic => {\n      if (setSmartparkBasic) {\n        this.store.dispatch(new SetSmartparkBasicAllAction(smartparkBasic));\n      }\n\n      this.loading.next(false);\n    }),\n      catchError(e => {\n        this.hasError.next(true);\n        this.loading.next(false);\n        throw e;\n      })\n    );\n  }\n\n  public getLoadingOverlayOptions(actions: ActionType | ActionType[], noDataMessage: string = null): LoadingOverlayOptions {\n    const loading$ = this.getLoadingStream(actions);\n    const hasError$ = this.getErrorStream(actions);\n\n    return this.createLoadingOverlayOptions(loading$, hasError$, noDataMessage);\n  }\n\n  private getLoadingStream(actions: ActionType | ActionType[]): Observable<boolean> {\n    const isSmartparkDataLoaded = this.store.selectSnapshot(SmartparkState.smartparks) !== null;\n    const response$ = isSmartparkDataLoaded ? this.actionStatusService.actionsExecuting$(actions) :\n      (\n        combineLatest([\n          this.loading$.pipe(delay(ONE_SECOND_IN_MILLISECONDS)),\n          this.actionStatusService.actionsExecuting$(actions)\n        ]).pipe(\n          map(([smartparksLoading, actionLoading]) => smartparksLoading || actionLoading),\n          startWith(true)\n        )\n      );\n    return response$;\n  }\n\n  private getErrorStream(actions: ActionType | ActionType[]): Observable<boolean> {\n    return this.actionStatusService.actionsErrored$(actions);\n  }\n\n  private createLoadingOverlayOptions(loading$: Observable<boolean>, hasError$: Observable<boolean>, noDataMessage: string): LoadingOverlayOptions {\n    const loadingOverlayOptions: LoadingOverlayOptions = {\n      loading$,\n      hasError$,\n    };\n\n    if (noDataMessage) {\n      loadingOverlayOptions.emptyResultsOptions = { noDataMessage };\n    }\n\n    return loadingOverlayOptions;\n  }\n}\n"]}
|
|
92
|
+
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.FacilityServiceProxy }, { type: i3.ActionStatusService }, { type: i4.MessageBarService }] });
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartpark.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/smartpark.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { ActionType, Store } from '@ngxs/store';\nimport { BehaviorSubject, catchError, combineLatest, Observable } from 'rxjs';\nimport { delay, map, startWith, tap } from 'rxjs/operators';\nimport { MessageBarService, MessageInfo, RestartLinkComponent } from '../components';\nimport { ONE_SECOND_IN_MILLISECONDS } from '../constants/global-constants';\nimport { LoadingOverlayOptions } from '../interfaces/loading-overlay-options';\nimport { ClearFacilityDictionaryAction, SetSmartparkBasicAllAction } from '../modules/facility/facility.actions';\nimport { ClearSmartparksBasicAction, SetSmartParkTableAction } from '../modules/smartparks/smartpark.actions';\nimport { SmartparkState } from '../modules/smartparks/smartpark.state';\nimport { AppModule, HttpStatusCode } from '../service-proxy/cloud-service-proxies';\nimport { FacilityServiceProxy, SmartParkWrapperDtoHttpResponseData } from '../service-proxy/edge-service-proxies';\nimport { ActionStatusService } from '../utils/ngxs/action-status.service';\n\n@Injectable()\nexport class SmartparkService {\n\n  get loading$(): Observable<boolean> {\n    return this.loading.asObservable();\n  }\n\n  get hasError$(): Observable<boolean> {\n    return this.hasError.asObservable();\n  }\n\n  private loading: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  private hasError: BehaviorSubject<boolean> = new BehaviorSubject(false);\n\n  constructor(\n    private store: Store,\n    private facilityServiceProxy: FacilityServiceProxy,\n    private actionStatusService: ActionStatusService,\n    private messageBarService: MessageBarService,\n  ) {\n  }\n\n  public getSmartparkBasicAll(appModule: AppModule, setSmartparkBasic = true): Observable<SmartParkWrapperDtoHttpResponseData> {\n    this.hasError.next(false);\n    this.loading.next(true);\n\n    if (setSmartparkBasic) {\n      this.store.dispatch(new SetSmartParkTableAction(null));\n      this.store.dispatch(new ClearSmartparksBasicAction());\n      this.store.dispatch(new ClearFacilityDictionaryAction());\n    }\n\n    // the subModule sent in the header by the CloudAuthTokenInterceptor\n    const response: Observable<SmartParkWrapperDtoHttpResponseData> = this.facilityServiceProxy.getSmartparkBasicAll(appModule);\n    return response.pipe(\n      tap(smartparkBasic => {\n        if (setSmartparkBasic) {\n          this.store.dispatch(new SetSmartparkBasicAllAction(smartparkBasic));\n        }\n        this.loading.next(false);\n      }),\n      catchError(e => {\n        this.hasError.next(true);\n        this.loading.next(false);\n\n        if (e.status !== HttpStatusCode.RequestTimeout) {\n          const messageInfo: MessageInfo = {\n            duration: ONE_SECOND_IN_MILLISECONDS * 15,\n            action: {\n              component: RestartLinkComponent\n            },\n          };\n          this.messageBarService.warn(\"\", messageInfo);\n        }\n\n        throw e;\n      })\n    );\n  }\n\n  public getLoadingOverlayOptions(actions: ActionType | ActionType[], noDataMessage: string = null): LoadingOverlayOptions {\n    const loading$ = this.getLoadingStream(actions);\n    const hasError$ = this.getErrorStream(actions);\n\n    return this.createLoadingOverlayOptions(loading$, hasError$, noDataMessage);\n  }\n\n  private getLoadingStream(actions: ActionType | ActionType[]): Observable<boolean> {\n    const isSmartparkDataLoaded = this.store.selectSnapshot(SmartparkState.smartparks) !== null;\n    const response$ = isSmartparkDataLoaded ? this.actionStatusService.actionsExecuting$(actions) :\n      (\n        combineLatest([\n          this.loading$.pipe(delay(ONE_SECOND_IN_MILLISECONDS)),\n          this.actionStatusService.actionsExecuting$(actions)\n        ]).pipe(\n          map(([smartparksLoading, actionLoading]) => smartparksLoading || actionLoading),\n          startWith(true)\n        )\n      );\n    return response$;\n  }\n\n  private getErrorStream(actions: ActionType | ActionType[]): Observable<boolean> {\n    return this.actionStatusService.actionsErrored$(actions);\n  }\n\n  private createLoadingOverlayOptions(loading$: Observable<boolean>, hasError$: Observable<boolean>, noDataMessage: string): LoadingOverlayOptions {\n    const loadingOverlayOptions: LoadingOverlayOptions = {\n      loading$,\n      hasError$,\n    };\n\n    if (noDataMessage) {\n      loadingOverlayOptions.emptyResultsOptions = { noDataMessage };\n    }\n\n    return loadingOverlayOptions;\n  }\n}\n"]}
|