ngx-edu-sharing-metaqs2 0.9.53 → 0.9.54
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/README.md +1 -14
- package/fesm2022/ngx-edu-sharing-metaqs2.mjs +195 -197
- package/fesm2022/ngx-edu-sharing-metaqs2.mjs.map +1 -1
- package/lib/components/collection-issues/collection-issues.component.d.ts +1 -1
- package/lib/components/donut-chart-tooltip/donut-chart-tooltip.component.d.ts +1 -1
- package/lib/components/filter/quality-matrix-filter.component.d.ts +4 -6
- package/lib/components/material-issues/material-issues.component.d.ts +1 -1
- package/lib/components/node-entry/node-entry.component.d.ts +1 -1
- package/lib/components/node-list/node-list.component.d.ts +1 -1
- package/lib/components/quality-matrix/quality_matrix.d.ts +1 -3
- package/lib/counts-with-history/counts-with-history.component.d.ts +1 -1
- package/lib/ng-meta-widgets-lib.module.d.ts +34 -37
- package/lib/node-image-url.pipe.d.ts +1 -1
- package/lib/wrap-observable.pipe.d.ts +1 -1
- package/package.json +6 -8
- package/esm2022/lib/collection-count-history/collection-count-history.component.mjs +0 -131
- package/esm2022/lib/collection-count-history/monthpicker/monthpicker.component.mjs +0 -114
- package/esm2022/lib/components/collection-issues/collection-issues.component.mjs +0 -23
- package/esm2022/lib/components/donut-chart/donut-chart.component.mjs +0 -85
- package/esm2022/lib/components/donut-chart/donut-chart.model.mjs +0 -2
- package/esm2022/lib/components/donut-chart/donut-chart.pipe.mjs +0 -50
- package/esm2022/lib/components/donut-chart-tooltip/donut-chart-tooltip.component.mjs +0 -79
- package/esm2022/lib/components/editorial-link-service/editorial-link.service.mjs +0 -169
- package/esm2022/lib/components/filter/datepicker/datepicker.component.mjs +0 -99
- package/esm2022/lib/components/filter/quality-matrix-filter.component.mjs +0 -47
- package/esm2022/lib/components/loading_indicator/overlay/overlay.service.mjs +0 -41
- package/esm2022/lib/components/loading_indicator/progress-spinner/progress-spinner.component.mjs +0 -65
- package/esm2022/lib/components/material-issues/material-issues.component.mjs +0 -23
- package/esm2022/lib/components/node-entry/node-entry.component.mjs +0 -35
- package/esm2022/lib/components/node-list/node-list.component.mjs +0 -112
- package/esm2022/lib/components/quality-matrix/quality_matrix.mjs +0 -413
- package/esm2022/lib/components/quality-matrix/scroll-marker.directive.mjs +0 -17
- package/esm2022/lib/config-helper.service.mjs +0 -32
- package/esm2022/lib/core/svg-icons.service.mjs +0 -44
- package/esm2022/lib/core/tooltip.service.mjs +0 -146
- package/esm2022/lib/counts-with-history/counts-with-history.component.mjs +0 -203
- package/esm2022/lib/java-api/api/api.mjs +0 -12
- package/esm2022/lib/java-api/api/authProxyController.service.mjs +0 -107
- package/esm2022/lib/java-api/api/collectionAPI.service.mjs +0 -409
- package/esm2022/lib/java-api/api/editorsAPI.service.mjs +0 -157
- package/esm2022/lib/java-api/api/filterAPI.service.mjs +0 -237
- package/esm2022/lib/java-api/api/replicationSourceAPI.service.mjs +0 -230
- package/esm2022/lib/java-api/api.base.service.mjs +0 -66
- package/esm2022/lib/java-api/api.module.mjs +0 -40
- package/esm2022/lib/java-api/configuration.mjs +0 -103
- package/esm2022/lib/java-api/encoder.mjs +0 -19
- package/esm2022/lib/java-api/index.mjs +0 -7
- package/esm2022/lib/java-api/model/collectionWithMissingAttributes.mjs +0 -11
- package/esm2022/lib/java-api/model/count.mjs +0 -11
- package/esm2022/lib/java-api/model/eduCollection.mjs +0 -11
- package/esm2022/lib/java-api/model/filter.mjs +0 -2
- package/esm2022/lib/java-api/model/filterValue.mjs +0 -11
- package/esm2022/lib/java-api/model/materialCountDto.mjs +0 -2
- package/esm2022/lib/java-api/model/materialCountFilter.mjs +0 -11
- package/esm2022/lib/java-api/model/materialWithMissingAttributes.mjs +0 -11
- package/esm2022/lib/java-api/model/matrixRowWithCounts.mjs +0 -2
- package/esm2022/lib/java-api/model/matrixWithCounts.mjs +0 -2
- package/esm2022/lib/java-api/model/missingAttributeResult.mjs +0 -2
- package/esm2022/lib/java-api/model/models.mjs +0 -16
- package/esm2022/lib/java-api/model/qualityMatrix.mjs +0 -2
- package/esm2022/lib/java-api/model/qualityMatrixHeader.mjs +0 -11
- package/esm2022/lib/java-api/model/qualityMatrixReplicationSourceCounts.mjs +0 -11
- package/esm2022/lib/java-api/model/qualityMatrixRow.mjs +0 -2
- package/esm2022/lib/java-api/param.mjs +0 -2
- package/esm2022/lib/java-api/variables.mjs +0 -9
- package/esm2022/lib/meta-api.service.mjs +0 -77
- package/esm2022/lib/ng-meta-widgets-lib.module.mjs +0 -198
- package/esm2022/lib/node-image-url.pipe.mjs +0 -29
- package/esm2022/lib/tree-collection-details/tree-collection-details.component.mjs +0 -87
- package/esm2022/lib/tree-license/tree-license.component.mjs +0 -136
- package/esm2022/lib/tree-search-counts/inline-worker.mjs +0 -102
- package/esm2022/lib/tree-search-counts/tree-search-counts.component.mjs +0 -209
- package/esm2022/lib/wrap-observable.pipe.mjs +0 -21
- package/esm2022/ngx-edu-sharing-metaqs2.mjs +0 -5
- package/esm2022/public-api.mjs +0 -18
- package/esm2022/web-components.mjs +0 -36
|
@@ -8,5 +8,5 @@ export declare class CollectionIssuesComponent implements OnInit {
|
|
|
8
8
|
constructor(filterAPIService: FilterAPIService);
|
|
9
9
|
ngOnInit(): Promise<void>;
|
|
10
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<CollectionIssuesComponent, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CollectionIssuesComponent, "metaqs2-collection-issues", never, {}, {}, never, never,
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CollectionIssuesComponent, "metaqs2-collection-issues", never, {}, {}, never, never, true, never>;
|
|
12
12
|
}
|
|
@@ -10,5 +10,5 @@ export declare class DonutChartTooltipComponent implements DataTooltip<DonutChar
|
|
|
10
10
|
animationState: boolean;
|
|
11
11
|
readonly data: DonutChartTooltipData;
|
|
12
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<DonutChartTooltipComponent, never>;
|
|
13
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DonutChartTooltipComponent, "metaqs2-donut-chart-tooltip", never, {}, {}, never, never,
|
|
13
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DonutChartTooltipComponent, "metaqs2-donut-chart-tooltip", never, {}, {}, never, never, true, never>;
|
|
14
14
|
}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { FormControl } from '@angular/forms';
|
|
2
2
|
import { FilterValue } from '../../java-api';
|
|
3
|
-
import { Observable } from 'rxjs';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
/**
|
|
6
5
|
* This component wraps a mat-select.
|
|
@@ -13,10 +12,9 @@ import * as i0 from "@angular/core";
|
|
|
13
12
|
export declare class QualityMatrixFilterComponent {
|
|
14
13
|
options: FilterValue[] | undefined | null;
|
|
15
14
|
inputFormControl: FormControl<any>;
|
|
16
|
-
label: string
|
|
17
|
-
multiple: boolean
|
|
18
|
-
changedFilters:
|
|
19
|
-
optionIdent(_index: number, option: FilterValue): string;
|
|
15
|
+
label: import("@angular/core").InputSignal<string | undefined>;
|
|
16
|
+
multiple: import("@angular/core").InputSignal<boolean>;
|
|
17
|
+
changedFilters: import("@angular/core").OutputRef<any>;
|
|
20
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<QualityMatrixFilterComponent, never>;
|
|
21
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<QualityMatrixFilterComponent, "metaqs2-qm-filter", never, { "options": { "alias": "options"; "required": false; }; "inputFormControl": { "alias": "inputFormControl"; "required": false; }; "label": { "alias": "label"; "required": false; }; "multiple": { "alias": "multiple"; "required": false; }; }, { "changedFilters": "changedFilters"; }, never, never, true, never>;
|
|
19
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<QualityMatrixFilterComponent, "metaqs2-qm-filter", never, { "options": { "alias": "options"; "required": false; }; "inputFormControl": { "alias": "inputFormControl"; "required": false; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "multiple": { "alias": "multiple"; "required": false; "isSignal": true; }; }, { "changedFilters": "changedFilters"; }, never, never, true, never>;
|
|
22
20
|
}
|
|
@@ -8,5 +8,5 @@ export declare class MaterialIssuesComponent implements OnInit {
|
|
|
8
8
|
constructor(filterAPIService: FilterAPIService);
|
|
9
9
|
ngOnInit(): Promise<void>;
|
|
10
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<MaterialIssuesComponent, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<MaterialIssuesComponent, "metaqs2-material-issues", never, {}, {}, never, never,
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MaterialIssuesComponent, "metaqs2-material-issues", never, {}, {}, never, never, true, never>;
|
|
12
12
|
}
|
|
@@ -9,5 +9,5 @@ export declare class NodeEntryComponent {
|
|
|
9
9
|
openNode(node: MaterialWithMissingAttributes | CollectionWithMissingAttributes): void;
|
|
10
10
|
isCollectionCount(): boolean;
|
|
11
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<NodeEntryComponent, never>;
|
|
12
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NodeEntryComponent, "metaqs2-node-entry", never, { "node": { "alias": "node"; "required": false; }; }, { "edit": "edit"; }, never, never,
|
|
12
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NodeEntryComponent, "metaqs2-node-entry", never, { "node": { "alias": "node"; "required": false; }; }, { "edit": "edit"; }, never, never, true, never>;
|
|
13
13
|
}
|
|
@@ -36,5 +36,5 @@ export declare class NodeListComponent implements OnChanges, OnDestroy {
|
|
|
36
36
|
editNode(node: MaterialWithMissingAttributes | CollectionWithMissingAttributes): void;
|
|
37
37
|
filterCount(): void;
|
|
38
38
|
static ɵfac: i0.ɵɵFactoryDeclaration<NodeListComponent, never>;
|
|
39
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NodeListComponent, "metaqs2-node-list", never, { "mode": { "alias": "mode"; "required": false; }; "type": { "alias": "type"; "required": false; }; "collectionId": { "alias": "collectionId"; "required": false; }; }, { "countChanged": "countChanged"; }, never, never,
|
|
39
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NodeListComponent, "metaqs2-node-list", never, { "mode": { "alias": "mode"; "required": false; }; "type": { "alias": "type"; "required": false; }; "collectionId": { "alias": "collectionId"; "required": false; }; }, { "countChanged": "countChanged"; }, never, never, true, never>;
|
|
40
40
|
}
|
|
@@ -6,7 +6,6 @@ import { FormControl, FormGroup, FormRecord } from '@angular/forms';
|
|
|
6
6
|
import { EditorialLinkService } from '../editorial-link-service/editorial-link.service';
|
|
7
7
|
import { DateTime } from 'luxon';
|
|
8
8
|
import { DonutSlice } from '../donut-chart/donut-chart.model';
|
|
9
|
-
import { KeyValue } from '@angular/common';
|
|
10
9
|
import { Overlay } from '@angular/cdk/overlay';
|
|
11
10
|
import { TooltipService } from '../../core/tooltip.service';
|
|
12
11
|
import * as i0 from "@angular/core";
|
|
@@ -21,7 +20,6 @@ export declare class QualityMatrixComponent implements OnInit, AfterViewChecked
|
|
|
21
20
|
private readonly scrollWidth;
|
|
22
21
|
readonly isLeftScrollable: import("@angular/core").Signal<boolean>;
|
|
23
22
|
readonly isRightScrollable: import("@angular/core").Signal<boolean | undefined>;
|
|
24
|
-
private readonly issueTypeHeader;
|
|
25
23
|
readonly filteredColumns: import("@angular/core").Signal<QualityMatrixHeader[]>;
|
|
26
24
|
readonly datatableColumns: import("@angular/core").Signal<string[]>;
|
|
27
25
|
readonly isHistoricalDataEnabledFormField: FormControl<boolean | null>;
|
|
@@ -31,6 +29,7 @@ export declare class QualityMatrixComponent implements OnInit, AfterViewChecked
|
|
|
31
29
|
readonly categoryControls: FormRecord<FormControl<string[]>>;
|
|
32
30
|
readonly loadingCount: import("@angular/core").WritableSignal<number>;
|
|
33
31
|
readonly isLoading: import("@angular/core").Signal<boolean>;
|
|
32
|
+
private readonly issueTypeHeader;
|
|
34
33
|
private readonly scrollMarkers;
|
|
35
34
|
readonly categoryFilterValues: Map<string, FilterValue[]>;
|
|
36
35
|
protected readonly refresh$: Subject<void>;
|
|
@@ -46,7 +45,6 @@ export declare class QualityMatrixComponent implements OnInit, AfterViewChecked
|
|
|
46
45
|
pageTitle: string;
|
|
47
46
|
readonly allColumns: import("@angular/core").Signal<QualityMatrixHeader[]>;
|
|
48
47
|
ngAfterViewChecked(): void;
|
|
49
|
-
filterIdent(_index: number, item: KeyValue<string, FormControl<string[]>>): string;
|
|
50
48
|
sourceColumns: import("@angular/core").Signal<string[]>;
|
|
51
49
|
currentColumns: import("@angular/core").Signal<string[]>;
|
|
52
50
|
pastColumns: import("@angular/core").Signal<string[]>;
|
|
@@ -54,7 +54,7 @@ export declare abstract class BaseHistoricDataTableDirective<TLoadingData extend
|
|
|
54
54
|
};
|
|
55
55
|
openInEditor(sourceId: string, issueId: string): Observable<string | null>;
|
|
56
56
|
static ɵfac: i0.ɵɵFactoryDeclaration<BaseHistoricDataTableDirective<any, any>, never>;
|
|
57
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<BaseHistoricDataTableDirective<any, any>, never, never, { "apiMethod": { "alias": "apiMethod"; "required": false; }; "columnTranslationkey": { "alias": "columnTranslationkey"; "required": false; }; "pageTitle": { "alias": "pageTitle"; "required": false; }; "sourceType": { "alias": "sourceType"; "required": true; }; }, {}, never, never,
|
|
57
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<BaseHistoricDataTableDirective<any, any>, never, never, { "apiMethod": { "alias": "apiMethod"; "required": false; }; "columnTranslationkey": { "alias": "columnTranslationkey"; "required": false; }; "pageTitle": { "alias": "pageTitle"; "required": false; }; "sourceType": { "alias": "sourceType"; "required": true; }; }, {}, never, never, true, never>;
|
|
58
58
|
}
|
|
59
59
|
type LoadingData = {
|
|
60
60
|
date: DateTime;
|
|
@@ -2,48 +2,45 @@ import { ModuleWithProviders } from '@angular/core';
|
|
|
2
2
|
import { NgMetaWidgetsLibConfiguration } from './config-helper.service';
|
|
3
3
|
import { SvgIconsService } from './core/svg-icons.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "./components/
|
|
8
|
-
import * as i4 from "./components/
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@ngx-translate/core";
|
|
7
|
+
import * as i3 from "./components/collection-issues/collection-issues.component";
|
|
8
|
+
import * as i4 from "./components/material-issues/material-issues.component";
|
|
9
9
|
import * as i5 from "./components/node-list/node-list.component";
|
|
10
|
-
import * as i6 from "
|
|
11
|
-
import * as i7 from "./
|
|
12
|
-
import * as i8 from "@angular/
|
|
13
|
-
import * as i9 from "
|
|
14
|
-
import * as i10 from "
|
|
15
|
-
import * as i11 from "
|
|
16
|
-
import * as i12 from "
|
|
17
|
-
import * as i13 from "
|
|
18
|
-
import * as i14 from "@angular/
|
|
19
|
-
import * as i15 from "
|
|
20
|
-
import * as i16 from "@angular/material/
|
|
21
|
-
import * as i17 from "
|
|
22
|
-
import * as i18 from "@angular/material/
|
|
23
|
-
import * as i19 from "@angular/material/
|
|
24
|
-
import * as i20 from "@angular/material/
|
|
25
|
-
import * as i21 from "@angular/material/
|
|
26
|
-
import * as i22 from "@angular/material/
|
|
27
|
-
import * as i23 from "@angular/material/
|
|
28
|
-
import * as i24 from "@angular/
|
|
29
|
-
import * as i25 from "@angular/material/
|
|
30
|
-
import * as i26 from "@angular/
|
|
31
|
-
import * as i27 from "@angular/material/
|
|
32
|
-
import * as i28 from "@angular/material/
|
|
33
|
-
import * as i29 from "@angular/material/
|
|
34
|
-
import * as i30 from "
|
|
35
|
-
import * as i31 from "@angular/material/
|
|
36
|
-
import * as i32 from "
|
|
37
|
-
import * as i33 from "./components/
|
|
38
|
-
import * as i34 from "
|
|
39
|
-
import * as i35 from "./components/filter/datepicker/datepicker.component";
|
|
40
|
-
import * as i36 from "./components/loading_indicator/progress-spinner/progress-spinner.component";
|
|
41
|
-
import * as i37 from "./components/quality-matrix/scroll-marker.directive";
|
|
10
|
+
import * as i6 from "@angular/platform-browser";
|
|
11
|
+
import * as i7 from "./java-api/api.module";
|
|
12
|
+
import * as i8 from "@angular/material/card";
|
|
13
|
+
import * as i9 from "@angular/material/tree";
|
|
14
|
+
import * as i10 from "./components/donut-chart/donut-chart.component";
|
|
15
|
+
import * as i11 from "./components/donut-chart/donut-chart.pipe";
|
|
16
|
+
import * as i12 from "@angular/platform-browser/animations";
|
|
17
|
+
import * as i13 from "@angular/material/icon";
|
|
18
|
+
import * as i14 from "@angular/material/slider";
|
|
19
|
+
import * as i15 from "./components/quality-matrix/quality_matrix";
|
|
20
|
+
import * as i16 from "@angular/material/slide-toggle";
|
|
21
|
+
import * as i17 from "@angular/material/button";
|
|
22
|
+
import * as i18 from "@angular/material/progress-spinner";
|
|
23
|
+
import * as i19 from "@angular/material/table";
|
|
24
|
+
import * as i20 from "@angular/material/grid-list";
|
|
25
|
+
import * as i21 from "@angular/material/form-field";
|
|
26
|
+
import * as i22 from "@angular/material/input";
|
|
27
|
+
import * as i23 from "@angular/material/sidenav";
|
|
28
|
+
import * as i24 from "@angular/forms";
|
|
29
|
+
import * as i25 from "@angular/material/select";
|
|
30
|
+
import * as i26 from "@angular/material/tooltip";
|
|
31
|
+
import * as i27 from "@angular/material/list";
|
|
32
|
+
import * as i28 from "@angular/material/sort";
|
|
33
|
+
import * as i29 from "@angular/material/checkbox";
|
|
34
|
+
import * as i30 from "./components/filter/quality-matrix-filter.component";
|
|
35
|
+
import * as i31 from "@angular/material/datepicker";
|
|
36
|
+
import * as i32 from "./components/filter/datepicker/datepicker.component";
|
|
37
|
+
import * as i33 from "./components/loading_indicator/progress-spinner/progress-spinner.component";
|
|
38
|
+
import * as i34 from "./components/quality-matrix/scroll-marker.directive";
|
|
42
39
|
export declare class NgMetaWidgetsLibModule {
|
|
43
40
|
private readonly svgIconsService;
|
|
44
41
|
constructor(svgIconsService: SvgIconsService);
|
|
45
42
|
static forRoot(params: NgMetaWidgetsLibConfiguration): ModuleWithProviders<NgMetaWidgetsLibModule>;
|
|
46
43
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgMetaWidgetsLibModule, never>;
|
|
47
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<NgMetaWidgetsLibModule, [typeof i1.
|
|
44
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NgMetaWidgetsLibModule, never, [typeof i1.CommonModule, typeof i2.TranslateModule, typeof i3.CollectionIssuesComponent, typeof i4.MaterialIssuesComponent, typeof i5.NodeListComponent, typeof i6.BrowserModule, typeof i7.ApiModule, typeof i8.MatCardModule, typeof i9.MatTreeModule, typeof i10.DonutChartComponent, typeof i11.DonutChartPipe, typeof i12.BrowserAnimationsModule, typeof i13.MatIconModule, typeof i14.MatSliderModule, typeof i15.QualityMatrixComponent, typeof i16.MatSlideToggleModule, typeof i17.MatButtonModule, typeof i18.MatProgressSpinnerModule, typeof i19.MatTableModule, typeof i20.MatGridListModule, typeof i21.MatFormFieldModule, typeof i22.MatInputModule, typeof i23.MatSidenavModule, typeof i24.FormsModule, typeof i25.MatSelectModule, typeof i24.ReactiveFormsModule, typeof i26.MatTooltipModule, typeof i27.MatListModule, typeof i28.MatSort, typeof i28.MatSortModule, typeof i29.MatCheckbox, typeof i2.TranslateModule, typeof i30.QualityMatrixFilterComponent, typeof i31.MatDateRangeInput, typeof i31.MatDatepickerToggle, typeof i31.MatDatepickerModule, typeof i31.MatDateRangePicker, typeof i31.MatDatepickerInput, typeof i31.MatDatepicker, typeof i32.DatepickerComponent, typeof i33.ProgressSpinnerComponent, typeof i34.ScrollMarkerDirective], [typeof i3.CollectionIssuesComponent, typeof i4.MaterialIssuesComponent, typeof i5.NodeListComponent, typeof i15.QualityMatrixComponent]>;
|
|
48
45
|
static ɵinj: i0.ɵɵInjectorDeclaration<NgMetaWidgetsLibModule>;
|
|
49
46
|
}
|
|
@@ -8,5 +8,5 @@ export declare class NodeImageUrlPipe implements PipeTransform {
|
|
|
8
8
|
height: number;
|
|
9
9
|
}): string;
|
|
10
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<NodeImageUrlPipe, never>;
|
|
11
|
-
static ɵpipe: i0.ɵɵPipeDeclaration<NodeImageUrlPipe, "nodeImageUrl",
|
|
11
|
+
static ɵpipe: i0.ɵɵPipeDeclaration<NodeImageUrlPipe, "nodeImageUrl", true>;
|
|
12
12
|
}
|
|
@@ -14,5 +14,5 @@ export declare function wrapResponse<T>(): UnaryFunction<Observable<T>, Observab
|
|
|
14
14
|
export declare class WrapObservablePipe implements PipeTransform {
|
|
15
15
|
transform<T>(value: Observable<T>): Observable<WrappedResponse<T>>;
|
|
16
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<WrapObservablePipe, never>;
|
|
17
|
-
static ɵpipe: i0.ɵɵPipeDeclaration<WrapObservablePipe, "wrapObservable",
|
|
17
|
+
static ɵpipe: i0.ɵɵPipeDeclaration<WrapObservablePipe, "wrapObservable", true>;
|
|
18
18
|
}
|
package/package.json
CHANGED
|
@@ -2,14 +2,14 @@
|
|
|
2
2
|
"name": "ngx-edu-sharing-metaqs2",
|
|
3
3
|
"description": "OEH MetaQS widgets library",
|
|
4
4
|
"license": "GNU GPL v2",
|
|
5
|
-
"version": "0.9.
|
|
5
|
+
"version": "0.9.54",
|
|
6
6
|
"author": "Torsten Simon",
|
|
7
7
|
"peerDependencies": {
|
|
8
|
-
"@angular/common": ">=
|
|
9
|
-
"@angular/core": ">=
|
|
10
|
-
"@angular/cdk": ">=
|
|
11
|
-
"@angular/elements": ">=
|
|
12
|
-
"@angular/material": ">=
|
|
8
|
+
"@angular/common": ">=19.0.0",
|
|
9
|
+
"@angular/core": ">=10.0.0",
|
|
10
|
+
"@angular/cdk": ">=19.0.0",
|
|
11
|
+
"@angular/elements": ">=19.0.0",
|
|
12
|
+
"@angular/material": ">=19.0.0",
|
|
13
13
|
"ng2-charts": ">=6.0.1"
|
|
14
14
|
},
|
|
15
15
|
"dependencies": {
|
|
@@ -23,8 +23,6 @@
|
|
|
23
23
|
},
|
|
24
24
|
".": {
|
|
25
25
|
"types": "./index.d.ts",
|
|
26
|
-
"esm2022": "./esm2022/ngx-edu-sharing-metaqs2.mjs",
|
|
27
|
-
"esm": "./esm2022/ngx-edu-sharing-metaqs2.mjs",
|
|
28
26
|
"default": "./fesm2022/ngx-edu-sharing-metaqs2.mjs"
|
|
29
27
|
}
|
|
30
28
|
},
|
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
import { Component, effect, Input, signal, ViewChild } from '@angular/core';
|
|
2
|
-
import { BaseChartDirective } from 'ng2-charts';
|
|
3
|
-
import { DateTime } from 'luxon';
|
|
4
|
-
import { MatCard, MatCardContent, MatCardHeader, MatCardTitle } from '@angular/material/card';
|
|
5
|
-
import { FormControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
6
|
-
import { MonthpickerComponent } from './monthpicker/monthpicker.component';
|
|
7
|
-
import { BehaviorSubject } from 'rxjs';
|
|
8
|
-
import { AsyncPipe, NgIf } from '@angular/common';
|
|
9
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
10
|
-
import { distinctUntilChanged, filter, finalize, map, switchMap, take, tap } from 'rxjs/operators';
|
|
11
|
-
import { MatSlideToggle } from '@angular/material/slide-toggle';
|
|
12
|
-
import { ProgressSpinnerComponent } from '../components/loading_indicator/progress-spinner/progress-spinner.component';
|
|
13
|
-
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "../meta-api.service";
|
|
15
|
-
import * as i2 from "@angular/forms";
|
|
16
|
-
export class CollectionCountHistoryComponent {
|
|
17
|
-
constructor(metaApi, destroyRef) {
|
|
18
|
-
this.metaApi = metaApi;
|
|
19
|
-
this.destroyRef = destroyRef;
|
|
20
|
-
this.lineChartOptions = {
|
|
21
|
-
parsing: {
|
|
22
|
-
xAxisKey: 'date',
|
|
23
|
-
yAxisKey: 'count',
|
|
24
|
-
},
|
|
25
|
-
font: {
|
|
26
|
-
family: 'Montserrat',
|
|
27
|
-
},
|
|
28
|
-
animation: false,
|
|
29
|
-
};
|
|
30
|
-
this.datapoints$ = new BehaviorSubject([]);
|
|
31
|
-
this.isLoading = signal(true);
|
|
32
|
-
this.range = new FormGroup({
|
|
33
|
-
start: new FormControl(),
|
|
34
|
-
end: new FormControl(),
|
|
35
|
-
});
|
|
36
|
-
this.granularities = ['year', 'month', 'week', 'day'];
|
|
37
|
-
this.granularity = new FormControl('month', { nonNullable: true });
|
|
38
|
-
this.isHistoryEnabled = signal(true);
|
|
39
|
-
effect(() => {
|
|
40
|
-
this.range.controls.end.reset();
|
|
41
|
-
if (!this.isHistoryEnabled()) {
|
|
42
|
-
this.range.controls.start.setValue(this.range.controls.end.value);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
this.range.controls.start.reset();
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
ngOnInit() {
|
|
50
|
-
this.registerDateRangeFilter();
|
|
51
|
-
}
|
|
52
|
-
registerDateRangeFilter() {
|
|
53
|
-
this.range.valueChanges
|
|
54
|
-
.pipe(filter((range) => !!range.start && !!range.end),
|
|
55
|
-
//the Material Datepicker emits the initial values 4 times when it starts, so we need to distinct them
|
|
56
|
-
distinctUntilChanged((prev, curr) => {
|
|
57
|
-
return prev.start === curr.start && prev.end === curr.end;
|
|
58
|
-
}), switchMap((range) => {
|
|
59
|
-
if (this.isHistoryEnabled()) {
|
|
60
|
-
return this.loadData(range.start, range.end);
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
return this.loadData(range.end.startOf(this.granularity.value), range.end);
|
|
64
|
-
}
|
|
65
|
-
}), takeUntilDestroyed(this.destroyRef))
|
|
66
|
-
.subscribe();
|
|
67
|
-
this.metaApi
|
|
68
|
-
.getTimerangeFilter()
|
|
69
|
-
.pipe(take(1))
|
|
70
|
-
.subscribe((rangeFilter) => {
|
|
71
|
-
if (rangeFilter) {
|
|
72
|
-
const startDate = DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeStart')?.label, {
|
|
73
|
-
zone: 'utc',
|
|
74
|
-
}).startOf(this.granularity.value);
|
|
75
|
-
const endDate = DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeEnd')?.label, {
|
|
76
|
-
zone: 'utc',
|
|
77
|
-
}).endOf(this.granularity.value);
|
|
78
|
-
this.range.setControl('start', new FormControl(startDate, { nonNullable: true }), {
|
|
79
|
-
emitEvent: false,
|
|
80
|
-
});
|
|
81
|
-
this.range.setControl('end', new FormControl(endDate, { nonNullable: true }), { emitEvent: false });
|
|
82
|
-
}
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
loadData(start, end) {
|
|
86
|
-
this.isLoading.set(true);
|
|
87
|
-
const request = {
|
|
88
|
-
startDate: start?.toISO(),
|
|
89
|
-
endDate: end?.toISO(),
|
|
90
|
-
granularity: this.granularity.value,
|
|
91
|
-
};
|
|
92
|
-
return this.metaApi.getEditorialMaterialCounts(request).pipe(map((response) => response.map((data) => {
|
|
93
|
-
return {
|
|
94
|
-
data: data.counts.map((count) => {
|
|
95
|
-
return {
|
|
96
|
-
date: DateTime.fromISO(count.date).toFormat('LLLL yyyy'),
|
|
97
|
-
count: count.count,
|
|
98
|
-
};
|
|
99
|
-
}),
|
|
100
|
-
label: data.name,
|
|
101
|
-
};
|
|
102
|
-
})), take(1), tap((datapoints) => {
|
|
103
|
-
this.datapoints$.next(datapoints);
|
|
104
|
-
}), finalize(() => this.isLoading.set(false)));
|
|
105
|
-
}
|
|
106
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CollectionCountHistoryComponent, deps: [{ token: i1.MetaApiService }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
107
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CollectionCountHistoryComponent, isStandalone: true, selector: "metaqs2-collection-count-history", inputs: { pageTitle: "pageTitle" }, viewQueries: [{ propertyName: "chart", first: true, predicate: BaseChartDirective, descendants: true }], ngImport: i0, template: "<mat-card appearance=\"outlined\">\n <mat-card-header *ngIf=\"pageTitle\">\n <mat-card-title>\n {{ pageTitle }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n </mat-card-title>\n </mat-card-header>\n <mat-card-content>\n <div style=\"display: flex; gap: 0.5rem; align-items: center\">\n <div style=\"flex: 1 1 auto\"></div>\n <metaqs2-monthpicker *ngIf=\"isHistoryEnabled()\" [inputGroup]=\"range\"></metaqs2-monthpicker>\n <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\">\n <label>Zeige historische Daten</label>\n </mat-slide-toggle>\n </div>\n <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n\n <div [class.while-loading]=\"isLoading()\">\n <canvas\n baseChart\n [datasets]=\"(datapoints$ | async) || []\"\n [options]=\"lineChartOptions\"\n [type]=\"'line'\"\n ></canvas>\n </div>\n </mat-card-content>\n</mat-card>\n", styles: [".while-loading{filter:blur(2px)}\n"], dependencies: [{ kind: "directive", type: BaseChartDirective, selector: "canvas[baseChart]", inputs: ["type", "legend", "data", "options", "plugins", "labels", "datasets"], outputs: ["chartClick", "chartHover"], exportAs: ["base-chart"] }, { kind: "component", type: MonthpickerComponent, selector: "metaqs2-monthpicker", inputs: ["startView", "inputGroup", "disabled"] }, { kind: "component", type: MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "component", type: MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: MatCardContent, selector: "mat-card-content" }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ProgressSpinnerComponent, selector: "metaqs2-progress-spinner", inputs: ["color", "diameter", "strokeWidth", "backdropEnabled", "positionGloballyCenter", "displayProgressSpinner"] }] }); }
|
|
108
|
-
}
|
|
109
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CollectionCountHistoryComponent, decorators: [{
|
|
110
|
-
type: Component,
|
|
111
|
-
args: [{ selector: 'metaqs2-collection-count-history', standalone: true, imports: [
|
|
112
|
-
BaseChartDirective,
|
|
113
|
-
MonthpickerComponent,
|
|
114
|
-
MatCard,
|
|
115
|
-
MatCardHeader,
|
|
116
|
-
MatCardTitle,
|
|
117
|
-
MatCardContent,
|
|
118
|
-
AsyncPipe,
|
|
119
|
-
ReactiveFormsModule,
|
|
120
|
-
NgIf,
|
|
121
|
-
MatSlideToggle,
|
|
122
|
-
FormsModule,
|
|
123
|
-
ProgressSpinnerComponent,
|
|
124
|
-
], template: "<mat-card appearance=\"outlined\">\n <mat-card-header *ngIf=\"pageTitle\">\n <mat-card-title>\n {{ pageTitle }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n </mat-card-title>\n </mat-card-header>\n <mat-card-content>\n <div style=\"display: flex; gap: 0.5rem; align-items: center\">\n <div style=\"flex: 1 1 auto\"></div>\n <metaqs2-monthpicker *ngIf=\"isHistoryEnabled()\" [inputGroup]=\"range\"></metaqs2-monthpicker>\n <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\">\n <label>Zeige historische Daten</label>\n </mat-slide-toggle>\n </div>\n <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n\n <div [class.while-loading]=\"isLoading()\">\n <canvas\n baseChart\n [datasets]=\"(datapoints$ | async) || []\"\n [options]=\"lineChartOptions\"\n [type]=\"'line'\"\n ></canvas>\n </div>\n </mat-card-content>\n</mat-card>\n", styles: [".while-loading{filter:blur(2px)}\n"] }]
|
|
125
|
-
}], ctorParameters: () => [{ type: i1.MetaApiService }, { type: i0.DestroyRef }], propDecorators: { chart: [{
|
|
126
|
-
type: ViewChild,
|
|
127
|
-
args: [BaseChartDirective]
|
|
128
|
-
}], pageTitle: [{
|
|
129
|
-
type: Input
|
|
130
|
-
}] } });
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collection-count-history.component.js","sourceRoot":"","sources":["../../../../../projects/ng-meta-widgets-lib/src/lib/collection-count-history/collection-count-history.component.ts","../../../../../projects/ng-meta-widgets-lib/src/lib/collection-count-history/collection-count-history.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, DestroyRef, effect, Input, OnInit, signal, ViewChild } from '@angular/core';\nimport { ChartConfiguration, ChartDataset } from 'chart.js';\nimport { BaseChartDirective } from 'ng2-charts';\nimport { DateTime, DateTimeUnit } from 'luxon';\nimport { MatCard, MatCardContent, MatCardHeader, MatCardTitle } from '@angular/material/card';\nimport { FormControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MonthpickerComponent } from './monthpicker/monthpicker.component';\nimport { Count, MaterialCountFilter } from '../java-api';\nimport { MetaApiService } from '../meta-api.service';\nimport { BehaviorSubject } from 'rxjs';\nimport { AsyncPipe, NgIf } from '@angular/common';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { distinctUntilChanged, filter, finalize, map, switchMap, take, tap } from 'rxjs/operators';\nimport { MatSlideToggle } from '@angular/material/slide-toggle';\nimport { ProgressSpinnerComponent } from '../components/loading_indicator/progress-spinner/progress-spinner.component';\n\n@Component({\n  selector: 'metaqs2-collection-count-history',\n  standalone: true,\n  imports: [\n    BaseChartDirective,\n    MonthpickerComponent,\n    MatCard,\n    MatCardHeader,\n    MatCardTitle,\n    MatCardContent,\n    AsyncPipe,\n    ReactiveFormsModule,\n    NgIf,\n    MatSlideToggle,\n    FormsModule,\n    ProgressSpinnerComponent,\n  ],\n  templateUrl: './collection-count-history.component.html',\n  styleUrl: './collection-count-history.component.scss',\n})\nexport class CollectionCountHistoryComponent implements OnInit {\n  @ViewChild(BaseChartDirective) chart?: BaseChartDirective;\n  protected lineChartOptions: ChartConfiguration['options'] = {\n    parsing: {\n      xAxisKey: 'date',\n      yAxisKey: 'count',\n    },\n    font: {\n      family: 'Montserrat',\n    },\n    animation: false,\n  };\n  protected datapoints$ = new BehaviorSubject<ChartDataset<'line', Count[]>[]>([]);\n  protected isLoading = signal(true);\n  readonly range: FormGroup<{\n    start: FormControl<DateTime<boolean>>;\n    end: FormControl<DateTime<boolean>>;\n  }> = new FormGroup({\n    start: new FormControl(),\n    end: new FormControl(),\n  });\n  protected granularities: DateTimeUnit[] = ['year', 'month', 'week', 'day'];\n  protected granularity = new FormControl<DateTimeUnit>('month', { nonNullable: true });\n\n  @Input()\n  public pageTitle: string;\n  public readonly isHistoryEnabled = signal(true);\n\n  constructor(private readonly metaApi: MetaApiService, private readonly destroyRef: DestroyRef) {\n    effect(() => {\n      this.range.controls.end.reset();\n      if (!this.isHistoryEnabled()) {\n        this.range.controls.start.setValue(this.range.controls.end.value);\n      } else {\n        this.range.controls.start.reset();\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    this.registerDateRangeFilter();\n  }\n\n  registerDateRangeFilter() {\n    this.range.valueChanges\n      .pipe(\n        filter((range): range is { start: DateTime; end: DateTime } => !!range.start && !!range.end),\n        //the Material Datepicker emits the initial values 4 times when it starts, so we need to distinct them\n        distinctUntilChanged((prev, curr) => {\n          return prev.start === curr.start && prev.end === curr.end;\n        }),\n        switchMap((range) => {\n          if (this.isHistoryEnabled()) {\n            return this.loadData(range.start, range.end);\n          } else {\n            return this.loadData(range.end.startOf(this.granularity.value), range.end);\n          }\n        }),\n        takeUntilDestroyed(this.destroyRef)\n      )\n      .subscribe();\n    this.metaApi\n      .getTimerangeFilter()\n      .pipe(take(1))\n      .subscribe((rangeFilter) => {\n        if (rangeFilter) {\n          const startDate = DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeStart')?.label!, {\n            zone: 'utc',\n          }).startOf(this.granularity.value);\n          const endDate = DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeEnd')?.label!, {\n            zone: 'utc',\n          }).endOf(this.granularity.value);\n          this.range.setControl('start', new FormControl<DateTime>(startDate, { nonNullable: true }), {\n            emitEvent: false,\n          });\n          this.range.setControl('end', new FormControl<DateTime>(endDate, { nonNullable: true }), { emitEvent: false });\n        }\n      });\n  }\n\n  private loadData(start?: DateTime<boolean>, end?: DateTime<boolean>) {\n    this.isLoading.set(true);\n\n    const request: MaterialCountFilter = {\n      startDate: start?.toISO()!,\n      endDate: end?.toISO()!,\n      granularity: this.granularity.value,\n    };\n\n    return this.metaApi.getEditorialMaterialCounts(request).pipe(\n      map((response) =>\n        response.map((data) => {\n          return {\n            data: data.counts.map((count) => {\n              return {\n                date: DateTime.fromISO(count.date).toFormat('LLLL yyyy')!,\n                count: count.count,\n              };\n            }),\n            label: data.name,\n          };\n        })\n      ),\n      take(1),\n      tap((datapoints) => {\n        this.datapoints$.next(datapoints);\n      }),\n      finalize(() => this.isLoading.set(false))\n    );\n  }\n}\n","<mat-card appearance=\"outlined\">\n  <mat-card-header *ngIf=\"pageTitle\">\n    <mat-card-title>\n      {{ pageTitle }}{{ isLoading() ? \": Lade neue Daten.\" : \"\" }}\n    </mat-card-title>\n  </mat-card-header>\n  <mat-card-content>\n    <div style=\"display: flex; gap: 0.5rem; align-items: center\">\n      <div style=\"flex: 1 1 auto\"></div>\n      <metaqs2-monthpicker *ngIf=\"isHistoryEnabled()\" [inputGroup]=\"range\"></metaqs2-monthpicker>\n      <mat-slide-toggle [ngModel]=\"isHistoryEnabled()\" (ngModelChange)=\"isHistoryEnabled.set($event)\" [disabled]=\"isLoading()\">\n        <label>Zeige historische Daten</label>\n      </mat-slide-toggle>\n    </div>\n    <metaqs2-progress-spinner [displayProgressSpinner]=\"isLoading()\"></metaqs2-progress-spinner>\n\n    <div [class.while-loading]=\"isLoading()\">\n      <canvas\n        baseChart\n        [datasets]=\"(datapoints$ | async) || []\"\n        [options]=\"lineChartOptions\"\n        [type]=\"'line'\"\n      ></canvas>\n    </div>\n  </mat-card-content>\n</mat-card>\n"]}
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import { Component, ElementRef, Input, LOCALE_ID, ViewChild } from '@angular/core';
|
|
2
|
-
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
3
|
-
import { MatDatepicker, MatDatepickerInput, MatDatepickerToggle } from '@angular/material/datepicker';
|
|
4
|
-
import { MatFormField, MatLabel, MatSuffix } from '@angular/material/form-field';
|
|
5
|
-
import { MatInput } from '@angular/material/input';
|
|
6
|
-
import { LuxonDateAdapter, MAT_LUXON_DATE_ADAPTER_OPTIONS } from '@angular/material-luxon-adapter';
|
|
7
|
-
import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE, MatRipple } from '@angular/material/core';
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@angular/forms";
|
|
10
|
-
export const datePickerFormats = {
|
|
11
|
-
parse: {
|
|
12
|
-
dateInput: 'LLLL yyyy',
|
|
13
|
-
},
|
|
14
|
-
display: {
|
|
15
|
-
dateInput: 'LLLL yyyy',
|
|
16
|
-
monthYearLabel: 'LLLL yyyy',
|
|
17
|
-
dateA11yLabel: 'LLL',
|
|
18
|
-
monthYearA11yLabel: 'MMMM yyyy',
|
|
19
|
-
},
|
|
20
|
-
};
|
|
21
|
-
/**
|
|
22
|
-
* Theoretically, this component should be able to handle both monthly and daily date ranges.
|
|
23
|
-
* But I am unable to find a way to change the date format of the datepicker
|
|
24
|
-
*/
|
|
25
|
-
export class MonthpickerComponent {
|
|
26
|
-
constructor() {
|
|
27
|
-
this.startView = 'year';
|
|
28
|
-
this.disabled = false;
|
|
29
|
-
}
|
|
30
|
-
setStart(date, picker) {
|
|
31
|
-
this.inputGroup.controls.start.setValue(date);
|
|
32
|
-
picker.close();
|
|
33
|
-
}
|
|
34
|
-
setEnd(date, picker) {
|
|
35
|
-
this.inputGroup.controls.end.setValue(date.endOf('month'));
|
|
36
|
-
picker.close();
|
|
37
|
-
}
|
|
38
|
-
ngOnInit() {
|
|
39
|
-
this.focus();
|
|
40
|
-
}
|
|
41
|
-
ngOnDestroy() {
|
|
42
|
-
//defer this to avoid an ExpressionChangedAfterItHasBeenCheckedError on the parent component
|
|
43
|
-
Promise.resolve().then(() => this.inputGroup.reset());
|
|
44
|
-
}
|
|
45
|
-
focus() {
|
|
46
|
-
this.start?.nativeElement.focus();
|
|
47
|
-
this.ripple.launch({
|
|
48
|
-
centered: true, // Material bug: disabled ripples do not trigger unless centered
|
|
49
|
-
radius: 1000,
|
|
50
|
-
animation: {
|
|
51
|
-
exitDuration: 1000,
|
|
52
|
-
},
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonthpickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
56
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MonthpickerComponent, isStandalone: true, selector: "metaqs2-monthpicker", inputs: { startView: "startView", inputGroup: "inputGroup", disabled: "disabled" }, providers: [
|
|
57
|
-
{
|
|
58
|
-
provide: DateAdapter,
|
|
59
|
-
useClass: LuxonDateAdapter,
|
|
60
|
-
deps: [MAT_DATE_LOCALE, MAT_LUXON_DATE_ADAPTER_OPTIONS],
|
|
61
|
-
},
|
|
62
|
-
{ provide: MAT_DATE_FORMATS, useValue: datePickerFormats },
|
|
63
|
-
//provideLuxonDateAdapter(datePickerFormats),
|
|
64
|
-
{ provide: LOCALE_ID, useValue: 'de-DE' },
|
|
65
|
-
{ provide: MAT_DATE_LOCALE, useValue: 'de-DE' },
|
|
66
|
-
{ provide: MAT_LUXON_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true, firstDayOfWeek: 1 } },
|
|
67
|
-
], viewQueries: [{ propertyName: "start", first: true, predicate: ["start"], descendants: true, read: (ElementRef), static: true }, { propertyName: "ripple", first: true, predicate: ["ripple"], descendants: true, read: MatRipple, static: true }], ngImport: i0, template: "<!--\n<mat-card>\n <mat-card-header>\n <mat-card-title> Monatlicher Vergleich </mat-card-title>\n </mat-card-header>\n <mat-card-content [formGroup]=\"inputGroup\">\n </!-- start date --/>\n -->\n<div [formGroup]=\"inputGroup\" matRipple #ripple=\"matRipple\" [matRippleDisabled]=\"true\">\n <mat-form-field>\n <mat-label>Zeitpunkt 1</mat-label>\n <input matInput\n #start\n [disabled]=\"disabled\"\n [min]=\"inputGroup.controls.start.defaultValue\"\n [max]=\"inputGroup.controls.end.defaultValue\"\n [matDatepicker]=\"picker1\" formControlName=\"start\"\n placeholder=\"Starts date\"\n >\n <mat-datepicker-toggle matIconSuffix [for]=\"picker1\"></mat-datepicker-toggle>\n <mat-datepicker\n [disabled]=\"disabled\"\n #picker1\n [startAt]=\"inputGroup.controls.start.defaultValue\"\n [startView]=\"startView\"\n (monthSelected)=\"setStart($event, picker1)\"\n\n >\n </mat-datepicker>\n </mat-form-field>\n <!-- /start date -->\n <!-- end date -->\n <mat-form-field>\n <mat-label>Zeitpunkt2</mat-label>\n <input matInput\n [disabled]=\"disabled\"\n [min]=\"inputGroup.controls.start.defaultValue\"\n [max]=\"inputGroup.controls.end.defaultValue\"\n [matDatepicker]=\"picker2\"\n formControlName=\"end\"\n placeholder=\"End date\"\n >\n <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n <mat-datepicker\n [disabled]=\"disabled\"\n #picker2\n [startAt]=\"inputGroup.controls.end.value\"\n [startView]=\"startView\"\n (monthSelected)=\"setEnd($event, picker2)\"\n >\n </mat-datepicker>\n </mat-form-field>\n <!-- /end date -->\n</div>\n<!--\n </mat-card-content>\n</mat-card>\n-->\n", styles: [""], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "directive", type: MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }] }); }
|
|
68
|
-
}
|
|
69
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonthpickerComponent, decorators: [{
|
|
70
|
-
type: Component,
|
|
71
|
-
args: [{ selector: 'metaqs2-monthpicker', standalone: true, imports: [
|
|
72
|
-
FormsModule,
|
|
73
|
-
MatDatepicker,
|
|
74
|
-
MatDatepickerInput,
|
|
75
|
-
MatDatepickerToggle,
|
|
76
|
-
MatFormField,
|
|
77
|
-
MatInput,
|
|
78
|
-
MatLabel,
|
|
79
|
-
MatSuffix,
|
|
80
|
-
ReactiveFormsModule,
|
|
81
|
-
MatRipple,
|
|
82
|
-
], providers: [
|
|
83
|
-
{
|
|
84
|
-
provide: DateAdapter,
|
|
85
|
-
useClass: LuxonDateAdapter,
|
|
86
|
-
deps: [MAT_DATE_LOCALE, MAT_LUXON_DATE_ADAPTER_OPTIONS],
|
|
87
|
-
},
|
|
88
|
-
{ provide: MAT_DATE_FORMATS, useValue: datePickerFormats },
|
|
89
|
-
//provideLuxonDateAdapter(datePickerFormats),
|
|
90
|
-
{ provide: LOCALE_ID, useValue: 'de-DE' },
|
|
91
|
-
{ provide: MAT_DATE_LOCALE, useValue: 'de-DE' },
|
|
92
|
-
{ provide: MAT_LUXON_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true, firstDayOfWeek: 1 } },
|
|
93
|
-
], template: "<!--\n<mat-card>\n <mat-card-header>\n <mat-card-title> Monatlicher Vergleich </mat-card-title>\n </mat-card-header>\n <mat-card-content [formGroup]=\"inputGroup\">\n </!-- start date --/>\n -->\n<div [formGroup]=\"inputGroup\" matRipple #ripple=\"matRipple\" [matRippleDisabled]=\"true\">\n <mat-form-field>\n <mat-label>Zeitpunkt 1</mat-label>\n <input matInput\n #start\n [disabled]=\"disabled\"\n [min]=\"inputGroup.controls.start.defaultValue\"\n [max]=\"inputGroup.controls.end.defaultValue\"\n [matDatepicker]=\"picker1\" formControlName=\"start\"\n placeholder=\"Starts date\"\n >\n <mat-datepicker-toggle matIconSuffix [for]=\"picker1\"></mat-datepicker-toggle>\n <mat-datepicker\n [disabled]=\"disabled\"\n #picker1\n [startAt]=\"inputGroup.controls.start.defaultValue\"\n [startView]=\"startView\"\n (monthSelected)=\"setStart($event, picker1)\"\n\n >\n </mat-datepicker>\n </mat-form-field>\n <!-- /start date -->\n <!-- end date -->\n <mat-form-field>\n <mat-label>Zeitpunkt2</mat-label>\n <input matInput\n [disabled]=\"disabled\"\n [min]=\"inputGroup.controls.start.defaultValue\"\n [max]=\"inputGroup.controls.end.defaultValue\"\n [matDatepicker]=\"picker2\"\n formControlName=\"end\"\n placeholder=\"End date\"\n >\n <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n <mat-datepicker\n [disabled]=\"disabled\"\n #picker2\n [startAt]=\"inputGroup.controls.end.value\"\n [startView]=\"startView\"\n (monthSelected)=\"setEnd($event, picker2)\"\n >\n </mat-datepicker>\n </mat-form-field>\n <!-- /end date -->\n</div>\n<!--\n </mat-card-content>\n</mat-card>\n-->\n" }]
|
|
94
|
-
}], propDecorators: { startView: [{
|
|
95
|
-
type: Input
|
|
96
|
-
}], inputGroup: [{
|
|
97
|
-
type: Input,
|
|
98
|
-
args: [{ required: true }]
|
|
99
|
-
}], disabled: [{
|
|
100
|
-
type: Input
|
|
101
|
-
}], start: [{
|
|
102
|
-
type: ViewChild,
|
|
103
|
-
args: ['start', {
|
|
104
|
-
read: (ElementRef),
|
|
105
|
-
static: true,
|
|
106
|
-
}]
|
|
107
|
-
}], ripple: [{
|
|
108
|
-
type: ViewChild,
|
|
109
|
-
args: ['ripple', {
|
|
110
|
-
read: MatRipple,
|
|
111
|
-
static: true,
|
|
112
|
-
}]
|
|
113
|
-
}] } });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monthpicker.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-meta-widgets-lib/src/lib/collection-count-history/monthpicker/monthpicker.component.ts","../../../../../../projects/ng-meta-widgets-lib/src/lib/collection-count-history/monthpicker/monthpicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, LOCALE_ID, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { FormControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatDatepicker, MatDatepickerInput, MatDatepickerToggle } from '@angular/material/datepicker';\nimport { MatFormField, MatLabel, MatSuffix } from '@angular/material/form-field';\nimport { MatInput } from '@angular/material/input';\nimport { DateTime } from 'luxon';\nimport { LuxonDateAdapter, MAT_LUXON_DATE_ADAPTER_OPTIONS } from '@angular/material-luxon-adapter';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE, MatDateFormats, MatRipple } from '@angular/material/core';\n\nexport const datePickerFormats: MatDateFormats = {\n  parse: {\n    dateInput: 'LLLL yyyy',\n  },\n  display: {\n    dateInput: 'LLLL yyyy',\n    monthYearLabel: 'LLLL yyyy',\n    dateA11yLabel: 'LLL',\n    monthYearA11yLabel: 'MMMM yyyy',\n  },\n};\n\n@Component({\n  selector: 'metaqs2-monthpicker',\n  standalone: true,\n  imports: [\n    FormsModule,\n    MatDatepicker,\n    MatDatepickerInput,\n    MatDatepickerToggle,\n    MatFormField,\n    MatInput,\n    MatLabel,\n    MatSuffix,\n    ReactiveFormsModule,\n    MatRipple,\n  ],\n  providers: [\n    {\n      provide: DateAdapter,\n      useClass: LuxonDateAdapter,\n      deps: [MAT_DATE_LOCALE, MAT_LUXON_DATE_ADAPTER_OPTIONS],\n    },\n    { provide: MAT_DATE_FORMATS, useValue: datePickerFormats },\n    //provideLuxonDateAdapter(datePickerFormats),\n    { provide: LOCALE_ID, useValue: 'de-DE' },\n    { provide: MAT_DATE_LOCALE, useValue: 'de-DE' },\n    { provide: MAT_LUXON_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true, firstDayOfWeek: 1 } },\n  ],\n  templateUrl: './monthpicker.component.html',\n  styleUrl: './monthpicker.component.css',\n})\n/**\n * Theoretically, this component should be able to handle both monthly and daily date ranges.\n * But I am unable to find a way to change the date format of the datepicker\n */\nexport class MonthpickerComponent implements OnInit, OnDestroy {\n  @Input()\n  startView: 'month' | 'year' | 'multi-year' = 'year';\n  @Input({ required: true })\n  inputGroup: FormGroup<{ start: FormControl<DateTime<boolean>>; end: FormControl<DateTime<boolean>> }>;\n  @Input()\n  disabled: boolean = false;\n\n  @ViewChild('start', {\n    read: ElementRef<HTMLInputElement>,\n    static: true,\n  })\n  protected start!: ElementRef<HTMLInputElement>;\n\n  @ViewChild('ripple', {\n    read: MatRipple,\n    static: true,\n  })\n  protected readonly ripple!: MatRipple;\n\n\n  protected setStart(date: DateTime<boolean>, picker: MatDatepicker<DateTime<boolean>>): void {\n    this.inputGroup.controls.start.setValue(date);\n    picker.close();\n  }\n\n  protected setEnd(date: DateTime<boolean>, picker: MatDatepicker<DateTime<boolean>>): void {\n    this.inputGroup.controls.end.setValue(date.endOf('month'));\n    picker.close();\n  }\n\n  ngOnInit() {\n    this.focus();\n  }\n\n  ngOnDestroy(): void {\n    //defer this to avoid an ExpressionChangedAfterItHasBeenCheckedError on the parent component\n    Promise.resolve().then(() => this.inputGroup.reset());\n  }\n\n  focus() {\n    this.start?.nativeElement.focus();\n    this.ripple.launch({\n      centered: true, // Material bug: disabled ripples do not trigger unless centered\n      radius: 1000,\n      animation: {\n        exitDuration: 1000,\n      },\n    });\n  }\n}\n","<!--\n<mat-card>\n  <mat-card-header>\n    <mat-card-title> Monatlicher Vergleich </mat-card-title>\n  </mat-card-header>\n  <mat-card-content [formGroup]=\"inputGroup\">\n    </!-- start date --/>\n    -->\n<div [formGroup]=\"inputGroup\" matRipple #ripple=\"matRipple\" [matRippleDisabled]=\"true\">\n    <mat-form-field>\n      <mat-label>Zeitpunkt 1</mat-label>\n      <input matInput\n             #start\n             [disabled]=\"disabled\"\n             [min]=\"inputGroup.controls.start.defaultValue\"\n             [max]=\"inputGroup.controls.end.defaultValue\"\n             [matDatepicker]=\"picker1\" formControlName=\"start\"\n             placeholder=\"Starts date\"\n      >\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker1\"></mat-datepicker-toggle>\n      <mat-datepicker\n        [disabled]=\"disabled\"\n        #picker1\n        [startAt]=\"inputGroup.controls.start.defaultValue\"\n        [startView]=\"startView\"\n        (monthSelected)=\"setStart($event, picker1)\"\n\n      >\n      </mat-datepicker>\n    </mat-form-field>\n    <!-- /start date -->\n    <!-- end date -->\n    <mat-form-field>\n      <mat-label>Zeitpunkt2</mat-label>\n      <input matInput\n             [disabled]=\"disabled\"\n             [min]=\"inputGroup.controls.start.defaultValue\"\n             [max]=\"inputGroup.controls.end.defaultValue\"\n             [matDatepicker]=\"picker2\"\n             formControlName=\"end\"\n             placeholder=\"End date\"\n      >\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n      <mat-datepicker\n        [disabled]=\"disabled\"\n        #picker2\n        [startAt]=\"inputGroup.controls.end.value\"\n        [startView]=\"startView\"\n        (monthSelected)=\"setEnd($event, picker2)\"\n      >\n      </mat-datepicker>\n    </mat-form-field>\n    <!-- /end date -->\n</div>\n<!--\n  </mat-card-content>\n</mat-card>\n-->\n"]}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "../../java-api";
|
|
4
|
-
import * as i2 from "@angular/common";
|
|
5
|
-
import * as i3 from "../node-list/node-list.component";
|
|
6
|
-
export class CollectionIssuesComponent {
|
|
7
|
-
constructor(filterAPIService) {
|
|
8
|
-
this.filterAPIService = filterAPIService;
|
|
9
|
-
this.issues = [];
|
|
10
|
-
// @TODO: Input is broken, maybe cause of withComponentInputBinding()?!
|
|
11
|
-
this.collectionId = '94f22c9b-0d3a-4c1c-8987-4c8e83f3a92e';
|
|
12
|
-
}
|
|
13
|
-
async ngOnInit() {
|
|
14
|
-
this.issues = await this.filterAPIService.getCollectionIssueFieldNames().toPromise();
|
|
15
|
-
}
|
|
16
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CollectionIssuesComponent, deps: [{ token: i1.FilterAPIService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
17
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CollectionIssuesComponent, selector: "metaqs2-collection-issues", ngImport: i0, template: "<metaqs2-node-list\n *ngFor=\"let mode of issues\"\n [collectionId]=\"collectionId\"\n [mode]=\"mode\"\n type=\"collection\"\n></metaqs2-node-list>\n", styles: [".while-loading{filter:blur(2px)}:host{padding:0 30px;display:flex;gap:30px;flex-wrap:wrap}:host>metaqs2-node-list{width:400px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.NodeListComponent, selector: "metaqs2-node-list", inputs: ["mode", "type", "collectionId"], outputs: ["countChanged"] }] }); }
|
|
18
|
-
}
|
|
19
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CollectionIssuesComponent, decorators: [{
|
|
20
|
-
type: Component,
|
|
21
|
-
args: [{ selector: 'metaqs2-collection-issues', template: "<metaqs2-node-list\n *ngFor=\"let mode of issues\"\n [collectionId]=\"collectionId\"\n [mode]=\"mode\"\n type=\"collection\"\n></metaqs2-node-list>\n", styles: [".while-loading{filter:blur(2px)}:host{padding:0 30px;display:flex;gap:30px;flex-wrap:wrap}:host>metaqs2-node-list{width:400px}\n"] }]
|
|
22
|
-
}], ctorParameters: () => [{ type: i1.FilterAPIService }] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi1pc3N1ZXMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctbWV0YS13aWRnZXRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvY29sbGVjdGlvbi1pc3N1ZXMvY29sbGVjdGlvbi1pc3N1ZXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctbWV0YS13aWRnZXRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvY29sbGVjdGlvbi1pc3N1ZXMvY29sbGVjdGlvbi1pc3N1ZXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRbEQsTUFBTSxPQUFPLHlCQUF5QjtJQUtwQyxZQUFvQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUp0RCxXQUFNLEdBQWEsRUFBRSxDQUFDO1FBQ3RCLHVFQUF1RTtRQUN2RSxpQkFBWSxHQUFXLHNDQUFzQyxDQUFDO0lBRUwsQ0FBQztJQUUxRCxLQUFLLENBQUMsUUFBUTtRQUNaLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsNEJBQTRCLEVBQUUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUN2RixDQUFDOytHQVRVLHlCQUF5QjttR0FBekIseUJBQXlCLGlFQ1J0QywySkFNQTs7NEZERWEseUJBQXlCO2tCQUxyQyxTQUFTOytCQUNFLDJCQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWx0ZXJBUElTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vamF2YS1hcGknO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtZXRhcXMyLWNvbGxlY3Rpb24taXNzdWVzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NvbGxlY3Rpb24taXNzdWVzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY29sbGVjdGlvbi1pc3N1ZXMuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ29sbGVjdGlvbklzc3Vlc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIGlzc3Vlczogc3RyaW5nW10gPSBbXTtcbiAgLy8gQFRPRE86IElucHV0IGlzIGJyb2tlbiwgbWF5YmUgY2F1c2Ugb2Ygd2l0aENvbXBvbmVudElucHV0QmluZGluZygpPyFcbiAgY29sbGVjdGlvbklkOiBzdHJpbmcgPSAnOTRmMjJjOWItMGQzYS00YzFjLTg5ODctNGM4ZTgzZjNhOTJlJztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGZpbHRlckFQSVNlcnZpY2U6IEZpbHRlckFQSVNlcnZpY2UpIHt9XG5cbiAgYXN5bmMgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5pc3N1ZXMgPSBhd2FpdCB0aGlzLmZpbHRlckFQSVNlcnZpY2UuZ2V0Q29sbGVjdGlvbklzc3VlRmllbGROYW1lcygpLnRvUHJvbWlzZSgpO1xuICB9XG59XG4iLCI8bWV0YXFzMi1ub2RlLWxpc3RcbiAgKm5nRm9yPVwibGV0IG1vZGUgb2YgaXNzdWVzXCJcbiAgW2NvbGxlY3Rpb25JZF09XCJjb2xsZWN0aW9uSWRcIlxuICBbbW9kZV09XCJtb2RlXCJcbiAgdHlwZT1cImNvbGxlY3Rpb25cIlxuPjwvbWV0YXFzMi1ub2RlLWxpc3Q+XG4iXX0=
|