ngx-edu-sharing-metaqs2 0.9.31 → 0.9.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/collection-count-history/collection-count-history.component.mjs +48 -32
- package/esm2022/lib/collection-count-history/monthpicker/monthpicker.component.mjs +7 -4
- package/esm2022/lib/components/collection-issues/collection-issues.component.mjs +2 -2
- package/esm2022/lib/components/donut-chart/donut-chart.component.mjs +9 -9
- package/esm2022/lib/components/filter/datepicker/datepicker.component.mjs +3 -3
- package/esm2022/lib/components/loading_indicator/overlay/overlay.service.mjs +41 -0
- package/esm2022/lib/components/loading_indicator/progress-spinner/progress-spinner.component.mjs +65 -0
- package/esm2022/lib/components/material-issues/material-issues.component.mjs +2 -2
- package/esm2022/lib/components/node-entry/node-entry.component.mjs +2 -2
- package/esm2022/lib/components/node-list/node-list.component.mjs +2 -2
- package/esm2022/lib/components/quality-matrix/quality_matrix.mjs +6 -5
- package/esm2022/lib/counts-with-history/counts-with-history.component.mjs +89 -84
- package/esm2022/lib/ng-meta-widgets-lib.module.mjs +8 -4
- package/esm2022/lib/tree-collection-details/tree-collection-details.component.mjs +17 -3
- package/esm2022/lib/tree-search-counts/tree-search-counts.component.mjs +5 -3
- package/esm2022/public-api.mjs +1 -2
- package/fesm2022/ngx-edu-sharing-metaqs2.mjs +277 -277
- package/fesm2022/ngx-edu-sharing-metaqs2.mjs.map +1 -1
- package/lib/collection-count-history/collection-count-history.component.d.ts +1 -0
- package/lib/collection-count-history/monthpicker/monthpicker.component.d.ts +2 -1
- package/lib/components/loading_indicator/overlay/overlay.service.d.ts +13 -0
- package/lib/components/loading_indicator/progress-spinner/progress-spinner.component.d.ts +21 -0
- package/lib/counts-with-history/counts-with-history.component.d.ts +27 -25
- package/lib/ng-meta-widgets-lib.module.d.ts +2 -1
- package/package.json +1 -1
- package/public-api.d.ts +0 -1
- package/esm2022/lib/materialtypes-by-sources/materialtypes-by-sources.component.mjs +0 -148
- package/lib/materialtypes-by-sources/materialtypes-by-sources.component.d.ts +0 -43
|
@@ -21,6 +21,7 @@ export declare class CollectionCountHistoryComponent implements OnInit {
|
|
|
21
21
|
protected granularities: DateTimeUnit[];
|
|
22
22
|
protected granularity: FormControl<DateTimeUnit>;
|
|
23
23
|
pageTitle: string;
|
|
24
|
+
isHistoryEnabled: import("@angular/core").WritableSignal<boolean>;
|
|
24
25
|
constructor(metaApi: MetaApiService, destroyRef: DestroyRef);
|
|
25
26
|
ngOnInit(): void;
|
|
26
27
|
registerDateRangeFilter(): void;
|
|
@@ -11,10 +11,11 @@ export declare class MonthpickerComponent implements OnDestroy {
|
|
|
11
11
|
start: FormControl<DateTime<boolean>>;
|
|
12
12
|
end: FormControl<DateTime<boolean>>;
|
|
13
13
|
}>;
|
|
14
|
+
disabled: boolean;
|
|
14
15
|
constructor();
|
|
15
16
|
protected setStart(date: DateTime<boolean>, picker: MatDatepicker<DateTime<boolean>>): void;
|
|
16
17
|
protected setEnd(date: DateTime<boolean>, picker: MatDatepicker<DateTime<boolean>>): void;
|
|
17
18
|
ngOnDestroy(): void;
|
|
18
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<MonthpickerComponent, never>;
|
|
19
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<MonthpickerComponent, "metaqs2-monthpicker", never, { "startView": { "alias": "startView"; "required": false; }; "inputGroup": { "alias": "inputGroup"; "required": true; }; }, {}, never, never, true, never>;
|
|
20
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MonthpickerComponent, "metaqs2-monthpicker", never, { "startView": { "alias": "startView"; "required": false; }; "inputGroup": { "alias": "inputGroup"; "required": true; }; "disabled": { "alias": "disabled"; "required": false; }; }, {}, never, never, true, never>;
|
|
20
21
|
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ElementRef, TemplateRef, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { Overlay, OverlayConfig, OverlayRef, PositionStrategy } from '@angular/cdk/overlay';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class OverlayService {
|
|
5
|
+
private overlay;
|
|
6
|
+
constructor(overlay: Overlay);
|
|
7
|
+
createOverlay(config: OverlayConfig): OverlayRef;
|
|
8
|
+
attachTemplatePortal(overlayRef: OverlayRef, templateRef: TemplateRef<any>, vcRef: ViewContainerRef): void;
|
|
9
|
+
positionGloballyCenter(): PositionStrategy;
|
|
10
|
+
positionFlexibleConnected(parent: Element | ElementRef): PositionStrategy;
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<OverlayService, never>;
|
|
12
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<OverlayService>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ViewContainerRef, OnChanges, SimpleChanges, ElementRef } from '@angular/core';
|
|
2
|
+
import { OverlayService } from '../overlay/overlay.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class ProgressSpinnerComponent implements OnChanges {
|
|
5
|
+
private vcRef;
|
|
6
|
+
private overlayService;
|
|
7
|
+
private el;
|
|
8
|
+
color?: string;
|
|
9
|
+
diameter?: number;
|
|
10
|
+
strokeWidth?: number;
|
|
11
|
+
backdropEnabled: boolean;
|
|
12
|
+
positionGloballyCenter: boolean;
|
|
13
|
+
displayProgressSpinner: boolean;
|
|
14
|
+
private progressSpinnerRef;
|
|
15
|
+
private progressSpinnerOverlayConfig;
|
|
16
|
+
private overlayRef;
|
|
17
|
+
constructor(vcRef: ViewContainerRef, overlayService: OverlayService, el: ElementRef);
|
|
18
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
19
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ProgressSpinnerComponent, never>;
|
|
20
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ProgressSpinnerComponent, "metaqs2-progress-spinner", never, { "color": { "alias": "color"; "required": false; }; "diameter": { "alias": "diameter"; "required": false; }; "strokeWidth": { "alias": "strokeWidth"; "required": false; }; "backdropEnabled": { "alias": "backdropEnabled"; "required": false; }; "positionGloballyCenter": { "alias": "positionGloballyCenter"; "required": false; }; "displayProgressSpinner": { "alias": "displayProgressSpinner"; "required": false; }; }, {}, never, never, true, never>;
|
|
21
|
+
}
|
|
@@ -1,21 +1,26 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { DestroyRef, OnInit } from '@angular/core';
|
|
2
2
|
import { BehaviorSubject, Observable } from 'rxjs';
|
|
3
3
|
import { MetaApiService } from '../meta-api.service';
|
|
4
|
-
import { MatrixRowWithCounts, MatrixWithCounts, QualityMatrixHeader } from '../java-api';
|
|
4
|
+
import { Filter, MatrixRowWithCounts, MatrixWithCounts, QualityMatrixHeader } from '../java-api';
|
|
5
5
|
import { DateTime } from 'luxon';
|
|
6
6
|
import { FormControl, FormGroup } from '@angular/forms';
|
|
7
7
|
import { EditorialLinkService } from '../components/editorial-link-service/editorial-link.service';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
type PickKeysByPropertyType<TObject extends object, TPropertyType> = {
|
|
10
|
+
[TKey in keyof TObject]: TObject[TKey] extends TPropertyType ? TKey : never;
|
|
11
|
+
}[keyof TObject];
|
|
12
|
+
export declare class CountsWithHistoryComponent implements OnInit {
|
|
13
|
+
protected readonly metaApi: MetaApiService;
|
|
14
|
+
protected readonly destroyRef: DestroyRef;
|
|
11
15
|
private readonly linkService;
|
|
12
|
-
protected readonly
|
|
16
|
+
protected readonly loadingCount: import("@angular/core").WritableSignal<number>;
|
|
17
|
+
protected readonly isLoading: import("@angular/core").Signal<boolean>;
|
|
13
18
|
protected readonly timeFilterLoaded: import("@angular/core").WritableSignal<boolean>;
|
|
14
|
-
private readonly destroyed$;
|
|
15
19
|
protected readonly recentTypeCount$: BehaviorSubject<MatrixWithCounts>;
|
|
16
20
|
protected readonly pastTypeCount$: BehaviorSubject<MatrixWithCounts>;
|
|
17
|
-
|
|
18
|
-
|
|
21
|
+
protected readonly DateTime: typeof DateTime;
|
|
22
|
+
columns: import("@angular/core").WritableSignal<QualityMatrixHeader[]>;
|
|
23
|
+
apiMethod: PickKeysByPropertyType<MetaApiService, (it: Array<Filter>) => Observable<MatrixWithCounts>>;
|
|
19
24
|
columnTranslationkey: string | null;
|
|
20
25
|
pageTitle: string;
|
|
21
26
|
sourceType: 'replicationSource' | 'collection';
|
|
@@ -23,28 +28,25 @@ export declare class CountsWithHistoryComponent implements OnInit, OnDestroy {
|
|
|
23
28
|
start: FormControl<DateTime<boolean>>;
|
|
24
29
|
end: FormControl<DateTime<boolean>>;
|
|
25
30
|
}>;
|
|
26
|
-
|
|
31
|
+
readonly isHistoryEnabled: import("@angular/core").WritableSignal<boolean>;
|
|
32
|
+
readonly allColumns: import("@angular/core").Signal<string[]>;
|
|
33
|
+
readonly typeColumns: import("@angular/core").Signal<string[]>;
|
|
34
|
+
readonly recentColumns: import("@angular/core").Signal<string[]>;
|
|
35
|
+
readonly pastColumns: import("@angular/core").Signal<string[]>;
|
|
36
|
+
constructor(metaApi: MetaApiService, destroyRef: DestroyRef, linkService: EditorialLinkService);
|
|
37
|
+
ngOnInit(): void;
|
|
38
|
+
private getStartDateOfRange;
|
|
27
39
|
columnIdent(_index: number, col: QualityMatrixHeader): string;
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
get pastColumns(): string[];
|
|
31
|
-
get allColumns(): string[];
|
|
32
|
-
private registerDateRangeFilter;
|
|
33
|
-
private getTimeRangeFilter;
|
|
40
|
+
private getAvailableDateRange;
|
|
41
|
+
private getValuesInDateRange;
|
|
34
42
|
private getCountByDate;
|
|
35
43
|
protected pastTypeCount(row: MatrixRowWithCounts, columnid: string): {
|
|
36
|
-
delta?:
|
|
37
|
-
trend?:
|
|
38
|
-
value?:
|
|
39
|
-
} | {
|
|
40
|
-
delta: number;
|
|
41
|
-
trend: string;
|
|
42
|
-
value: number;
|
|
44
|
+
delta?: number;
|
|
45
|
+
trend?: string;
|
|
46
|
+
value?: number;
|
|
43
47
|
};
|
|
44
48
|
protected openInEditor(sourceId: string, issueId: string): Observable<string | null>;
|
|
45
|
-
ngOnInit(): void;
|
|
46
|
-
protected readonly DateTime: typeof DateTime;
|
|
47
|
-
ngOnDestroy(): void;
|
|
48
49
|
static ɵfac: i0.ɵɵFactoryDeclaration<CountsWithHistoryComponent, never>;
|
|
49
50
|
static ɵcmp: i0.ɵɵComponentDeclaration<CountsWithHistoryComponent, "metaqs2-counts-with-history", never, { "apiMethod": { "alias": "apiMethod"; "required": true; }; "columnTranslationkey": { "alias": "columnTranslationkey"; "required": false; }; "pageTitle": { "alias": "pageTitle"; "required": false; }; "sourceType": { "alias": "sourceType"; "required": true; }; }, {}, never, never, true, never>;
|
|
50
51
|
}
|
|
52
|
+
export {};
|
|
@@ -36,11 +36,12 @@ import * as i31 from "@ngx-translate/core";
|
|
|
36
36
|
import * as i32 from "./components/filter/quality-matrix-filter.component";
|
|
37
37
|
import * as i33 from "@angular/material/datepicker";
|
|
38
38
|
import * as i34 from "./components/filter/datepicker/datepicker.component";
|
|
39
|
+
import * as i35 from "./components/loading_indicator/progress-spinner/progress-spinner.component";
|
|
39
40
|
export declare class NgMetaWidgetsLibModule {
|
|
40
41
|
private readonly svgIconsService;
|
|
41
42
|
constructor(svgIconsService: SvgIconsService);
|
|
42
43
|
static forRoot(params: NgMetaWidgetsLibConfiguration): ModuleWithProviders<NgMetaWidgetsLibModule>;
|
|
43
44
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgMetaWidgetsLibModule, never>;
|
|
44
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<NgMetaWidgetsLibModule, [typeof i1.WrapObservablePipe, typeof i2.QualityMatrixComponent, typeof i3.DonutChartComponent, typeof i4.DonutChartPipe, typeof i5.CollectionIssuesComponent, typeof i6.MaterialIssuesComponent, typeof i7.NodeEntryComponent, typeof i8.NodeListComponent, typeof i9.NodeImageUrlPipe], [typeof i10.BrowserModule, typeof i11.ApiModule, typeof i12.MatCardModule, typeof i13.MatTreeModule, typeof i14.BrowserAnimationsModule, typeof i15.MatIconModule, typeof i16.MatSliderModule, typeof i17.MatSlideToggleModule, typeof i18.MatButtonModule, typeof i19.MatProgressSpinnerModule, typeof i20.MatTableModule, typeof i21.MatGridListModule, typeof i22.MatFormFieldModule, typeof i23.MatInputModule, typeof i24.MatSidenavModule, typeof i25.FormsModule, typeof i26.MatSelectModule, typeof i25.ReactiveFormsModule, typeof i27.MatTooltipModule, typeof i28.MatListModule, typeof i29.MatSort, typeof i29.MatSortModule, typeof i30.MatCheckbox, typeof i31.TranslateModule, typeof i32.QualityMatrixFilterComponent, typeof i33.MatDateRangeInput, typeof i33.MatDatepickerToggle, typeof i33.MatDatepickerModule, typeof i33.MatDateRangePicker, typeof i33.MatDatepickerInput, typeof i33.MatDatepicker, typeof i34.DatepickerComponent], [typeof i5.CollectionIssuesComponent, typeof i6.MaterialIssuesComponent, typeof i8.NodeListComponent]>;
|
|
45
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NgMetaWidgetsLibModule, [typeof i1.WrapObservablePipe, typeof i2.QualityMatrixComponent, typeof i3.DonutChartComponent, typeof i4.DonutChartPipe, typeof i5.CollectionIssuesComponent, typeof i6.MaterialIssuesComponent, typeof i7.NodeEntryComponent, typeof i8.NodeListComponent, typeof i9.NodeImageUrlPipe], [typeof i10.BrowserModule, typeof i11.ApiModule, typeof i12.MatCardModule, typeof i13.MatTreeModule, typeof i14.BrowserAnimationsModule, typeof i15.MatIconModule, typeof i16.MatSliderModule, typeof i17.MatSlideToggleModule, typeof i18.MatButtonModule, typeof i19.MatProgressSpinnerModule, typeof i20.MatTableModule, typeof i21.MatGridListModule, typeof i22.MatFormFieldModule, typeof i23.MatInputModule, typeof i24.MatSidenavModule, typeof i25.FormsModule, typeof i26.MatSelectModule, typeof i25.ReactiveFormsModule, typeof i27.MatTooltipModule, typeof i28.MatListModule, typeof i29.MatSort, typeof i29.MatSortModule, typeof i30.MatCheckbox, typeof i31.TranslateModule, typeof i32.QualityMatrixFilterComponent, typeof i33.MatDateRangeInput, typeof i33.MatDatepickerToggle, typeof i33.MatDatepickerModule, typeof i33.MatDateRangePicker, typeof i33.MatDatepickerInput, typeof i33.MatDatepicker, typeof i34.DatepickerComponent, typeof i35.ProgressSpinnerComponent], [typeof i5.CollectionIssuesComponent, typeof i6.MaterialIssuesComponent, typeof i8.NodeListComponent, typeof i2.QualityMatrixComponent]>;
|
|
45
46
|
static ɵinj: i0.ɵɵInjectorDeclaration<NgMetaWidgetsLibModule>;
|
|
46
47
|
}
|
package/package.json
CHANGED
package/public-api.d.ts
CHANGED
|
@@ -7,5 +7,4 @@ export * from './lib/components/node-list/node-list.component';
|
|
|
7
7
|
export * from './lib/components/collection-issues/collection-issues.component';
|
|
8
8
|
export * from './lib/components/material-issues/material-issues.component';
|
|
9
9
|
export * from './lib/collection-count-history/collection-count-history.component';
|
|
10
|
-
export * from './lib/materialtypes-by-sources/materialtypes-by-sources.component';
|
|
11
10
|
export * from './lib/counts-with-history/counts-with-history.component';
|
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
import { Component, signal } from '@angular/core';
|
|
2
|
-
import { MatCard, MatCardActions, MatCardContent, MatCardHeader, MatCardModule, MatCardTitle, } from '@angular/material/card';
|
|
3
|
-
import { MatTooltip } from '@angular/material/tooltip';
|
|
4
|
-
import { MatHeaderRow, MatHeaderRowDef, MatRow, MatRowDef, MatTable, MatTableModule } from '@angular/material/table';
|
|
5
|
-
import { BehaviorSubject, Subject } from 'rxjs';
|
|
6
|
-
import { TranslateModule } from '@ngx-translate/core';
|
|
7
|
-
import { NgClass, NgForOf, NgIf } from '@angular/common';
|
|
8
|
-
import { DateTime } from 'luxon';
|
|
9
|
-
import { finalize, takeUntil, tap } from 'rxjs/operators';
|
|
10
|
-
import { FormControl, FormGroup } from '@angular/forms';
|
|
11
|
-
import { DatepickerComponent } from '../components/filter/datepicker/datepicker.component';
|
|
12
|
-
import { MatIcon } from '@angular/material/icon';
|
|
13
|
-
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "../meta-api.service";
|
|
15
|
-
import * as i2 from "@angular/material/card";
|
|
16
|
-
import * as i3 from "@angular/material/table";
|
|
17
|
-
export class MaterialtypesBySourcesComponent {
|
|
18
|
-
constructor(metaApi) {
|
|
19
|
-
this.metaApi = metaApi;
|
|
20
|
-
this.isLoading = signal(true);
|
|
21
|
-
this.timeFilterLoaded = signal(false);
|
|
22
|
-
this.destroyed$ = new Subject();
|
|
23
|
-
this.recentTypeCount$ = new BehaviorSubject({ columns: [], rows: [] });
|
|
24
|
-
this.pastTypeCount$ = new BehaviorSubject({ columns: [], rows: [] });
|
|
25
|
-
this.columns = [];
|
|
26
|
-
/* In this widget's backend we do have data for today
|
|
27
|
-
* therefore we set the end date to today and use the timerange() endpoint to only set the start date
|
|
28
|
-
*/
|
|
29
|
-
this.range = new FormGroup({
|
|
30
|
-
start: new FormControl(),
|
|
31
|
-
end: new FormControl(DateTime.utc().startOf('day'), { nonNullable: true }),
|
|
32
|
-
});
|
|
33
|
-
this.DateTime = DateTime;
|
|
34
|
-
}
|
|
35
|
-
columnIdent(_index, col) {
|
|
36
|
-
return col.id;
|
|
37
|
-
}
|
|
38
|
-
get typeColumns() {
|
|
39
|
-
return this.columns.map((c) => c.id + '_type');
|
|
40
|
-
}
|
|
41
|
-
get recentColumns() {
|
|
42
|
-
return this.columns.map((c) => c.id + '_recent');
|
|
43
|
-
}
|
|
44
|
-
get pastColumns() {
|
|
45
|
-
return this.columns.map((c) => c.id + '_past');
|
|
46
|
-
}
|
|
47
|
-
get allColumns() {
|
|
48
|
-
//return this.recentColumns;
|
|
49
|
-
return this.pastColumns.flatMap((e, i) => [e, this.recentColumns[i]]);
|
|
50
|
-
}
|
|
51
|
-
pastTypeCount(row, columnid) {
|
|
52
|
-
if (!this.pastTypeCount$.value.rows.length) {
|
|
53
|
-
return {};
|
|
54
|
-
}
|
|
55
|
-
const past_row = this.pastTypeCount$.value.rows.find((pr) => pr.meta.id == row.meta.id);
|
|
56
|
-
const past_column = this.pastTypeCount$.value.columns.find((c) => c.id == columnid);
|
|
57
|
-
if (!past_row || !past_column) {
|
|
58
|
-
return {};
|
|
59
|
-
}
|
|
60
|
-
const currentValue = row.counts[columnid];
|
|
61
|
-
const pastValue = past_row.counts[columnid];
|
|
62
|
-
const delta = (currentValue || 0) - (pastValue || 0);
|
|
63
|
-
const trend = delta === 0 ? 'trending_flat' : delta < 0 ? 'trending_down' : 'trending_up';
|
|
64
|
-
return { delta, trend, value: pastValue };
|
|
65
|
-
}
|
|
66
|
-
registerDateRangeFilter() {
|
|
67
|
-
/* we cannot use the takeUntilDestroyed() helper here,
|
|
68
|
-
* because this method is indirectly called in the finalization of the getTimerangeFilter() call
|
|
69
|
-
*/
|
|
70
|
-
this.range.controls.end.valueChanges.pipe(takeUntil(this.destroyed$)).subscribe((date) => {
|
|
71
|
-
this.getCountByDate(date).subscribe((response) => {
|
|
72
|
-
this.recentTypeCount$.next(response);
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
this.range.controls.start.valueChanges.pipe(takeUntil(this.destroyed$)).subscribe((date) => {
|
|
76
|
-
this.getCountByDate(date).subscribe((response) => {
|
|
77
|
-
this.pastTypeCount$.next(response);
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
getTimeRangeFilter() {
|
|
82
|
-
return this.metaApi
|
|
83
|
-
.getTimerangeFilter()
|
|
84
|
-
.pipe(finalize(() => {
|
|
85
|
-
this.timeFilterLoaded.set(true);
|
|
86
|
-
this.registerDateRangeFilter();
|
|
87
|
-
}))
|
|
88
|
-
.subscribe((rangeFilter) => {
|
|
89
|
-
if (rangeFilter) {
|
|
90
|
-
const startDate = DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeStart')?.label, {
|
|
91
|
-
zone: 'utc',
|
|
92
|
-
}).startOf('day');
|
|
93
|
-
this.range.setControl('start', new FormControl(startDate, { nonNullable: true }));
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
getCountByDate(date) {
|
|
98
|
-
this.isLoading.set(true);
|
|
99
|
-
const filter = {
|
|
100
|
-
field: 'asOf',
|
|
101
|
-
values: [{ id: date.toISO({ includeOffset: false }), label: '' }],
|
|
102
|
-
};
|
|
103
|
-
return this.metaApi
|
|
104
|
-
.getMaterialTypeCountsByReplicationSource([filter])
|
|
105
|
-
.pipe(finalize(() => this.isLoading.set(false)));
|
|
106
|
-
}
|
|
107
|
-
ngOnInit() {
|
|
108
|
-
this.getTimeRangeFilter();
|
|
109
|
-
this.getCountByDate(this.range.controls.end.value)
|
|
110
|
-
.pipe(tap((response) => {
|
|
111
|
-
this.columns = response.columns.slice();
|
|
112
|
-
}))
|
|
113
|
-
.subscribe((response) => {
|
|
114
|
-
this.recentTypeCount$.next(response);
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
ngOnDestroy() {
|
|
118
|
-
this.destroyed$.next();
|
|
119
|
-
this.destroyed$.complete();
|
|
120
|
-
}
|
|
121
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialtypesBySourcesComponent, deps: [{ token: i1.MetaApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
122
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MaterialtypesBySourcesComponent, isStandalone: true, selector: "metaqs2-content-type-count", ngImport: i0, template: "<mat-card appearance=\"raised\">\n <mat-card-header>\n <mat-card-title>\n Qualit\u00E4tsmetrik: Inhaltsarten von Quellen{{isLoading() ? \": Lade neue Daten.\" : \"\"}}\n </mat-card-title>\n </mat-card-header>\n <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n <!-- show the filter after the values are loaded to avoid loading current data twice -->\n <mat-card-content *ngIf=\"timeFilterLoaded()\">\n <metaqs2-datepicker [disabled]=\"isLoading()\" [inputGroup]=\"range\" ></metaqs2-datepicker>\n </mat-card-content>\n <mat-card-actions align=\"end\">and some knops</mat-card-actions>\n</mat-card>\n<mat-card>\n <table [ngClass]=\"{'while-loading': isLoading()}\" mat-table [dataSource]=\"recentTypeCount$.value.rows\" class=\"quality-matrix\">\n <!-- Define columns of table -->\n <!-- Row Header Column -->\n <ng-container matColumnDef=\"label-col\" sticky>\n <th rowspan=\"2\" mat-header-cell *matHeaderCellDef>Quelle</th>\n <td\n mat-cell\n *matCellDef=\"let row\"\n matTooltip=\"{{row.meta.alt_label}}\"\n class=\"label-col\"\n >\n {{row.meta.label}}\n </td>\n </ng-container>\n <!-- one column for each type -->\n <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_type'\">\n <th colspan=\"2\" mat-header-cell *matHeaderCellDef matTooltip=\"{{col.label}}\" >{{col.label}}</th>\n </ng-container>\n <!-- one column for each type for the most current date-->\n <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_recent'\">\n <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\" >{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}</th>\n <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">{{ row.counts[col.id] ?? 'n/a' }}</td>\n </ng-container>\n <!-- one column for each type for the older date-->\n <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_past'\">\n <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\" >\n {{ pastTypeCount$.value.rows.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n </th>\n <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\">\n <ng-container *ngIf=\"pastTypeCount$.value.rows.length && pastTypeCount(row, col.id) as trend\">\n <span [ngClass]=\"trend.trend\"> {{ trend.value ?? 'n/a' }}<mat-icon aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n <span class=\"cdk-visually-hidden\">{{trend.trend}}</span>\n </ng-container>\n </td>\n </ng-container>\n <!-- generate actual table -->\n <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns); sticky:true;\"></tr>\n <tr mat-header-row *matHeaderRowDef=\"allColumns; sticky: true;\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns)\"></tr>\n\n </table>\n</mat-card>.", styles: ["tr:nth-child(2n){background-color:#e4e4e4}tr:nth-child(2n)>td.label-col,tr:nth-child(2n) td.recent-data-cell{border-right:1px solid white}tr:nth-child(odd){background-color:#fff}tr:nth-child(odd)>td.label-col,tr:nth-child(odd) td.recent-data-cell{border-right:1px solid #e4e4e4}.mat-mdc-header-cell,.mat-mdc-cell{text-align:center}.mat-mdc-header-cell a,.mat-mdc-cell a{cursor:pointer;text-decoration:underline}.mat-mdc-header-cell a:hover,.mat-mdc-cell a:hover{text-decoration:underline}.mat-mdc-header-cell mat-icon,.mat-mdc-cell mat-icon{margin-left:5px;vertical-align:middle}.trending_up{color:#4abeff}.trending_down{color:#c20808}\n"], dependencies: [{ kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i2.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i2.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { kind: "directive", type: i2.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i2.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i2.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i3.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i3.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i3.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i3.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i3.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i3.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i3.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i3.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i3.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i3.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: DatepickerComponent, selector: "metaqs2-datepicker", inputs: ["disabled", "inputGroup"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
123
|
-
}
|
|
124
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialtypesBySourcesComponent, decorators: [{
|
|
125
|
-
type: Component,
|
|
126
|
-
args: [{ selector: 'metaqs2-content-type-count', standalone: true, imports: [
|
|
127
|
-
MatCardModule,
|
|
128
|
-
MatCard,
|
|
129
|
-
MatCardHeader,
|
|
130
|
-
MatCardTitle,
|
|
131
|
-
MatCardContent,
|
|
132
|
-
MatCardActions,
|
|
133
|
-
MatTooltip,
|
|
134
|
-
MatTableModule,
|
|
135
|
-
MatTable,
|
|
136
|
-
TranslateModule,
|
|
137
|
-
MatHeaderRow,
|
|
138
|
-
MatHeaderRowDef,
|
|
139
|
-
MatRow,
|
|
140
|
-
MatRowDef,
|
|
141
|
-
NgForOf,
|
|
142
|
-
DatepickerComponent,
|
|
143
|
-
NgClass,
|
|
144
|
-
MatIcon,
|
|
145
|
-
NgIf,
|
|
146
|
-
], template: "<mat-card appearance=\"raised\">\n <mat-card-header>\n <mat-card-title>\n Qualit\u00E4tsmetrik: Inhaltsarten von Quellen{{isLoading() ? \": Lade neue Daten.\" : \"\"}}\n </mat-card-title>\n </mat-card-header>\n <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n <!-- show the filter after the values are loaded to avoid loading current data twice -->\n <mat-card-content *ngIf=\"timeFilterLoaded()\">\n <metaqs2-datepicker [disabled]=\"isLoading()\" [inputGroup]=\"range\" ></metaqs2-datepicker>\n </mat-card-content>\n <mat-card-actions align=\"end\">and some knops</mat-card-actions>\n</mat-card>\n<mat-card>\n <table [ngClass]=\"{'while-loading': isLoading()}\" mat-table [dataSource]=\"recentTypeCount$.value.rows\" class=\"quality-matrix\">\n <!-- Define columns of table -->\n <!-- Row Header Column -->\n <ng-container matColumnDef=\"label-col\" sticky>\n <th rowspan=\"2\" mat-header-cell *matHeaderCellDef>Quelle</th>\n <td\n mat-cell\n *matCellDef=\"let row\"\n matTooltip=\"{{row.meta.alt_label}}\"\n class=\"label-col\"\n >\n {{row.meta.label}}\n </td>\n </ng-container>\n <!-- one column for each type -->\n <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_type'\">\n <th colspan=\"2\" mat-header-cell *matHeaderCellDef matTooltip=\"{{col.label}}\" >{{col.label}}</th>\n </ng-container>\n <!-- one column for each type for the most current date-->\n <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_recent'\">\n <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\" >{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}</th>\n <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">{{ row.counts[col.id] ?? 'n/a' }}</td>\n </ng-container>\n <!-- one column for each type for the older date-->\n <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_past'\">\n <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\" >\n {{ pastTypeCount$.value.rows.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n </th>\n <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\">\n <ng-container *ngIf=\"pastTypeCount$.value.rows.length && pastTypeCount(row, col.id) as trend\">\n <span [ngClass]=\"trend.trend\"> {{ trend.value ?? 'n/a' }}<mat-icon aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n <span class=\"cdk-visually-hidden\">{{trend.trend}}</span>\n </ng-container>\n </td>\n </ng-container>\n <!-- generate actual table -->\n <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns); sticky:true;\"></tr>\n <tr mat-header-row *matHeaderRowDef=\"allColumns; sticky: true;\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns)\"></tr>\n\n </table>\n</mat-card>.", styles: ["tr:nth-child(2n){background-color:#e4e4e4}tr:nth-child(2n)>td.label-col,tr:nth-child(2n) td.recent-data-cell{border-right:1px solid white}tr:nth-child(odd){background-color:#fff}tr:nth-child(odd)>td.label-col,tr:nth-child(odd) td.recent-data-cell{border-right:1px solid #e4e4e4}.mat-mdc-header-cell,.mat-mdc-cell{text-align:center}.mat-mdc-header-cell a,.mat-mdc-cell a{cursor:pointer;text-decoration:underline}.mat-mdc-header-cell a:hover,.mat-mdc-cell a:hover{text-decoration:underline}.mat-mdc-header-cell mat-icon,.mat-mdc-cell mat-icon{margin-left:5px;vertical-align:middle}.trending_up{color:#4abeff}.trending_down{color:#c20808}\n"] }]
|
|
147
|
-
}], ctorParameters: () => [{ type: i1.MetaApiService }] });
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"materialtypes-by-sources.component.js","sourceRoot":"","sources":["../../../../../projects/ng-meta-widgets-lib/src/lib/materialtypes-by-sources/materialtypes-by-sources.component.ts","../../../../../projects/ng-meta-widgets-lib/src/lib/materialtypes-by-sources/materialtypes-by-sources.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit, signal } from '@angular/core';\nimport {\n  MatCard,\n  MatCardActions,\n  MatCardContent,\n  MatCardHeader,\n  MatCardModule,\n  MatCardTitle,\n} from '@angular/material/card';\nimport { MatTooltip } from '@angular/material/tooltip';\nimport { MatHeaderRow, MatHeaderRowDef, MatRow, MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { NgClass, NgForOf, NgIf } from '@angular/common';\nimport { MetaApiService } from '../meta-api.service';\nimport { Filter, MatrixRowWithCounts, MatrixWithCounts, QualityMatrixHeader } from '../java-api';\nimport { DateTime } from 'luxon';\nimport { finalize, takeUntil, tap } from 'rxjs/operators';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { DatepickerComponent } from '../components/filter/datepicker/datepicker.component';\nimport { MatIcon } from '@angular/material/icon';\n\n@Component({\n  selector: 'metaqs2-content-type-count',\n  standalone: true,\n  imports: [\n    MatCardModule,\n    MatCard,\n    MatCardHeader,\n    MatCardTitle,\n    MatCardContent,\n    MatCardActions,\n    MatTooltip,\n    MatTableModule,\n    MatTable,\n    TranslateModule,\n    MatHeaderRow,\n    MatHeaderRowDef,\n    MatRow,\n    MatRowDef,\n    NgForOf,\n    DatepickerComponent,\n    NgClass,\n    MatIcon,\n    NgIf,\n  ],\n  //changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './materialtypes-by-sources.component.html',\n  styleUrl: './materialtypes-by-sources.component.scss',\n})\nexport class MaterialtypesBySourcesComponent implements OnInit, OnDestroy {\n  protected readonly isLoading = signal(true);\n  protected readonly timeFilterLoaded = signal(false);\n  private readonly destroyed$ = new Subject<void>();\n  protected readonly recentTypeCount$ = new BehaviorSubject<MatrixWithCounts>({ columns: [], rows: [] });\n  protected readonly pastTypeCount$ = new BehaviorSubject<MatrixWithCounts>({ columns: [], rows: [] });\n  private columns: QualityMatrixHeader[] = [];\n  /* In this widget's backend we do have data for today\n   * therefore we set the end date to today and use the timerange() endpoint to only set the start date\n   */\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(DateTime.utc().startOf('day'), { nonNullable: true }),\n  });\n\n  constructor(private readonly metaApi: MetaApiService) {}\n  columnIdent(_index: number, col: QualityMatrixHeader) {\n    return col.id;\n  }\n\n  get typeColumns(): string[] {\n    return this.columns.map((c) => c.id + '_type');\n  }\n\n  get recentColumns(): string[] {\n    return this.columns.map((c) => c.id + '_recent');\n  }\n\n  get pastColumns(): string[] {\n    return this.columns.map((c) => c.id + '_past');\n  }\n\n  get allColumns(): string[] {\n    //return this.recentColumns;\n    return this.pastColumns.flatMap((e, i) => [e, this.recentColumns[i]]);\n  }\n\n  protected pastTypeCount(row: MatrixRowWithCounts, columnid: string) {\n    if (!this.pastTypeCount$.value.rows.length) {\n      return {};\n    }\n    const past_row = this.pastTypeCount$.value.rows.find((pr) => pr.meta.id == row.meta.id);\n    const past_column = this.pastTypeCount$.value.columns.find((c) => c.id == columnid);\n    if (!past_row || !past_column) {\n      return {};\n    }\n\n    const currentValue = row.counts[columnid];\n    const pastValue = past_row.counts[columnid];\n\n    const delta = (currentValue || 0) - (pastValue || 0);\n    const trend = delta === 0 ? 'trending_flat' : delta < 0 ? 'trending_down' : 'trending_up';\n    return { delta, trend, value: pastValue };\n  }\n\n  private registerDateRangeFilter() {\n    /* we cannot use the takeUntilDestroyed() helper here,\n     * because this method is indirectly called in the finalization of the getTimerangeFilter() call\n     */\n    this.range.controls.end.valueChanges.pipe(takeUntil(this.destroyed$)).subscribe((date) => {\n      this.getCountByDate(date).subscribe((response) => {\n        this.recentTypeCount$.next(response);\n      });\n    });\n    this.range.controls.start.valueChanges.pipe(takeUntil(this.destroyed$)).subscribe((date) => {\n      this.getCountByDate(date).subscribe((response) => {\n        this.pastTypeCount$.next(response);\n      });\n    });\n  }\n\n  private getTimeRangeFilter() {\n    return this.metaApi\n      .getTimerangeFilter()\n      .pipe(\n        finalize(() => {\n          this.timeFilterLoaded.set(true);\n          this.registerDateRangeFilter();\n        })\n      )\n      .subscribe((rangeFilter) => {\n        if (rangeFilter) {\n          const startDate = DateTime.fromISO(rangeFilter.values.find((v) => v.id === 'rangeStart')?.label!, {\n            zone: 'utc',\n          }).startOf('day');\n          this.range.setControl('start', new FormControl<DateTime>(startDate, { nonNullable: true }));\n        }\n      });\n  }\n\n  private getCountByDate(date: DateTime) {\n    this.isLoading.set(true);\n    const filter: Filter = {\n      field: 'asOf',\n      values: [{ id: date.toISO({ includeOffset: false })!, label: '' }],\n    };\n    return this.metaApi\n      .getMaterialTypeCountsByReplicationSource([filter])\n      .pipe(finalize(() => this.isLoading.set(false)));\n  }\n\n  ngOnInit(): void {\n    this.getTimeRangeFilter();\n    this.getCountByDate(this.range.controls.end.value)\n      .pipe(\n        tap((response) => {\n          this.columns = response.columns.slice();\n        })\n      )\n      .subscribe((response) => {\n        this.recentTypeCount$.next(response);\n      });\n  }\n\n  protected readonly DateTime = DateTime;\n\n  ngOnDestroy(): void {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n  }\n}\n","<mat-card appearance=\"raised\">\n  <mat-card-header>\n    <mat-card-title>\n      Qualitätsmetrik: Inhaltsarten von Quellen{{isLoading() ? \": Lade neue Daten.\" : \"\"}}\n    </mat-card-title>\n  </mat-card-header>\n  <!-- consider to put the filter in the table header to avoid that it is scrolled out of view-->\n  <!-- show the filter after the values are loaded to avoid loading current data twice -->\n  <mat-card-content *ngIf=\"timeFilterLoaded()\">\n    <metaqs2-datepicker [disabled]=\"isLoading()\" [inputGroup]=\"range\" ></metaqs2-datepicker>\n  </mat-card-content>\n  <mat-card-actions align=\"end\">and some knops</mat-card-actions>\n</mat-card>\n<mat-card>\n  <table [ngClass]=\"{'while-loading': isLoading()}\" mat-table [dataSource]=\"recentTypeCount$.value.rows\" class=\"quality-matrix\">\n    <!-- Define columns of table -->\n    <!-- Row Header Column -->\n    <ng-container matColumnDef=\"label-col\" sticky>\n      <th rowspan=\"2\" mat-header-cell *matHeaderCellDef>Quelle</th>\n      <td\n        mat-cell\n        *matCellDef=\"let row\"\n        matTooltip=\"{{row.meta.alt_label}}\"\n        class=\"label-col\"\n      >\n        {{row.meta.label}}\n      </td>\n    </ng-container>\n    <!-- one column for each type -->\n    <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_type'\">\n      <th colspan=\"2\" mat-header-cell *matHeaderCellDef matTooltip=\"{{col.label}}\" >{{col.label}}</th>\n    </ng-container>\n    <!-- one column for each type for the most current date-->\n    <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_recent'\">\n      <th class=\"recent-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\" >{{ range.controls.end.value.toLocaleString(DateTime.DATE_SHORT) }}</th>\n      <td class=\"recent-data-cell\" mat-cell *matCellDef=\"let row\">{{ row.counts[col.id] ?? 'n/a' }}</td>\n    </ng-container>\n    <!-- one column for each type for the older date-->\n    <ng-container *ngFor=\"let col of recentTypeCount$.value.columns; trackBy:columnIdent\" [matColumnDef]=\"col.id + '_past'\">\n      <th class=\"past-data-cell\" mat-header-cell *matHeaderCellDef matTooltip=\"no tooltip\" >\n        {{ pastTypeCount$.value.rows.length ? range.controls.start.value.toLocaleString(DateTime.DATE_SHORT) : 'no past data' }}\n      </th>\n      <td class=\"past-data-cell\" mat-cell *matCellDef=\"let row;\">\n        <ng-container *ngIf=\"pastTypeCount$.value.rows.length && pastTypeCount(row, col.id) as trend\">\n          <span [ngClass]=\"trend.trend\"> {{ trend.value ?? 'n/a' }}<mat-icon aria-hidden=\"false\" [attr.aria-label]=\"trend.trend\" [fontIcon]=\"trend.trend!\" /></span>\n          <span class=\"cdk-visually-hidden\">{{trend.trend}}</span>\n        </ng-container>\n      </td>\n    </ng-container>\n    <!-- generate actual table -->\n    <tr mat-header-row *matHeaderRowDef=\"['label-col'].concat(typeColumns); sticky:true;\"></tr>\n    <tr mat-header-row *matHeaderRowDef=\"allColumns; sticky: true;\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: ['label-col'].concat(allColumns)\"></tr>\n\n  </table>\n</mat-card>."]}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject } from 'rxjs';
|
|
3
|
-
import { MetaApiService } from '../meta-api.service';
|
|
4
|
-
import { MatrixRowWithCounts, MatrixWithCounts, QualityMatrixHeader } from '../java-api';
|
|
5
|
-
import { DateTime } from 'luxon';
|
|
6
|
-
import { FormControl, FormGroup } from '@angular/forms';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export declare class MaterialtypesBySourcesComponent implements OnInit, OnDestroy {
|
|
9
|
-
private readonly metaApi;
|
|
10
|
-
protected readonly isLoading: import("@angular/core").WritableSignal<boolean>;
|
|
11
|
-
protected readonly timeFilterLoaded: import("@angular/core").WritableSignal<boolean>;
|
|
12
|
-
private readonly destroyed$;
|
|
13
|
-
protected readonly recentTypeCount$: BehaviorSubject<MatrixWithCounts>;
|
|
14
|
-
protected readonly pastTypeCount$: BehaviorSubject<MatrixWithCounts>;
|
|
15
|
-
private columns;
|
|
16
|
-
readonly range: FormGroup<{
|
|
17
|
-
start: FormControl<DateTime<boolean>>;
|
|
18
|
-
end: FormControl<DateTime<boolean>>;
|
|
19
|
-
}>;
|
|
20
|
-
constructor(metaApi: MetaApiService);
|
|
21
|
-
columnIdent(_index: number, col: QualityMatrixHeader): string;
|
|
22
|
-
get typeColumns(): string[];
|
|
23
|
-
get recentColumns(): string[];
|
|
24
|
-
get pastColumns(): string[];
|
|
25
|
-
get allColumns(): string[];
|
|
26
|
-
protected pastTypeCount(row: MatrixRowWithCounts, columnid: string): {
|
|
27
|
-
delta?: undefined;
|
|
28
|
-
trend?: undefined;
|
|
29
|
-
value?: undefined;
|
|
30
|
-
} | {
|
|
31
|
-
delta: number;
|
|
32
|
-
trend: string;
|
|
33
|
-
value: number;
|
|
34
|
-
};
|
|
35
|
-
private registerDateRangeFilter;
|
|
36
|
-
private getTimeRangeFilter;
|
|
37
|
-
private getCountByDate;
|
|
38
|
-
ngOnInit(): void;
|
|
39
|
-
protected readonly DateTime: typeof DateTime;
|
|
40
|
-
ngOnDestroy(): void;
|
|
41
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<MaterialtypesBySourcesComponent, never>;
|
|
42
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<MaterialtypesBySourcesComponent, "metaqs2-content-type-count", never, {}, {}, never, never, true, never>;
|
|
43
|
-
}
|