@ng-atomic/common 16.2.0 → 16.3.1
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/directives/fallback-src/fallback-src.directive.d.ts +9 -0
- package/directives/fallback-src/index.d.ts +1 -0
- package/esm2022/directives/fallback-src/fallback-src.directive.mjs +25 -0
- package/esm2022/directives/fallback-src/index.mjs +2 -0
- package/esm2022/directives/fallback-src/ng-atomic-common-directives-fallback-src.mjs +5 -0
- package/esm2022/directives/ios-safari-scroll-buggyfill/ios-safari-scroll-buggyfill.directive.mjs +4 -4
- package/esm2022/directives/ios-safari-scroll-buggyfill/ios-safari-scroll-buggyfill.module.mjs +5 -5
- package/esm2022/interceptors/authorization/authorization.interceptor.mjs +4 -4
- package/esm2022/interceptors/index.mjs +2 -0
- package/esm2022/interceptors/interceptors.module.mjs +54 -0
- package/esm2022/interceptors/ng-atomic-common-interceptors.mjs +5 -0
- package/esm2022/interceptors/throttle/throttle.interceptor.mjs +8 -8
- package/esm2022/interceptors/token/authorization.interceptor.mjs +4 -4
- package/esm2022/models/index.mjs +1 -1
- package/esm2022/pipes/actions/actions.pipe.mjs +4 -4
- package/esm2022/pipes/data-accessor/data-accessor.pipe.mjs +14 -14
- package/esm2022/pipes/domain/domain.pipe.mjs +50 -21
- package/esm2022/pipes/error/error.pipe.mjs +4 -4
- package/esm2022/pipes/grouped-by/grouped-by.pipe.mjs +6 -4
- package/esm2022/pipes/index/index.mjs +2 -0
- package/esm2022/pipes/index/index.pipe.mjs +29 -0
- package/esm2022/pipes/index/ng-atomic-common-pipes-index.mjs +5 -0
- package/esm2022/pipes/index-length/index-length.pipe.mjs +22 -0
- package/esm2022/pipes/index-length/index.mjs +2 -0
- package/esm2022/pipes/index-length/ng-atomic-common-pipes-index-length.mjs +5 -0
- package/esm2022/pipes/keys/keys.pipe.mjs +4 -4
- package/esm2022/pipes/page/index.mjs +2 -0
- package/esm2022/pipes/page/ng-atomic-common-pipes-page.mjs +5 -0
- package/esm2022/pipes/page/page.pipe.mjs +25 -0
- package/esm2022/pipes/pagination/pagination.pipe.mjs +9 -9
- package/esm2022/pipes/query/query.pipe.mjs +14 -7
- package/esm2022/pipes/secret/index.mjs +2 -0
- package/esm2022/pipes/secret/ng-atomic-common-pipes-secret.mjs +5 -0
- package/esm2022/pipes/secret/secret.pipe.mjs +21 -0
- package/esm2022/pipes/select-id/select-id.pipe.mjs +6 -6
- package/esm2022/pipes/signal/signal.pipe.mjs +8 -4
- package/esm2022/pipes/smart-exp/smart-exp.module.mjs +5 -5
- package/esm2022/pipes/smart-exp/smart-exp.pipe.mjs +6 -6
- package/esm2022/pipes/smart-field/smart-field.pipe.mjs +21 -21
- package/esm2022/pipes/sort-by/index.mjs +2 -0
- package/esm2022/pipes/sort-by/ng-atomic-common-pipes-sort-by.mjs +5 -0
- package/esm2022/pipes/sort-by/sort-by.pipe.mjs +32 -0
- package/esm2022/pipes/yen/yen.pipe.mjs +4 -4
- package/esm2022/services/auth/auth.service.mjs +35 -20
- package/esm2022/services/chips-manager/chips.manager.mjs +4 -4
- package/esm2022/services/csv/csv.service.mjs +4 -4
- package/esm2022/services/form/pagination/pagination.service.mjs +4 -4
- package/esm2022/services/form/sort/sort.service.mjs +5 -5
- package/esm2022/services/loading/loading.service.mjs +42 -21
- package/esm2022/services/navigation-history/index.mjs +2 -0
- package/esm2022/services/navigation-history/navigation-history.service.mjs +50 -0
- package/esm2022/services/navigation-history/ng-atomic-common-services-navigation-history.mjs +5 -0
- package/esm2022/services/query-resolver/query-resolver.service.mjs +87 -25
- package/esm2022/services/root-property/index.mjs +2 -0
- package/esm2022/services/root-property/ng-atomic-common-services-root-property.mjs +5 -0
- package/esm2022/services/root-property/root-property.service.mjs +122 -0
- package/esm2022/services/router/index.mjs +2 -0
- package/esm2022/services/router/ng-atomic-common-services-router.mjs +5 -0
- package/esm2022/services/router/router.service.mjs +25 -0
- package/esm2022/services/secret/index.mjs +2 -0
- package/esm2022/services/secret/ng-atomic-common-services-secret.mjs +5 -0
- package/esm2022/services/secret/secret.service.mjs +16 -0
- package/esm2022/services/side-app/index.mjs +2 -0
- package/esm2022/services/side-app/ng-atomic-common-services-side-app.mjs +5 -0
- package/esm2022/services/side-app/side-app.service.mjs +25 -0
- package/esm2022/services/side-nav-mode/index.mjs +2 -0
- package/esm2022/services/side-nav-mode/ng-atomic-common-services-side-nav-mode.mjs +5 -0
- package/esm2022/services/side-nav-mode/side-nav-mode.service.mjs +27 -0
- package/esm2022/services/snack-bar/snack-bar.module.mjs +5 -5
- package/esm2022/services/snack-bar/snack-bar.service.mjs +6 -6
- package/esm2022/services/ui/index.mjs +2 -1
- package/esm2022/services/ui/ui.helpers.mjs +186 -0
- package/esm2022/services/ui/ui.service.mjs +55 -173
- package/esm2022/stores/entities/di.mjs +56 -0
- package/esm2022/stores/entities/entity-store-manager.mjs +42 -0
- package/esm2022/stores/entities/entity-store.mjs +127 -0
- package/esm2022/stores/entities/index.mjs +6 -2
- package/esm2022/stores/entities/proxy-id.service.mjs +29 -0
- package/esm2022/stores/entities/task-composer.mjs +71 -0
- package/esm2022/stores/pagination/pagination.store.mjs +5 -5
- package/esm2022/stores/query/query.store.mjs +7 -7
- package/esm2022/stores/selection/selection.store.mjs +5 -5
- package/esm2022/stores/sort/sort.store.mjs +5 -5
- package/esm2022/utils/form/form.mjs +26 -0
- package/esm2022/utils/form/index.mjs +2 -0
- package/esm2022/utils/get/get.mjs +2 -1
- package/esm2022/utils/index.mjs +5 -2
- package/esm2022/utils/inject/index.mjs +2 -0
- package/esm2022/utils/inject/inject.mjs +120 -0
- package/esm2022/utils/mat-dayjs-date/dayjs-date.adapter.mjs +3 -2
- package/esm2022/utils/mat-dayjs-date/dayjs-date.module.mjs +22 -26
- package/esm2022/utils/page/page.mjs +1 -1
- package/esm2022/utils/router/index.mjs +2 -0
- package/esm2022/utils/router/router.mjs +54 -0
- package/esm2022/utils/time.mjs +8 -0
- package/fesm2022/ng-atomic-common-directives-fallback-src.mjs +32 -0
- package/fesm2022/ng-atomic-common-directives-fallback-src.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-directives-ios-safari-scroll-buggyfill.mjs +7 -7
- package/fesm2022/ng-atomic-common-directives-ios-safari-scroll-buggyfill.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-interceptors-authorization.mjs +3 -3
- package/fesm2022/ng-atomic-common-interceptors-authorization.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-interceptors-throttle.mjs +7 -7
- package/fesm2022/ng-atomic-common-interceptors-throttle.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-interceptors-token.mjs +3 -3
- package/fesm2022/ng-atomic-common-interceptors-token.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-interceptors.mjs +61 -0
- package/fesm2022/ng-atomic-common-interceptors.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-pipes-actions.mjs +3 -3
- package/fesm2022/ng-atomic-common-pipes-actions.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-data-accessor.mjs +14 -14
- package/fesm2022/ng-atomic-common-pipes-data-accessor.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-domain.mjs +50 -21
- package/fesm2022/ng-atomic-common-pipes-domain.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-error.mjs +3 -3
- package/fesm2022/ng-atomic-common-pipes-error.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-grouped-by.mjs +5 -3
- package/fesm2022/ng-atomic-common-pipes-grouped-by.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-index-length.mjs +29 -0
- package/fesm2022/ng-atomic-common-pipes-index-length.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-pipes-index.mjs +36 -0
- package/fesm2022/ng-atomic-common-pipes-index.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-pipes-keys.mjs +3 -3
- package/fesm2022/ng-atomic-common-pipes-keys.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-page.mjs +32 -0
- package/fesm2022/ng-atomic-common-pipes-page.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-pipes-pagination.mjs +8 -8
- package/fesm2022/ng-atomic-common-pipes-pagination.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-query.mjs +14 -7
- package/fesm2022/ng-atomic-common-pipes-query.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-secret.mjs +28 -0
- package/fesm2022/ng-atomic-common-pipes-secret.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-pipes-select-id.mjs +5 -5
- package/fesm2022/ng-atomic-common-pipes-select-id.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-signal.mjs +8 -4
- package/fesm2022/ng-atomic-common-pipes-signal.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-smart-exp.mjs +9 -9
- package/fesm2022/ng-atomic-common-pipes-smart-exp.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-smart-field.mjs +21 -21
- package/fesm2022/ng-atomic-common-pipes-smart-field.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-pipes-sort-by.mjs +39 -0
- package/fesm2022/ng-atomic-common-pipes-sort-by.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-pipes-yen.mjs +3 -3
- package/fesm2022/ng-atomic-common-pipes-yen.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-auth.mjs +35 -20
- package/fesm2022/ng-atomic-common-services-auth.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-chips-manager.mjs +3 -3
- package/fesm2022/ng-atomic-common-services-chips-manager.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-csv.mjs +3 -3
- package/fesm2022/ng-atomic-common-services-csv.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-form-pagination.mjs +3 -3
- package/fesm2022/ng-atomic-common-services-form-pagination.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-form-sort.mjs +4 -4
- package/fesm2022/ng-atomic-common-services-form-sort.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-loading.mjs +42 -21
- package/fesm2022/ng-atomic-common-services-loading.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-navigation-history.mjs +57 -0
- package/fesm2022/ng-atomic-common-services-navigation-history.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-services-query-resolver.mjs +86 -25
- package/fesm2022/ng-atomic-common-services-query-resolver.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-root-property.mjs +129 -0
- package/fesm2022/ng-atomic-common-services-root-property.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-services-router.mjs +32 -0
- package/fesm2022/ng-atomic-common-services-router.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-services-secret.mjs +23 -0
- package/fesm2022/ng-atomic-common-services-secret.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-services-side-app.mjs +32 -0
- package/fesm2022/ng-atomic-common-services-side-app.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-services-side-nav-mode.mjs +34 -0
- package/fesm2022/ng-atomic-common-services-side-nav-mode.mjs.map +1 -0
- package/fesm2022/ng-atomic-common-services-snack-bar.mjs +9 -9
- package/fesm2022/ng-atomic-common-services-snack-bar.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-services-ui.mjs +237 -174
- package/fesm2022/ng-atomic-common-services-ui.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-stores-entities.mjs +297 -19
- package/fesm2022/ng-atomic-common-stores-entities.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-stores-pagination.mjs +4 -4
- package/fesm2022/ng-atomic-common-stores-pagination.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-stores-query.mjs +6 -6
- package/fesm2022/ng-atomic-common-stores-query.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-stores-selection.mjs +4 -4
- package/fesm2022/ng-atomic-common-stores-selection.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-stores-sort.mjs +4 -4
- package/fesm2022/ng-atomic-common-stores-sort.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-utils-page.mjs.map +1 -1
- package/fesm2022/ng-atomic-common-utils.mjs +227 -124
- package/fesm2022/ng-atomic-common-utils.mjs.map +1 -1
- package/interceptors/index.d.ts +1 -0
- package/interceptors/interceptors.module.d.ts +7 -0
- package/models/index.d.ts +34 -0
- package/package.json +79 -7
- package/pipes/data-accessor/data-accessor.pipe.d.ts +7 -3
- package/pipes/domain/domain.pipe.d.ts +51 -5
- package/pipes/grouped-by/grouped-by.pipe.d.ts +1 -1
- package/pipes/index/index.d.ts +1 -0
- package/pipes/index/index.pipe.d.ts +11 -0
- package/pipes/index-length/index-length.pipe.d.ts +10 -0
- package/pipes/index-length/index.d.ts +1 -0
- package/pipes/page/index.d.ts +1 -0
- package/pipes/page/page.pipe.d.ts +11 -0
- package/pipes/query/query.pipe.d.ts +5 -4
- package/pipes/secret/index.d.ts +1 -0
- package/pipes/secret/secret.pipe.d.ts +8 -0
- package/pipes/signal/signal.pipe.d.ts +1 -0
- package/pipes/smart-field/smart-field.pipe.d.ts +48 -15
- package/pipes/sort-by/index.d.ts +1 -0
- package/pipes/sort-by/sort-by.pipe.d.ts +17 -0
- package/services/auth/auth.service.d.ts +32 -25
- package/services/loading/loading.service.d.ts +20 -8
- package/services/navigation-history/index.d.ts +1 -0
- package/services/navigation-history/navigation-history.service.d.ts +14 -0
- package/services/query-resolver/query-resolver.service.d.ts +25 -8
- package/services/root-property/index.d.ts +1 -0
- package/services/root-property/root-property.service.d.ts +91 -0
- package/services/router/index.d.ts +1 -0
- package/services/router/router.service.d.ts +10 -0
- package/services/secret/index.d.ts +1 -0
- package/services/secret/secret.service.d.ts +6 -0
- package/services/side-app/index.d.ts +1 -0
- package/services/side-app/side-app.service.d.ts +9 -0
- package/services/side-nav-mode/index.d.ts +1 -0
- package/services/side-nav-mode/side-nav-mode.service.d.ts +11 -0
- package/services/snack-bar/snack-bar.service.d.ts +1 -1
- package/services/ui/index.d.ts +1 -0
- package/services/ui/ui.helpers.d.ts +28 -0
- package/services/ui/ui.service.d.ts +42 -47
- package/stores/entities/di.d.ts +15 -0
- package/stores/entities/entity-store-manager.d.ts +12 -0
- package/stores/entities/entity-store.d.ts +86 -0
- package/stores/entities/index.d.ts +5 -1
- package/stores/entities/proxy-id.service.d.ts +10 -0
- package/stores/entities/task-composer.d.ts +35 -0
- package/stores/query/query.store.d.ts +3 -3
- package/utils/form/form.d.ts +10 -0
- package/utils/form/index.d.ts +1 -0
- package/utils/get/get.d.ts +1 -0
- package/utils/index.d.ts +4 -1
- package/utils/inject/index.d.ts +1 -0
- package/utils/inject/inject.d.ts +50 -0
- package/utils/mat-dayjs-date/dayjs-date.module.d.ts +2 -5
- package/utils/page/page.d.ts +1 -1
- package/utils/router/index.d.ts +1 -0
- package/utils/router/router.d.ts +4 -0
- package/utils/time.d.ts +1 -0
- package/esm2022/pipes/smart-sort-by/index.mjs +0 -4
- package/esm2022/pipes/smart-sort-by/ng-atomic-common-pipes-smart-sort-by.mjs +0 -5
- package/esm2022/pipes/smart-sort-by/smart-sort-by.module.mjs +0 -24
- package/esm2022/pipes/smart-sort-by/smart-sort-by.pipe.mjs +0 -28
- package/esm2022/pipes/smart-sort-by/smart-sort-by.transformer.mjs +0 -5
- package/esm2022/stores/entities/entities.store.mjs +0 -32
- package/esm2022/utils/query/index.mjs +0 -2
- package/esm2022/utils/query/query.resolver.mjs +0 -100
- package/fesm2022/ng-atomic-common-pipes-smart-sort-by.mjs +0 -60
- package/fesm2022/ng-atomic-common-pipes-smart-sort-by.mjs.map +0 -1
- package/pipes/smart-sort-by/index.d.ts +0 -3
- package/pipes/smart-sort-by/smart-sort-by.module.d.ts +0 -8
- package/pipes/smart-sort-by/smart-sort-by.pipe.d.ts +0 -11
- package/pipes/smart-sort-by/smart-sort-by.transformer.d.ts +0 -2
- package/stores/entities/entities.store.d.ts +0 -19
- package/utils/query/index.d.ts +0 -1
- package/utils/query/query.resolver.d.ts +0 -2
|
@@ -4,38 +4,34 @@ import { DayjsDateAdapter, MAT_DAYJS_DATE_ADAPTER_OPTIONS } from './dayjs-date.a
|
|
|
4
4
|
import { MAT_DAYJS_DATE_FORMATS } from './dayjs-date.formats';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class DayjsDateModule {
|
|
7
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
8
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
9
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
10
|
-
|
|
11
|
-
provide: DateAdapter,
|
|
12
|
-
useClass: DayjsDateAdapter,
|
|
13
|
-
deps: [MAT_DATE_LOCALE, MAT_DAYJS_DATE_ADAPTER_OPTIONS]
|
|
14
|
-
},
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DayjsDateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: DayjsDateModule }); }
|
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DayjsDateModule, providers: [
|
|
10
|
+
provideDayjsDateAdapter(),
|
|
15
11
|
] }); }
|
|
16
12
|
}
|
|
17
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DayjsDateModule, decorators: [{
|
|
18
14
|
type: NgModule,
|
|
19
15
|
args: [{
|
|
20
16
|
providers: [
|
|
21
|
-
|
|
22
|
-
provide: DateAdapter,
|
|
23
|
-
useClass: DayjsDateAdapter,
|
|
24
|
-
deps: [MAT_DATE_LOCALE, MAT_DAYJS_DATE_ADAPTER_OPTIONS]
|
|
25
|
-
},
|
|
17
|
+
provideDayjsDateAdapter(),
|
|
26
18
|
],
|
|
27
19
|
}]
|
|
28
20
|
}] });
|
|
29
|
-
export
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
21
|
+
export function provideDayjsDateAdapter() {
|
|
22
|
+
return [
|
|
23
|
+
{
|
|
24
|
+
provide: DateAdapter,
|
|
25
|
+
useClass: DayjsDateAdapter,
|
|
26
|
+
deps: [
|
|
27
|
+
MAT_DATE_LOCALE,
|
|
28
|
+
MAT_DAYJS_DATE_ADAPTER_OPTIONS,
|
|
29
|
+
]
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
provide: MAT_DATE_FORMATS,
|
|
33
|
+
useValue: MAT_DAYJS_DATE_FORMATS,
|
|
34
|
+
},
|
|
35
|
+
];
|
|
33
36
|
}
|
|
34
|
-
|
|
35
|
-
type: NgModule,
|
|
36
|
-
args: [{
|
|
37
|
-
imports: [DayjsDateModule],
|
|
38
|
-
providers: [{ provide: MAT_DATE_FORMATS, useValue: MAT_DAYJS_DATE_FORMATS }],
|
|
39
|
-
}]
|
|
40
|
-
}] });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5anMtZGF0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvbGliL3V0aWxzL21hdC1kYXlqcy1kYXRlL2RheWpzLWRhdGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN4RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFXOUQsTUFBTSxPQUFPLGVBQWU7K0dBQWYsZUFBZTtnSEFBZixlQUFlO2dIQUFmLGVBQWUsYUFSZjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxXQUFXO2dCQUNwQixRQUFRLEVBQUUsZ0JBQWdCO2dCQUMxQixJQUFJLEVBQUUsQ0FBQyxlQUFlLEVBQUUsOEJBQThCLENBQUM7YUFDeEQ7U0FDRjs7NEZBRVUsZUFBZTtrQkFUM0IsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLFdBQVc7NEJBQ3BCLFFBQVEsRUFBRSxnQkFBZ0I7NEJBQzFCLElBQUksRUFBRSxDQUFDLGVBQWUsRUFBRSw4QkFBOEIsQ0FBQzt5QkFDeEQ7cUJBQ0Y7aUJBQ0Y7O0FBT0QsTUFBTSxPQUFPLGtCQUFrQjsrR0FBbEIsa0JBQWtCO2dIQUFsQixrQkFBa0IsWUFObEIsZUFBZTtnSEFNZixrQkFBa0IsYUFGbEIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsc0JBQXNCLEVBQUUsQ0FBQyxZQURsRSxlQUFlOzs0RkFHZCxrQkFBa0I7a0JBSjlCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsZUFBZSxDQUFDO29CQUMxQixTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsc0JBQXNCLEVBQUUsQ0FBQztpQkFDN0UiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGF0ZUFkYXB0ZXIsIE1BVF9EQVRFX0ZPUk1BVFMsIE1BVF9EQVRFX0xPQ0FMRSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRGF5anNEYXRlQWRhcHRlciwgTUFUX0RBWUpTX0RBVEVfQURBUFRFUl9PUFRJT05TIH0gZnJvbSAnLi9kYXlqcy1kYXRlLmFkYXB0ZXInO1xuaW1wb3J0IHsgTUFUX0RBWUpTX0RBVEVfRk9STUFUUyB9IGZyb20gJy4vZGF5anMtZGF0ZS5mb3JtYXRzJztcblxuQE5nTW9kdWxlKHtcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogRGF0ZUFkYXB0ZXIsXG4gICAgICB1c2VDbGFzczogRGF5anNEYXRlQWRhcHRlcixcbiAgICAgIGRlcHM6IFtNQVRfREFURV9MT0NBTEUsIE1BVF9EQVlKU19EQVRFX0FEQVBURVJfT1BUSU9OU11cbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBEYXlqc0RhdGVNb2R1bGUgeyB9XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtEYXlqc0RhdGVNb2R1bGVdLFxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6IE1BVF9EQVRFX0ZPUk1BVFMsIHVzZVZhbHVlOiBNQVRfREFZSlNfREFURV9GT1JNQVRTIH1dLFxufSlcbmV4cG9ydCBjbGFzcyBNYXREYXlqc0RhdGVNb2R1bGUgeyB9Il19
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5anMtZGF0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvbGliL3V0aWxzL21hdC1kYXlqcy1kYXRlL2RheWpzLWRhdGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQVksTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN4RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFPOUQsTUFBTSxPQUFPLGVBQWU7OEdBQWYsZUFBZTsrR0FBZixlQUFlOytHQUFmLGVBQWUsYUFKZjtZQUNULHVCQUF1QixFQUFFO1NBQzFCOzsyRkFFVSxlQUFlO2tCQUwzQixRQUFRO21CQUFDO29CQUNSLFNBQVMsRUFBRTt3QkFDVCx1QkFBdUIsRUFBRTtxQkFDMUI7aUJBQ0Y7O0FBR0QsTUFBTSxVQUFVLHVCQUF1QjtJQUNyQyxPQUFPO1FBQ0w7WUFDRSxPQUFPLEVBQUUsV0FBVztZQUNwQixRQUFRLEVBQUUsZ0JBQWdCO1lBQzFCLElBQUksRUFBRTtnQkFDSixlQUFlO2dCQUNmLDhCQUE4QjthQUMvQjtTQUNGO1FBQ0Q7WUFDRSxPQUFPLEVBQUUsZ0JBQWdCO1lBQ3pCLFFBQVEsRUFBRSxzQkFBc0I7U0FDakM7S0FDRixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGF0ZUFkYXB0ZXIsIE1BVF9EQVRFX0ZPUk1BVFMsIE1BVF9EQVRFX0xPQ0FMRSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRGF5anNEYXRlQWRhcHRlciwgTUFUX0RBWUpTX0RBVEVfQURBUFRFUl9PUFRJT05TIH0gZnJvbSAnLi9kYXlqcy1kYXRlLmFkYXB0ZXInO1xuaW1wb3J0IHsgTUFUX0RBWUpTX0RBVEVfRk9STUFUUyB9IGZyb20gJy4vZGF5anMtZGF0ZS5mb3JtYXRzJztcblxuQE5nTW9kdWxlKHtcbiAgcHJvdmlkZXJzOiBbXG4gICAgcHJvdmlkZURheWpzRGF0ZUFkYXB0ZXIoKSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRGF5anNEYXRlTW9kdWxlIHsgfVxuXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZURheWpzRGF0ZUFkYXB0ZXIoKTogUHJvdmlkZXJbXSB7XG4gIHJldHVybiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogRGF0ZUFkYXB0ZXIsXG4gICAgICB1c2VDbGFzczogRGF5anNEYXRlQWRhcHRlcixcbiAgICAgIGRlcHM6IFtcbiAgICAgICAgTUFUX0RBVEVfTE9DQUxFLCBcbiAgICAgICAgTUFUX0RBWUpTX0RBVEVfQURBUFRFUl9PUFRJT05TLFxuICAgICAgXVxuICAgIH0sXG4gICAge1xuICAgICAgcHJvdmlkZTogTUFUX0RBVEVfRk9STUFUUyxcbiAgICAgIHVzZVZhbHVlOiBNQVRfREFZSlNfREFURV9GT1JNQVRTLFxuICAgIH0sICBcbiAgXVxufVxuIl19
|
|
@@ -17,4 +17,4 @@ export class Page {
|
|
|
17
17
|
return Page.from({ ...this, ...obj });
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL0BuZy1hdG9taWMvY29tbW9uL3NyYy9saWIvdXRpbHMvcGFnZS9wYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU9BLE1BQU0sT0FBTyxJQUFJO0lBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUF1QixFQUFFO1FBQ25DLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksRUFBRSxFQUFFO1lBQy9CLFFBQVEsRUFBRSxFQUFFO1lBQ1osU0FBUyxFQUFFLENBQUM7WUFDWixNQUFNLEVBQUUsR0FBRztZQUNYLEdBQUcsS0FBSztTQUNULENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN4QyxDQUFDO0lBRUQsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQsS0FBSyxDQUFDLEdBQWtCO1FBQ3RCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFDLEdBQUcsSUFBSSxFQUFFLEdBQUcsR0FBRyxFQUFDLENBQUMsQ0FBQztJQUN0QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQYWdlRXZlbnQgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wYWdpbmF0b3InO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhZ2UgZXh0ZW5kcyBQYWdlRXZlbnQge1xuICBzb3J0S2V5OiBzdHJpbmc7XG4gIHNvcnRPcmRlcjogJ2FzYycgfCAnZGVzYyc7XG59XG5cbmV4cG9ydCBjbGFzcyBQYWdlIHtcbiAgc3RhdGljIGZyb20oZXZlbnQ6IFBhcnRpYWw8UGFnZT4gPSB7fSk6IFBhZ2Uge1xuICAgIHJldHVybiBPYmplY3QuYXNzaWduKG5ldyBQYWdlKCksIHtcbiAgICAgIHBhZ2VTaXplOiA1MCxcbiAgICAgIHBhZ2VJbmRleDogMCxcbiAgICAgIGxlbmd0aDogMTAwLFxuICAgICAgLi4uZXZlbnRcbiAgICB9KTtcbiAgfVxuXG4gIGdldCBzdGFydCgpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLnBhZ2VJbmRleCAqIHRoaXMucGFnZVNpemU7XG4gIH1cblxuICBnZXQgZW5kKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIE1hdGgubWluKCh0aGlzLnBhZ2VJbmRleCArIDEpICogdGhpcy5wYWdlU2l6ZSwgdGhpcy5sZW5ndGgpO1xuICB9XG5cbiAgcGF0Y2gob2JqOiBQYXJ0aWFsPFBhZ2U+KTogUGFnZSB7XG4gICAgcmV0dXJuIFBhZ2UuZnJvbSh7Li4udGhpcywgLi4ub2JqfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './router';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvbGliL3V0aWxzL3JvdXRlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcm91dGVyJztcbiJdfQ==
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
export function walkActivatedRouteSnapshot(snapshot, callback, target = 'children') {
|
|
2
|
+
if (callback(snapshot))
|
|
3
|
+
return;
|
|
4
|
+
if (target === 'children') {
|
|
5
|
+
snapshot.children.forEach(child => walkActivatedRouteSnapshot(child, callback, target));
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
export function skippedResolver(outlet = 'primary') {
|
|
9
|
+
let skipped;
|
|
10
|
+
return (route, snapshot) => {
|
|
11
|
+
const routes = [];
|
|
12
|
+
walkActivatedRouteSnapshot(snapshot.root, snapshot => {
|
|
13
|
+
if (snapshot.outlet === outlet) {
|
|
14
|
+
routes.push(snapshot);
|
|
15
|
+
return false;
|
|
16
|
+
}
|
|
17
|
+
return true;
|
|
18
|
+
});
|
|
19
|
+
if (route === routes.at(-1)) {
|
|
20
|
+
return skipped = false;
|
|
21
|
+
}
|
|
22
|
+
return skipped ??= route !== routes.at(-1);
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
function resolveModule(m) {
|
|
26
|
+
if (m.default) {
|
|
27
|
+
return m.default;
|
|
28
|
+
}
|
|
29
|
+
return m;
|
|
30
|
+
}
|
|
31
|
+
export function wrapRoutes(routes) {
|
|
32
|
+
return (routes ?? []).map(route => {
|
|
33
|
+
if (route.loadChildren) {
|
|
34
|
+
return {
|
|
35
|
+
...route,
|
|
36
|
+
loadChildren: () => route.loadChildren().then(routes => {
|
|
37
|
+
return wrapRoutes(resolveModule(routes));
|
|
38
|
+
}),
|
|
39
|
+
resolve: {
|
|
40
|
+
...(route?.resolve || {}),
|
|
41
|
+
skipped: skippedResolver(),
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
return {
|
|
46
|
+
...route,
|
|
47
|
+
resolve: {
|
|
48
|
+
...(route?.resolve || {}),
|
|
49
|
+
skipped: skippedResolver(),
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb21tb24vc3JjL2xpYi91dGlscy9yb3V0ZXIvcm91dGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sVUFBVSwwQkFBMEIsQ0FDeEMsUUFBZ0MsRUFDaEMsUUFBdUQsRUFDdkQsU0FBZ0MsVUFBVTtJQUUxQyxJQUFHLFFBQVEsQ0FBQyxRQUFRLENBQUM7UUFBRSxPQUFPO0lBQzlCLElBQUksTUFBTSxLQUFLLFVBQVUsRUFBRTtRQUN6QixRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLDBCQUEwQixDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztLQUN6RjtBQUNILENBQUM7QUFHRCxNQUFNLFVBQVUsZUFBZSxDQUFDLE1BQU0sR0FBRyxTQUFTO0lBQ2pELElBQUksT0FBZ0IsQ0FBQztJQUVyQixPQUFPLENBQUMsS0FBNkIsRUFBRSxRQUE2QixFQUFFLEVBQUU7UUFDdkUsTUFBTSxNQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ2xCLDBCQUEwQixDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLEVBQUU7WUFDcEQsSUFBSSxRQUFRLENBQUMsTUFBTSxLQUFLLE1BQU0sRUFBRTtnQkFDL0IsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDdEIsT0FBTyxLQUFLLENBQUM7YUFDYjtZQUNELE9BQU8sSUFBSSxDQUFDO1FBQ2IsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLEtBQUssS0FBSyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDNUIsT0FBTyxPQUFPLEdBQUcsS0FBSyxDQUFDO1NBQ3ZCO1FBRUQsT0FBTyxPQUFPLEtBQUssS0FBSyxLQUFLLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1QyxDQUFDLENBQUE7QUFDRixDQUFDO0FBRUQsU0FBUyxhQUFhLENBQUMsQ0FBTTtJQUMzQixJQUFJLENBQUMsQ0FBQyxPQUFPLEVBQUU7UUFDYixPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUM7S0FDbEI7SUFDRCxPQUFPLENBQUMsQ0FBQztBQUNYLENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLE1BQWM7SUFDdkMsT0FBTyxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7UUFDaEMsSUFBSSxLQUFLLENBQUMsWUFBWSxFQUFFO1lBQ3RCLE9BQU87Z0JBQ0wsR0FBRyxLQUFLO2dCQUNSLFlBQVksRUFBRSxHQUFHLEVBQUUsQ0FBRSxLQUFLLENBQUMsWUFBWSxFQUFzQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRTtvQkFDL0UsT0FBTyxVQUFVLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUE7Z0JBQ3pDLENBQUMsQ0FBQztnQkFDRSxPQUFPLEVBQUU7b0JBQ1AsR0FBRyxDQUFDLEtBQUssRUFBRSxPQUFPLElBQUksRUFBRSxDQUFDO29CQUN6QixPQUFPLEVBQUUsZUFBZSxFQUFFO2lCQUMzQjthQUNGLENBQUM7U0FDSDtRQUNELE9BQU87WUFDTCxHQUFHLEtBQUs7WUFDUixPQUFPLEVBQUU7Z0JBQ1AsR0FBRyxDQUFDLEtBQUssRUFBRSxPQUFPLElBQUksRUFBRSxDQUFDO2dCQUN6QixPQUFPLEVBQUUsZUFBZSxFQUFFO2FBQzNCO1NBQ0YsQ0FBQztJQUNKLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIFJvdXRlclN0YXRlU25hcHNob3QsIFJvdXRlcyB9IGZyb20gXCJAYW5ndWxhci9yb3V0ZXJcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIHdhbGtBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90KFxuICBzbmFwc2hvdDogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCxcbiAgY2FsbGJhY2s6IChzbmFwc2hvdDogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCkgPT4gYm9vbGVhbixcbiAgdGFyZ2V0OiAnY2hpbGRyZW4nIHwgJ3BhcmVudCcgPSAnY2hpbGRyZW4nLFxuKTogdm9pZCB7XG4gIGlmKGNhbGxiYWNrKHNuYXBzaG90KSkgcmV0dXJuO1xuICBpZiAodGFyZ2V0ID09PSAnY2hpbGRyZW4nKSB7XG4gICAgc25hcHNob3QuY2hpbGRyZW4uZm9yRWFjaChjaGlsZCA9PiB3YWxrQWN0aXZhdGVkUm91dGVTbmFwc2hvdChjaGlsZCwgY2FsbGJhY2ssIHRhcmdldCkpO1xuICB9XG59XG5cblxuZXhwb3J0IGZ1bmN0aW9uIHNraXBwZWRSZXNvbHZlcihvdXRsZXQgPSAncHJpbWFyeScpIHtcblx0bGV0IHNraXBwZWQ6IGJvb2xlYW47XG5cblx0cmV0dXJuIChyb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgc25hcHNob3Q6IFJvdXRlclN0YXRlU25hcHNob3QpID0+IHtcblx0XHRjb25zdCByb3V0ZXMgPSBbXTtcblx0XHR3YWxrQWN0aXZhdGVkUm91dGVTbmFwc2hvdChzbmFwc2hvdC5yb290LCBzbmFwc2hvdCA9PiB7XG5cdFx0XHRpZiAoc25hcHNob3Qub3V0bGV0ID09PSBvdXRsZXQpIHtcblx0XHRcdFx0cm91dGVzLnB1c2goc25hcHNob3QpO1xuXHRcdFx0XHRyZXR1cm4gZmFsc2U7XG5cdFx0XHR9XG5cdFx0XHRyZXR1cm4gdHJ1ZTtcblx0XHR9KTtcblxuXHRcdGlmIChyb3V0ZSA9PT0gcm91dGVzLmF0KC0xKSkge1xuXHRcdFx0cmV0dXJuIHNraXBwZWQgPSBmYWxzZTtcblx0XHR9XG5cblx0XHRyZXR1cm4gc2tpcHBlZCA/Pz0gcm91dGUgIT09IHJvdXRlcy5hdCgtMSk7XG5cdH1cbn1cblxuZnVuY3Rpb24gcmVzb2x2ZU1vZHVsZShtOiBhbnkpIHtcbiAgaWYgKG0uZGVmYXVsdCkge1xuICAgIHJldHVybiBtLmRlZmF1bHQ7XG4gIH1cbiAgcmV0dXJuIG07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB3cmFwUm91dGVzKHJvdXRlczogUm91dGVzKSB7XG4gIHJldHVybiAocm91dGVzID8/IFtdKS5tYXAocm91dGUgPT4ge1xuICAgIGlmIChyb3V0ZS5sb2FkQ2hpbGRyZW4pIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIC4uLnJvdXRlLFxuICAgICAgICBsb2FkQ2hpbGRyZW46ICgpID0+IChyb3V0ZS5sb2FkQ2hpbGRyZW4oKSBhcyBQcm9taXNlPFJvdXRlcz4pLnRoZW4ocm91dGVzID0+IHtcblx0XHRcdFx0XHRyZXR1cm4gd3JhcFJvdXRlcyhyZXNvbHZlTW9kdWxlKHJvdXRlcykpXG5cdFx0XHRcdH0pLFxuICAgICAgICByZXNvbHZlOiB7XG4gICAgICAgICAgLi4uKHJvdXRlPy5yZXNvbHZlIHx8IHt9KSxcbiAgICAgICAgICBza2lwcGVkOiBza2lwcGVkUmVzb2x2ZXIoKSxcbiAgICAgICAgfVxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnJvdXRlLFxuICAgICAgcmVzb2x2ZToge1xuICAgICAgICAuLi4ocm91dGU/LnJlc29sdmUgfHwge30pLFxuICAgICAgICBza2lwcGVkOiBza2lwcGVkUmVzb2x2ZXIoKSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfSk7XG59Il19
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// 秒数をhh:mm:ssの形にフォーマットする
|
|
2
|
+
export function formatSeconds(seconds) {
|
|
3
|
+
const h = `${Math.floor(seconds / 3600)}`.padStart(2, '0');
|
|
4
|
+
const m = `${Math.floor(seconds % 3600 / 60)}`.padStart(2, '0');
|
|
5
|
+
const s = `${Math.floor(seconds % 3600 % 60)}`.padStart(2, '0');
|
|
6
|
+
return `${h}:${m}:${s}`;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL0BuZy1hdG9taWMvY29tbW9uL3NyYy9saWIvdXRpbHMvdGltZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx5QkFBeUI7QUFDekIsTUFBTSxVQUFVLGFBQWEsQ0FBQyxPQUFlO0lBQzNDLE1BQU0sQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQzNELE1BQU0sQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNoRSxNQUFNLENBQUMsR0FBRyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDaEUsT0FBTyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7QUFDMUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIOenkuaVsOOCkmhoOm1tOnNz44Gu5b2i44Gr44OV44Kp44O844Oe44OD44OI44GZ44KLXG5leHBvcnQgZnVuY3Rpb24gZm9ybWF0U2Vjb25kcyhzZWNvbmRzOiBudW1iZXIpOiBzdHJpbmcge1xuICBjb25zdCBoID0gYCR7TWF0aC5mbG9vcihzZWNvbmRzIC8gMzYwMCl9YC5wYWRTdGFydCgyLCAnMCcpO1xuICBjb25zdCBtID0gYCR7TWF0aC5mbG9vcihzZWNvbmRzICUgMzYwMCAvIDYwKX1gLnBhZFN0YXJ0KDIsICcwJyk7XG4gIGNvbnN0IHMgPSBgJHtNYXRoLmZsb29yKHNlY29uZHMgJSAzNjAwICUgNjApfWAucGFkU3RhcnQoMiwgJzAnKTtcbiAgcmV0dXJuIGAke2h9OiR7bX06JHtzfWA7XG59Il19
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { signal, inject, ElementRef, Directive, HostListener } from '@angular/core';
|
|
3
|
+
|
|
4
|
+
class FallbackSrcDirective {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.fallbackSrc = signal('');
|
|
7
|
+
this.el = inject((ElementRef));
|
|
8
|
+
}
|
|
9
|
+
onError() {
|
|
10
|
+
const element = this.el.nativeElement;
|
|
11
|
+
element.src = this.fallbackSrc();
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: FallbackSrcDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
14
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.2", type: FallbackSrcDirective, isStandalone: true, selector: "[fallbackSrc]", host: { listeners: { "error": "onError()" } }, ngImport: i0 }); }
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: FallbackSrcDirective, decorators: [{
|
|
17
|
+
type: Directive,
|
|
18
|
+
args: [{
|
|
19
|
+
standalone: true,
|
|
20
|
+
selector: '[fallbackSrc]',
|
|
21
|
+
}]
|
|
22
|
+
}], propDecorators: { onError: [{
|
|
23
|
+
type: HostListener,
|
|
24
|
+
args: ['error']
|
|
25
|
+
}] } });
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Generated bundle index. Do not edit.
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
export { FallbackSrcDirective };
|
|
32
|
+
//# sourceMappingURL=ng-atomic-common-directives-fallback-src.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-directives-fallback-src.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/directives/fallback-src/fallback-src.directive.ts","../../../../../packages/@ng-atomic/common/src/lib/directives/fallback-src/ng-atomic-common-directives-fallback-src.ts"],"sourcesContent":["import { Directive, ElementRef, HostListener, inject, signal } from '@angular/core';\n\n@Directive({\n standalone: true,\n selector: '[fallbackSrc]',\n})\nexport class FallbackSrcDirective {\n readonly fallbackSrc = signal('');\n protected el = inject(ElementRef<HTMLImageElement>)\n\n @HostListener('error')\n onError() {\n const element: HTMLImageElement = this.el.nativeElement;\n element.src = this.fallbackSrc();\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;MAMa,oBAAoB,CAAA;AAJjC,IAAA,WAAA,GAAA;AAKW,QAAA,IAAA,CAAA,WAAW,GAAG,MAAM,CAAC,4EAA4E,CAAC,CAAC;AAClG,QAAA,IAAA,CAAA,EAAE,GAAG,MAAM,EAAC,UAA4B,EAAC,CAAA;AAOpD,KAAA;IAJC,OAAO,GAAA;AACL,QAAA,MAAM,OAAO,GAAqB,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;AACxD,QAAA,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;KAClC;8GARU,oBAAoB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;kGAApB,oBAAoB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,eAAA,EAAA,IAAA,EAAA,EAAA,SAAA,EAAA,EAAA,OAAA,EAAA,WAAA,EAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA,EAAA;;2FAApB,oBAAoB,EAAA,UAAA,EAAA,CAAA;kBAJhC,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,UAAU,EAAE,IAAI;AAChB,oBAAA,QAAQ,EAAE,eAAe;AAC1B,iBAAA,CAAA;8BAMC,OAAO,EAAA,CAAA;sBADN,YAAY;uBAAC,OAAO,CAAA;;;ACVvB;;AAEG;;;;"}
|
|
@@ -11,10 +11,10 @@ class IosSafariScrollBuggyfillDirective {
|
|
|
11
11
|
onTouchmove(event) {
|
|
12
12
|
event.preventDefault();
|
|
13
13
|
}
|
|
14
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
15
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IosSafariScrollBuggyfillDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
15
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.2", type: IosSafariScrollBuggyfillDirective, selector: "[iosSafariScrollBuggyfill]", host: { listeners: { "touchmove": "onTouchmove($event)" } }, ngImport: i0 }); }
|
|
16
16
|
}
|
|
17
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IosSafariScrollBuggyfillDirective, decorators: [{
|
|
18
18
|
type: Directive,
|
|
19
19
|
args: [{
|
|
20
20
|
selector: '[iosSafariScrollBuggyfill]'
|
|
@@ -25,11 +25,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
25
25
|
}] } });
|
|
26
26
|
|
|
27
27
|
class IosSafariScrollBuggyfillModule {
|
|
28
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
29
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
30
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IosSafariScrollBuggyfillModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
29
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: IosSafariScrollBuggyfillModule, declarations: [IosSafariScrollBuggyfillDirective], imports: [CommonModule], exports: [IosSafariScrollBuggyfillDirective] }); }
|
|
30
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IosSafariScrollBuggyfillModule, imports: [CommonModule] }); }
|
|
31
31
|
}
|
|
32
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IosSafariScrollBuggyfillModule, decorators: [{
|
|
33
33
|
type: NgModule,
|
|
34
34
|
args: [{
|
|
35
35
|
declarations: [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-directives-ios-safari-scroll-buggyfill.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/directives/ios-safari-scroll-buggyfill/ios-safari-scroll-buggyfill.directive.ts","../../../../../packages/@ng-atomic/common/src/lib/directives/ios-safari-scroll-buggyfill/ios-safari-scroll-buggyfill.module.ts","../../../../../packages/@ng-atomic/common/src/lib/directives/ios-safari-scroll-buggyfill/ng-atomic-common-directives-ios-safari-scroll-buggyfill.ts"],"sourcesContent":["import { AfterViewInit, Directive, HostListener } from '@angular/core';\n\n@Directive({\n selector: '[iosSafariScrollBuggyfill]'\n})\nexport class IosSafariScrollBuggyfillDirective implements AfterViewInit {\n\n ngAfterViewInit(): void {\n // this.el.nativeElement.addEventListener('touchmove', (e: Event) => {\n // e.preventDefault();\n // }, {passive: false});\n }\n\n @HostListener('touchmove', ['$event'])\n onTouchmove(event: Event) {\n event.preventDefault();\n }\n\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { IosSafariScrollBuggyfillDirective } from './ios-safari-scroll-buggyfill.directive';\n\n\n\n@NgModule({\n declarations: [\n IosSafariScrollBuggyfillDirective,\n ],\n imports: [\n CommonModule,\n ],\n exports: [\n IosSafariScrollBuggyfillDirective,\n ]\n})\nexport class IosSafariScrollBuggyfillModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;MAKa,iCAAiC,CAAA;IAE5C,eAAe,GAAA;;;;KAId;AAGD,IAAA,WAAW,CAAC,KAAY,EAAA;QACtB,KAAK,CAAC,cAAc,EAAE,CAAC;KACxB
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-directives-ios-safari-scroll-buggyfill.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/directives/ios-safari-scroll-buggyfill/ios-safari-scroll-buggyfill.directive.ts","../../../../../packages/@ng-atomic/common/src/lib/directives/ios-safari-scroll-buggyfill/ios-safari-scroll-buggyfill.module.ts","../../../../../packages/@ng-atomic/common/src/lib/directives/ios-safari-scroll-buggyfill/ng-atomic-common-directives-ios-safari-scroll-buggyfill.ts"],"sourcesContent":["import { AfterViewInit, Directive, HostListener } from '@angular/core';\n\n@Directive({\n selector: '[iosSafariScrollBuggyfill]'\n})\nexport class IosSafariScrollBuggyfillDirective implements AfterViewInit {\n\n ngAfterViewInit(): void {\n // this.el.nativeElement.addEventListener('touchmove', (e: Event) => {\n // e.preventDefault();\n // }, {passive: false});\n }\n\n @HostListener('touchmove', ['$event'])\n onTouchmove(event: Event) {\n event.preventDefault();\n }\n\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { IosSafariScrollBuggyfillDirective } from './ios-safari-scroll-buggyfill.directive';\n\n\n\n@NgModule({\n declarations: [\n IosSafariScrollBuggyfillDirective,\n ],\n imports: [\n CommonModule,\n ],\n exports: [\n IosSafariScrollBuggyfillDirective,\n ]\n})\nexport class IosSafariScrollBuggyfillModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;MAKa,iCAAiC,CAAA;IAE5C,eAAe,GAAA;;;;KAId;AAGD,IAAA,WAAW,CAAC,KAAY,EAAA;QACtB,KAAK,CAAC,cAAc,EAAE,CAAC;KACxB;8GAXU,iCAAiC,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;kGAAjC,iCAAiC,EAAA,QAAA,EAAA,4BAAA,EAAA,IAAA,EAAA,EAAA,SAAA,EAAA,EAAA,WAAA,EAAA,qBAAA,EAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA,EAAA;;2FAAjC,iCAAiC,EAAA,UAAA,EAAA,CAAA;kBAH7C,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,QAAQ,EAAE,4BAA4B;AACvC,iBAAA,CAAA;8BAUC,WAAW,EAAA,CAAA;sBADV,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAA;;;MCI1B,8BAA8B,CAAA;8GAA9B,8BAA8B,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA,CAAA,EAAA;AAA9B,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,8BAA8B,EATvC,YAAA,EAAA,CAAA,iCAAiC,CAGjC,EAAA,OAAA,EAAA,CAAA,YAAY,aAGZ,iCAAiC,CAAA,EAAA,CAAA,CAAA,EAAA;AAGxB,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,8BAA8B,YANvC,YAAY,CAAA,EAAA,CAAA,CAAA,EAAA;;2FAMH,8BAA8B,EAAA,UAAA,EAAA,CAAA;kBAX1C,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACR,oBAAA,YAAY,EAAE;wBACZ,iCAAiC;AAClC,qBAAA;AACD,oBAAA,OAAO,EAAE;wBACP,YAAY;AACb,qBAAA;AACD,oBAAA,OAAO,EAAE;wBACP,iCAAiC;AAClC,qBAAA;AACF,iBAAA,CAAA;;;AChBD;;AAEG;;;;"}
|
|
@@ -18,10 +18,10 @@ class AuthorizationInterceptor {
|
|
|
18
18
|
getRequestWithToken(req, token) {
|
|
19
19
|
return req.clone({ setHeaders: { Authorization: token } });
|
|
20
20
|
}
|
|
21
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
22
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AuthorizationInterceptor, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
22
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AuthorizationInterceptor }); }
|
|
23
23
|
}
|
|
24
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AuthorizationInterceptor, decorators: [{
|
|
25
25
|
type: Injectable
|
|
26
26
|
}] });
|
|
27
27
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-interceptors-authorization.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/interceptors/authorization/authorization.interceptor.ts","../../../../../packages/@ng-atomic/common/src/lib/interceptors/authorization/ng-atomic-common-interceptors-authorization.ts"],"sourcesContent":["import { Injectable, InjectionToken, inject } from '@angular/core';\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\nimport { from, Observable } from 'rxjs';\nimport { mergeMap, take } from 'rxjs/operators';\n\nexport type ProvideAuthorization = () => Promise<string | null> | Observable<string | null>;\nexport const PROVIDE_AUTHORIZATION = new InjectionToken<ProvideAuthorization>('PROVIDE_AUTHORIZATION');\n\n@Injectable()\nexport class AuthorizationInterceptor implements HttpInterceptor {\n\n private provide = inject(PROVIDE_AUTHORIZATION);\n\n intercept(req: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n if (!req.url.startsWith('/api')) return next.handle(req);\n\n return from(this.provide())\n .pipe(take(1))\n .pipe(mergeMap(idToken => next.handle(idToken ? this.getRequestWithToken(req, idToken) : req)));\n }\n\n private getRequestWithToken(req: HttpRequest<unknown>, token: string) {\n return req.clone({ setHeaders: {Authorization: token} });\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;MAMa,qBAAqB,GAAG,IAAI,cAAc,CAAuB,uBAAuB,EAAE;MAG1F,wBAAwB,CAAA;AADrC,IAAA,WAAA,GAAA;AAGU,QAAA,IAAA,CAAA,OAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;AAajD,KAAA;IAXC,SAAS,CAAC,GAAyB,EAAE,IAAiB,EAAA;QACpD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC;AAAE,YAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAEzD,QAAA,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;AACxB,aAAA,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACb,aAAA,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;KACnG;IAEO,mBAAmB,CAAC,GAAyB,EAAE,KAAa,EAAA;AAClE,QAAA,OAAO,GAAG,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,EAAC,aAAa,EAAE,KAAK,EAAC,EAAE,CAAC,CAAC;KAC1D
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-interceptors-authorization.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/interceptors/authorization/authorization.interceptor.ts","../../../../../packages/@ng-atomic/common/src/lib/interceptors/authorization/ng-atomic-common-interceptors-authorization.ts"],"sourcesContent":["import { Injectable, InjectionToken, inject } from '@angular/core';\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\nimport { from, Observable } from 'rxjs';\nimport { mergeMap, take } from 'rxjs/operators';\n\nexport type ProvideAuthorization = () => Promise<string | null> | Observable<string | null>;\nexport const PROVIDE_AUTHORIZATION = new InjectionToken<ProvideAuthorization>('PROVIDE_AUTHORIZATION');\n\n@Injectable()\nexport class AuthorizationInterceptor implements HttpInterceptor {\n\n private provide = inject(PROVIDE_AUTHORIZATION);\n\n intercept(req: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n if (!req.url.startsWith('/api')) return next.handle(req);\n\n return from(this.provide())\n .pipe(take(1))\n .pipe(mergeMap(idToken => next.handle(idToken ? this.getRequestWithToken(req, idToken) : req)));\n }\n\n private getRequestWithToken(req: HttpRequest<unknown>, token: string) {\n return req.clone({ setHeaders: {Authorization: token} });\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;MAMa,qBAAqB,GAAG,IAAI,cAAc,CAAuB,uBAAuB,EAAE;MAG1F,wBAAwB,CAAA;AADrC,IAAA,WAAA,GAAA;AAGU,QAAA,IAAA,CAAA,OAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;AAajD,KAAA;IAXC,SAAS,CAAC,GAAyB,EAAE,IAAiB,EAAA;QACpD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC;AAAE,YAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAEzD,QAAA,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;AACxB,aAAA,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACb,aAAA,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;KACnG;IAEO,mBAAmB,CAAC,GAAyB,EAAE,KAAa,EAAA;AAClE,QAAA,OAAO,GAAG,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,EAAC,aAAa,EAAE,KAAK,EAAC,EAAE,CAAC,CAAC;KAC1D;8GAdU,wBAAwB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA,CAAA,EAAA;kHAAxB,wBAAwB,EAAA,CAAA,CAAA,EAAA;;2FAAxB,wBAAwB,EAAA,UAAA,EAAA,CAAA;kBADpC,UAAU;;;ACRX;;AAEG;;;;"}
|
|
@@ -23,10 +23,10 @@ class IcedCacheService {
|
|
|
23
23
|
remove(key) {
|
|
24
24
|
delete this.cache?.[key];
|
|
25
25
|
}
|
|
26
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
27
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IcedCacheService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
27
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IcedCacheService, providedIn: 'root' }); }
|
|
28
28
|
}
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: IcedCacheService, decorators: [{
|
|
30
30
|
type: Injectable,
|
|
31
31
|
args: [{
|
|
32
32
|
providedIn: 'root'
|
|
@@ -55,12 +55,12 @@ class ThrottleInterceptor {
|
|
|
55
55
|
buildKey(req) {
|
|
56
56
|
return `${req.url}`;
|
|
57
57
|
}
|
|
58
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
59
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
58
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ThrottleInterceptor, deps: [{ token: IcedCacheService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
59
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ThrottleInterceptor }); }
|
|
60
60
|
}
|
|
61
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
61
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ThrottleInterceptor, decorators: [{
|
|
62
62
|
type: Injectable
|
|
63
|
-
}], ctorParameters:
|
|
63
|
+
}], ctorParameters: () => [{ type: IcedCacheService }] });
|
|
64
64
|
|
|
65
65
|
/**
|
|
66
66
|
* Generated bundle index. Do not edit.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-interceptors-throttle.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/interceptors/throttle/throttle.interceptor.ts","../../../../../packages/@ng-atomic/common/src/lib/interceptors/throttle/ng-atomic-common-interceptors-throttle.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\nimport { Observable, ReplaySubject, Subject, throwError } from 'rxjs';\nimport { catchError, finalize, tap} from 'rxjs/operators';\n\n\n@Injectable({\n providedIn: 'root'\n})\nclass IcedCacheService {\n cache = {};\n\n has(key: string): boolean {\n return !!this.cache?.[key];\n }\n\n get(key: string): Subject<HttpEvent<unknown>> {\n return this.cache[key];\n }\n\n set(key: string, value: Subject<HttpEvent<unknown>>): void {\n this.cache[key] = value;\n this.removeAfter(key, 10 * 1000);\n }\n\n removeAfter(key: string, ms: number = 1000) {\n setTimeout(() => this.remove(key), ms);\n }\n\n remove(key: string) {\n delete this.cache?.[key];\n }\n}\n\n@Injectable()\nexport class ThrottleInterceptor implements HttpInterceptor {\n\n constructor(private cache: IcedCacheService) { }\n\n intercept(req: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n if (!this.test(req)) return next.handle(req);\n\n const key = this.buildKey(req);\n\n if (!this.cache.has(key)) {\n const subject = new ReplaySubject<HttpEvent<unknown>>(1);\n next.handle(req).pipe(\n tap(event => subject.next(event)),\n catchError((error) => (subject.error(error), throwError(error))),\n finalize(() => subject.complete()),\n ).subscribe(() => {});\n this.cache.set(key, subject);\n }\n\n return this.cache.get(key);\n }\n\n protected test(req: HttpRequest<unknown>): boolean {\n if (req.method !== 'GET') return false;\n return req.url.startsWith('/api');\n }\n\n private buildKey(req: HttpRequest<unknown>): string {\n return `${req.url}`;\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;AAMA,MAGM,gBAAgB,CAAA;AAHtB,IAAA,WAAA,GAAA;QAIE,IAAK,CAAA,KAAA,GAAG,EAAE,CAAC;AAsBZ,KAAA;AApBC,IAAA,GAAG,CAAC,GAAW,EAAA;QACb,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;KAC5B;AAED,IAAA,GAAG,CAAC,GAAW,EAAA;AACb,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;KACxB;IAED,GAAG,CAAC,GAAW,EAAE,KAAkC,EAAA;AACjD,QAAA,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;KAClC;AAED,IAAA,WAAW,CAAC,GAAW,EAAE,EAAA,GAAa,IAAI,EAAA;AACxC,QAAA,UAAU,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC;KACxC;AAED,IAAA,MAAM,CAAC,GAAW,EAAA;AAChB,QAAA,OAAO,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;KAC1B
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-interceptors-throttle.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/interceptors/throttle/throttle.interceptor.ts","../../../../../packages/@ng-atomic/common/src/lib/interceptors/throttle/ng-atomic-common-interceptors-throttle.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\nimport { Observable, ReplaySubject, Subject, throwError } from 'rxjs';\nimport { catchError, finalize, tap} from 'rxjs/operators';\n\n\n@Injectable({\n providedIn: 'root'\n})\nclass IcedCacheService {\n cache = {};\n\n has(key: string): boolean {\n return !!this.cache?.[key];\n }\n\n get(key: string): Subject<HttpEvent<unknown>> {\n return this.cache[key];\n }\n\n set(key: string, value: Subject<HttpEvent<unknown>>): void {\n this.cache[key] = value;\n this.removeAfter(key, 10 * 1000);\n }\n\n removeAfter(key: string, ms: number = 1000) {\n setTimeout(() => this.remove(key), ms);\n }\n\n remove(key: string) {\n delete this.cache?.[key];\n }\n}\n\n@Injectable()\nexport class ThrottleInterceptor implements HttpInterceptor {\n\n constructor(private cache: IcedCacheService) { }\n\n intercept(req: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n if (!this.test(req)) return next.handle(req);\n\n const key = this.buildKey(req);\n\n if (!this.cache.has(key)) {\n const subject = new ReplaySubject<HttpEvent<unknown>>(1);\n next.handle(req).pipe(\n tap(event => subject.next(event)),\n catchError((error) => (subject.error(error), throwError(error))),\n finalize(() => subject.complete()),\n ).subscribe(() => {});\n this.cache.set(key, subject);\n }\n\n return this.cache.get(key);\n }\n\n protected test(req: HttpRequest<unknown>): boolean {\n if (req.method !== 'GET') return false;\n return req.url.startsWith('/api');\n }\n\n private buildKey(req: HttpRequest<unknown>): string {\n return `${req.url}`;\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;AAMA,MAGM,gBAAgB,CAAA;AAHtB,IAAA,WAAA,GAAA;QAIE,IAAK,CAAA,KAAA,GAAG,EAAE,CAAC;AAsBZ,KAAA;AApBC,IAAA,GAAG,CAAC,GAAW,EAAA;QACb,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;KAC5B;AAED,IAAA,GAAG,CAAC,GAAW,EAAA;AACb,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;KACxB;IAED,GAAG,CAAC,GAAW,EAAE,KAAkC,EAAA;AACjD,QAAA,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;KAClC;AAED,IAAA,WAAW,CAAC,GAAW,EAAE,EAAA,GAAa,IAAI,EAAA;AACxC,QAAA,UAAU,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC;KACxC;AAED,IAAA,MAAM,CAAC,GAAW,EAAA;AAChB,QAAA,OAAO,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;KAC1B;8GAtBG,gBAAgB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA,CAAA,EAAA;AAAhB,IAAA,SAAA,IAAA,CAAA,KAAA,GAAA,EAAA,CAAA,qBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,gBAAgB,cAFR,MAAM,EAAA,CAAA,CAAA,EAAA;;2FAEd,gBAAgB,EAAA,UAAA,EAAA,CAAA;kBAHrB,UAAU;AAAC,YAAA,IAAA,EAAA,CAAA;AACV,oBAAA,UAAU,EAAE,MAAM;AACnB,iBAAA,CAAA;;MA2BY,mBAAmB,CAAA;AAE9B,IAAA,WAAA,CAAoB,KAAuB,EAAA;QAAvB,IAAK,CAAA,KAAA,GAAL,KAAK,CAAkB;KAAK;IAEhD,SAAS,CAAC,GAAyB,EAAE,IAAiB,EAAA;AACpD,QAAA,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;AAAE,YAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAE7C,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAE/B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;AACxB,YAAA,MAAM,OAAO,GAAG,IAAI,aAAa,CAAqB,CAAC,CAAC,CAAC;AACzD,YAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CACnB,GAAG,CAAC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EACjC,UAAU,CAAC,CAAC,KAAK,MAAM,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,EAChE,QAAQ,CAAC,MAAM,OAAO,CAAC,QAAQ,EAAE,CAAC,CACnC,CAAC,SAAS,CAAC,MAAO,GAAC,CAAC,CAAC;YACtB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;AAC9B,SAAA;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;KAC5B;AAES,IAAA,IAAI,CAAC,GAAyB,EAAA;AACtC,QAAA,IAAI,GAAG,CAAC,MAAM,KAAK,KAAK;AAAE,YAAA,OAAO,KAAK,CAAC;QACvC,OAAO,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;KACnC;AAEO,IAAA,QAAQ,CAAC,GAAyB,EAAA;AACxC,QAAA,OAAO,CAAG,EAAA,GAAG,CAAC,GAAG,EAAE,CAAC;KACrB;8GA7BU,mBAAmB,EAAA,IAAA,EAAA,CAAA,EAAA,KAAA,EAAA,gBAAA,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA,CAAA,EAAA;kHAAnB,mBAAmB,EAAA,CAAA,CAAA,EAAA;;2FAAnB,mBAAmB,EAAA,UAAA,EAAA,CAAA;kBAD/B,UAAU;;;AClCX;;AAEG;;;;"}
|
|
@@ -18,10 +18,10 @@ class AuthorizationInterceptor {
|
|
|
18
18
|
getRequestWithToken(req, token) {
|
|
19
19
|
return req.clone({ setHeaders: { Authorization: token } });
|
|
20
20
|
}
|
|
21
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
22
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AuthorizationInterceptor, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
22
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AuthorizationInterceptor }); }
|
|
23
23
|
}
|
|
24
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: AuthorizationInterceptor, decorators: [{
|
|
25
25
|
type: Injectable
|
|
26
26
|
}] });
|
|
27
27
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-interceptors-token.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/interceptors/token/authorization.interceptor.ts","../../../../../packages/@ng-atomic/common/src/lib/interceptors/token/ng-atomic-common-interceptors-token.ts"],"sourcesContent":["import { Injectable, InjectionToken, inject } from '@angular/core';\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\nimport { from, Observable } from 'rxjs';\nimport { mergeMap, take } from 'rxjs/operators';\n\nexport type ProvideAuthorization = () => Promise<string | null> | Observable<string | null>;\nexport const PROVIDE_AUTHORIZATION = new InjectionToken<ProvideAuthorization>('PROVIDE_AUTHORIZATION');\n\n@Injectable()\nexport class AuthorizationInterceptor implements HttpInterceptor {\n\n private provide = inject(PROVIDE_AUTHORIZATION);\n\n intercept(req: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n if (!req.url.startsWith('/api')) return next.handle(req);\n\n return from(this.provide())\n .pipe(take(1))\n .pipe(mergeMap(idToken => next.handle(idToken ? this.getRequestWithToken(req, idToken) : req)));\n }\n\n private getRequestWithToken(req: HttpRequest<unknown>, token: string) {\n return req.clone({ setHeaders: {Authorization: token} });\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;MAMa,qBAAqB,GAAG,IAAI,cAAc,CAAuB,uBAAuB,EAAE;MAG1F,wBAAwB,CAAA;AADrC,IAAA,WAAA,GAAA;AAGU,QAAA,IAAA,CAAA,OAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;AAajD,KAAA;IAXC,SAAS,CAAC,GAAyB,EAAE,IAAiB,EAAA;QACpD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC;AAAE,YAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAEzD,QAAA,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;AACxB,aAAA,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACb,aAAA,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;KACnG;IAEO,mBAAmB,CAAC,GAAyB,EAAE,KAAa,EAAA;AAClE,QAAA,OAAO,GAAG,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,EAAC,aAAa,EAAE,KAAK,EAAC,EAAE,CAAC,CAAC;KAC1D
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-interceptors-token.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/interceptors/token/authorization.interceptor.ts","../../../../../packages/@ng-atomic/common/src/lib/interceptors/token/ng-atomic-common-interceptors-token.ts"],"sourcesContent":["import { Injectable, InjectionToken, inject } from '@angular/core';\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\nimport { from, Observable } from 'rxjs';\nimport { mergeMap, take } from 'rxjs/operators';\n\nexport type ProvideAuthorization = () => Promise<string | null> | Observable<string | null>;\nexport const PROVIDE_AUTHORIZATION = new InjectionToken<ProvideAuthorization>('PROVIDE_AUTHORIZATION');\n\n@Injectable()\nexport class AuthorizationInterceptor implements HttpInterceptor {\n\n private provide = inject(PROVIDE_AUTHORIZATION);\n\n intercept(req: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {\n if (!req.url.startsWith('/api')) return next.handle(req);\n\n return from(this.provide())\n .pipe(take(1))\n .pipe(mergeMap(idToken => next.handle(idToken ? this.getRequestWithToken(req, idToken) : req)));\n }\n\n private getRequestWithToken(req: HttpRequest<unknown>, token: string) {\n return req.clone({ setHeaders: {Authorization: token} });\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;MAMa,qBAAqB,GAAG,IAAI,cAAc,CAAuB,uBAAuB,EAAE;MAG1F,wBAAwB,CAAA;AADrC,IAAA,WAAA,GAAA;AAGU,QAAA,IAAA,CAAA,OAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;AAajD,KAAA;IAXC,SAAS,CAAC,GAAyB,EAAE,IAAiB,EAAA;QACpD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC;AAAE,YAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAEzD,QAAA,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;AACxB,aAAA,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACb,aAAA,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;KACnG;IAEO,mBAAmB,CAAC,GAAyB,EAAE,KAAa,EAAA;AAClE,QAAA,OAAO,GAAG,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,EAAC,aAAa,EAAE,KAAK,EAAC,EAAE,CAAC,CAAC;KAC1D;8GAdU,wBAAwB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA,CAAA,EAAA;kHAAxB,wBAAwB,EAAA,CAAA,CAAA,EAAA;;2FAAxB,wBAAwB,EAAA,UAAA,EAAA,CAAA;kBADpC,UAAU;;;ACRX;;AAEG;;;;"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { inject, NgModule } from '@angular/core';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { HTTP_INTERCEPTORS } from '@angular/common/http';
|
|
5
|
+
import { AuthorizationInterceptor, PROVIDE_AUTHORIZATION } from '@ng-atomic/common/interceptors/authorization';
|
|
6
|
+
import { ThrottleInterceptor } from '@ng-atomic/common/interceptors/throttle';
|
|
7
|
+
import { AuthService } from '@ng-atomic/common/services/auth';
|
|
8
|
+
import { switchMap, of, map } from 'rxjs';
|
|
9
|
+
|
|
10
|
+
class InterceptorsModule {
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: InterceptorsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
12
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: InterceptorsModule, imports: [CommonModule] }); }
|
|
13
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: InterceptorsModule, providers: [
|
|
14
|
+
{
|
|
15
|
+
provide: HTTP_INTERCEPTORS,
|
|
16
|
+
useClass: AuthorizationInterceptor,
|
|
17
|
+
multi: true
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
provide: HTTP_INTERCEPTORS,
|
|
21
|
+
useClass: ThrottleInterceptor,
|
|
22
|
+
multi: true
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
provide: PROVIDE_AUTHORIZATION,
|
|
26
|
+
useValue: () => inject(AuthService).auth$.pipe(switchMap(auth => auth ? auth.getIdToken() : of(``)), map(token => `Bearer ${token}`)),
|
|
27
|
+
},
|
|
28
|
+
], imports: [CommonModule] }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: InterceptorsModule, decorators: [{
|
|
31
|
+
type: NgModule,
|
|
32
|
+
args: [{
|
|
33
|
+
declarations: [],
|
|
34
|
+
imports: [
|
|
35
|
+
CommonModule
|
|
36
|
+
],
|
|
37
|
+
providers: [
|
|
38
|
+
{
|
|
39
|
+
provide: HTTP_INTERCEPTORS,
|
|
40
|
+
useClass: AuthorizationInterceptor,
|
|
41
|
+
multi: true
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
provide: HTTP_INTERCEPTORS,
|
|
45
|
+
useClass: ThrottleInterceptor,
|
|
46
|
+
multi: true
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
provide: PROVIDE_AUTHORIZATION,
|
|
50
|
+
useValue: () => inject(AuthService).auth$.pipe(switchMap(auth => auth ? auth.getIdToken() : of(``)), map(token => `Bearer ${token}`)),
|
|
51
|
+
},
|
|
52
|
+
],
|
|
53
|
+
}]
|
|
54
|
+
}] });
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Generated bundle index. Do not edit.
|
|
58
|
+
*/
|
|
59
|
+
|
|
60
|
+
export { InterceptorsModule };
|
|
61
|
+
//# sourceMappingURL=ng-atomic-common-interceptors.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-interceptors.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/interceptors/interceptors.module.ts","../../../../../packages/@ng-atomic/common/src/lib/interceptors/ng-atomic-common-interceptors.ts"],"sourcesContent":["import { NgModule, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { HTTP_INTERCEPTORS } from '@angular/common/http';\nimport { AuthorizationInterceptor, PROVIDE_AUTHORIZATION } from '@ng-atomic/common/interceptors/authorization';\nimport { ThrottleInterceptor } from '@ng-atomic/common/interceptors/throttle';\nimport { AuthService } from '@ng-atomic/common/services/auth';\nimport { map, of, switchMap } from 'rxjs';\n\n@NgModule({\n declarations: [],\n imports: [\n CommonModule\n ],\n providers: [\n {\n provide: HTTP_INTERCEPTORS,\n useClass: AuthorizationInterceptor,\n multi: true\n },\n {\n provide: HTTP_INTERCEPTORS,\n useClass: ThrottleInterceptor,\n multi: true\n },\n {\n provide: PROVIDE_AUTHORIZATION,\n useValue: () => inject(AuthService).auth$.pipe(\n switchMap(auth => auth ? auth.getIdToken() : of(``)),\n map(token => `Bearer ${token}`),\n ),\n },\n ],\n})\nexport class InterceptorsModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;MAiCa,kBAAkB,CAAA;8GAAlB,kBAAkB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA,CAAA,EAAA;AAAlB,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,kBAAkB,YAtB3B,YAAY,CAAA,EAAA,CAAA,CAAA,EAAA;AAsBH,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,kBAAkB,EApBlB,SAAA,EAAA;AACT,YAAA;AACE,gBAAA,OAAO,EAAE,iBAAiB;AAC1B,gBAAA,QAAQ,EAAE,wBAAwB;AAClC,gBAAA,KAAK,EAAE,IAAI;AACZ,aAAA;AACD,YAAA;AACE,gBAAA,OAAO,EAAE,iBAAiB;AAC1B,gBAAA,QAAQ,EAAE,mBAAmB;AAC7B,gBAAA,KAAK,EAAE,IAAI;AACZ,aAAA;AACD,YAAA;AACE,gBAAA,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,IAAI,CAC5C,SAAS,CAAC,IAAI,IAAI,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,EACpD,GAAG,CAAC,KAAK,IAAI,CAAU,OAAA,EAAA,KAAK,CAAE,CAAA,CAAC,CAChC;AACF,aAAA;AACF,SAAA,EAAA,OAAA,EAAA,CApBC,YAAY,CAAA,EAAA,CAAA,CAAA,EAAA;;2FAsBH,kBAAkB,EAAA,UAAA,EAAA,CAAA;kBAzB9B,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACR,oBAAA,YAAY,EAAE,EAAE;AAChB,oBAAA,OAAO,EAAE;wBACP,YAAY;AACb,qBAAA;AACD,oBAAA,SAAS,EAAE;AACT,wBAAA;AACE,4BAAA,OAAO,EAAE,iBAAiB;AAC1B,4BAAA,QAAQ,EAAE,wBAAwB;AAClC,4BAAA,KAAK,EAAE,IAAI;AACZ,yBAAA;AACD,wBAAA;AACE,4BAAA,OAAO,EAAE,iBAAiB;AAC1B,4BAAA,QAAQ,EAAE,mBAAmB;AAC7B,4BAAA,KAAK,EAAE,IAAI;AACZ,yBAAA;AACD,wBAAA;AACE,4BAAA,OAAO,EAAE,qBAAqB;4BAC9B,QAAQ,EAAE,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,IAAI,CAC5C,SAAS,CAAC,IAAI,IAAI,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,EACpD,GAAG,CAAC,KAAK,IAAI,CAAU,OAAA,EAAA,KAAK,CAAE,CAAA,CAAC,CAChC;AACF,yBAAA;AACF,qBAAA;AACF,iBAAA,CAAA;;;AChCD;;AAEG;;;;"}
|
|
@@ -6,10 +6,10 @@ class ActionsPipe {
|
|
|
6
6
|
transform(value, ...args) {
|
|
7
7
|
return resolveActions(value, ...args);
|
|
8
8
|
}
|
|
9
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
10
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ActionsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
10
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: ActionsPipe, isStandalone: true, name: "resolveActions" }); }
|
|
11
11
|
}
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: ActionsPipe, decorators: [{
|
|
13
13
|
type: Pipe,
|
|
14
14
|
args: [{
|
|
15
15
|
standalone: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-pipes-actions.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/pipes/actions/actions.pipe.ts","../../../../../packages/@ng-atomic/common/src/lib/pipes/actions/ng-atomic-common-pipes-actions.ts"],"sourcesContent":["import { Pipe } from \"@angular/core\";\nimport { resolveActions } from \"@ng-atomic/core\";\n\n@Pipe({\n standalone: true,\n name: 'resolveActions',\n pure: true\n})\nexport class ActionsPipe {\n transform(value: any, ...args: any[]): any {\n return resolveActions(value, ...args);\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;MAQa,WAAW,CAAA;AACtB,IAAA,SAAS,CAAC,KAAU,EAAE,GAAG,IAAW,EAAA;AAClC,QAAA,OAAO,cAAc,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC;KACvC
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-pipes-actions.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/pipes/actions/actions.pipe.ts","../../../../../packages/@ng-atomic/common/src/lib/pipes/actions/ng-atomic-common-pipes-actions.ts"],"sourcesContent":["import { Pipe } from \"@angular/core\";\nimport { resolveActions } from \"@ng-atomic/core\";\n\n@Pipe({\n standalone: true,\n name: 'resolveActions',\n pure: true\n})\nexport class ActionsPipe {\n transform(value: any, ...args: any[]): any {\n return resolveActions(value, ...args);\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;MAQa,WAAW,CAAA;AACtB,IAAA,SAAS,CAAC,KAAU,EAAE,GAAG,IAAW,EAAA;AAClC,QAAA,OAAO,cAAc,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC;KACvC;8GAHU,WAAW,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,IAAA,EAAA,CAAA,CAAA,EAAA;4GAAX,WAAW,EAAA,YAAA,EAAA,IAAA,EAAA,IAAA,EAAA,gBAAA,EAAA,CAAA,CAAA,EAAA;;2FAAX,WAAW,EAAA,UAAA,EAAA,CAAA;kBALvB,IAAI;AAAC,YAAA,IAAA,EAAA,CAAA;AACJ,oBAAA,UAAU,EAAE,IAAI;AAChB,oBAAA,IAAI,EAAE,gBAAgB;AACtB,oBAAA,IAAI,EAAE,IAAI;AACX,iBAAA,CAAA;;;ACPD;;AAEG;;;;"}
|
|
@@ -1,37 +1,37 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { InjectionToken,
|
|
2
|
+
import { InjectionToken, inject, Pipe } from '@angular/core';
|
|
3
3
|
import get from 'lodash.get';
|
|
4
4
|
|
|
5
5
|
const DATA_ACCESSOR = new InjectionToken('DATA_ACCESSOR');
|
|
6
6
|
const defaultDataAccessor = (obj, key) => get(obj, key) ?? '';
|
|
7
|
+
function provideDataAccessor(useFactory = () => defaultDataAccessor) {
|
|
8
|
+
return { provide: DATA_ACCESSOR, useFactory };
|
|
9
|
+
}
|
|
10
|
+
function injectDataAccessor() {
|
|
11
|
+
return inject(DATA_ACCESSOR, { optional: true }) ?? defaultDataAccessor;
|
|
12
|
+
}
|
|
7
13
|
class DataAccessorPipe {
|
|
8
|
-
constructor(
|
|
9
|
-
this.dataAccessor =
|
|
10
|
-
this.dataAccessor ??= defaultDataAccessor;
|
|
14
|
+
constructor() {
|
|
15
|
+
this.dataAccessor = inject(DATA_ACCESSOR, { optional: true }) ?? defaultDataAccessor;
|
|
11
16
|
}
|
|
12
17
|
transform(data, key) {
|
|
13
18
|
return this.dataAccessor(data, key);
|
|
14
19
|
}
|
|
15
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
16
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DataAccessorPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
21
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.2", ngImport: i0, type: DataAccessorPipe, isStandalone: true, name: "dataAccessor" }); }
|
|
17
22
|
}
|
|
18
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DataAccessorPipe, decorators: [{
|
|
19
24
|
type: Pipe,
|
|
20
25
|
args: [{
|
|
21
26
|
name: 'dataAccessor',
|
|
22
27
|
pure: true,
|
|
23
28
|
standalone: true,
|
|
24
29
|
}]
|
|
25
|
-
}]
|
|
26
|
-
type: Optional
|
|
27
|
-
}, {
|
|
28
|
-
type: Inject,
|
|
29
|
-
args: [DATA_ACCESSOR]
|
|
30
|
-
}] }]; } });
|
|
30
|
+
}] });
|
|
31
31
|
|
|
32
32
|
/**
|
|
33
33
|
* Generated bundle index. Do not edit.
|
|
34
34
|
*/
|
|
35
35
|
|
|
36
|
-
export { DATA_ACCESSOR, DataAccessorPipe, defaultDataAccessor };
|
|
36
|
+
export { DATA_ACCESSOR, DataAccessorPipe, defaultDataAccessor, injectDataAccessor, provideDataAccessor };
|
|
37
37
|
//# sourceMappingURL=ng-atomic-common-pipes-data-accessor.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-pipes-data-accessor.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/pipes/data-accessor/data-accessor.pipe.ts","../../../../../packages/@ng-atomic/common/src/lib/pipes/data-accessor/ng-atomic-common-pipes-data-accessor.ts"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-pipes-data-accessor.mjs","sources":["../../../../../packages/@ng-atomic/common/src/lib/pipes/data-accessor/data-accessor.pipe.ts","../../../../../packages/@ng-atomic/common/src/lib/pipes/data-accessor/ng-atomic-common-pipes-data-accessor.ts"],"sourcesContent":["import { InjectionToken, Pipe, inject } from \"@angular/core\";\nimport get from 'lodash.get';\n\nexport type DataAccessor<T> = (obj: T, key: string) => string;\nexport const DATA_ACCESSOR = new InjectionToken<DataAccessor<any>>('DATA_ACCESSOR');\nexport const defaultDataAccessor: DataAccessor<any> = (obj, key) => get(obj, key) ?? '';\nexport function provideDataAccessor<T>(useFactory: () => DataAccessor<T> = () => defaultDataAccessor) {\n return { provide: DATA_ACCESSOR, useFactory };\n}\n\nexport function injectDataAccessor<T>(): DataAccessor<T> {\n return inject(DATA_ACCESSOR, {optional: true}) ?? defaultDataAccessor;\n}\n\n@Pipe({\n name: 'dataAccessor',\n pure: true,\n standalone: true,\n})\nexport class DataAccessorPipe<T> {\n protected dataAccessor = inject(DATA_ACCESSOR, {optional: true}) ?? defaultDataAccessor;\n\n transform(data: T, key: string) {\n return this.dataAccessor(data, key);\n }\n}\n\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;MAIa,aAAa,GAAG,IAAI,cAAc,CAAoB,eAAe,EAAE;AACvE,MAAA,mBAAmB,GAAsB,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,GAAG;SACxE,mBAAmB,CAAI,aAAoC,MAAM,mBAAmB,EAAA;AAClG,IAAA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC;AAChD,CAAC;SAEe,kBAAkB,GAAA;AAChC,IAAA,OAAO,MAAM,CAAC,aAAa,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,IAAI,mBAAmB,CAAC;AACxE,CAAC;MAOY,gBAAgB,CAAA;AAL7B,IAAA,WAAA,GAAA;AAMY,QAAA,IAAA,CAAA,YAAY,GAAG,MAAM,CAAC,aAAa,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,IAAI,mBAAmB,CAAC;AAKzF,KAAA;IAHC,SAAS,CAAC,IAAO,EAAE,GAAW,EAAA;QAC5B,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;KACrC;8GALU,gBAAgB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,IAAA,EAAA,CAAA,CAAA,EAAA;4GAAhB,gBAAgB,EAAA,YAAA,EAAA,IAAA,EAAA,IAAA,EAAA,cAAA,EAAA,CAAA,CAAA,EAAA;;2FAAhB,gBAAgB,EAAA,UAAA,EAAA,CAAA;kBAL5B,IAAI;AAAC,YAAA,IAAA,EAAA,CAAA;AACJ,oBAAA,IAAI,EAAE,cAAc;AACpB,oBAAA,IAAI,EAAE,IAAI;AACV,oBAAA,UAAU,EAAE,IAAI;AACjB,iBAAA,CAAA;;;AClBD;;AAEG;;;;"}
|