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.
Files changed (76) hide show
  1. package/README.md +1 -14
  2. package/fesm2022/ngx-edu-sharing-metaqs2.mjs +195 -197
  3. package/fesm2022/ngx-edu-sharing-metaqs2.mjs.map +1 -1
  4. package/lib/components/collection-issues/collection-issues.component.d.ts +1 -1
  5. package/lib/components/donut-chart-tooltip/donut-chart-tooltip.component.d.ts +1 -1
  6. package/lib/components/filter/quality-matrix-filter.component.d.ts +4 -6
  7. package/lib/components/material-issues/material-issues.component.d.ts +1 -1
  8. package/lib/components/node-entry/node-entry.component.d.ts +1 -1
  9. package/lib/components/node-list/node-list.component.d.ts +1 -1
  10. package/lib/components/quality-matrix/quality_matrix.d.ts +1 -3
  11. package/lib/counts-with-history/counts-with-history.component.d.ts +1 -1
  12. package/lib/ng-meta-widgets-lib.module.d.ts +34 -37
  13. package/lib/node-image-url.pipe.d.ts +1 -1
  14. package/lib/wrap-observable.pipe.d.ts +1 -1
  15. package/package.json +6 -8
  16. package/esm2022/lib/collection-count-history/collection-count-history.component.mjs +0 -131
  17. package/esm2022/lib/collection-count-history/monthpicker/monthpicker.component.mjs +0 -114
  18. package/esm2022/lib/components/collection-issues/collection-issues.component.mjs +0 -23
  19. package/esm2022/lib/components/donut-chart/donut-chart.component.mjs +0 -85
  20. package/esm2022/lib/components/donut-chart/donut-chart.model.mjs +0 -2
  21. package/esm2022/lib/components/donut-chart/donut-chart.pipe.mjs +0 -50
  22. package/esm2022/lib/components/donut-chart-tooltip/donut-chart-tooltip.component.mjs +0 -79
  23. package/esm2022/lib/components/editorial-link-service/editorial-link.service.mjs +0 -169
  24. package/esm2022/lib/components/filter/datepicker/datepicker.component.mjs +0 -99
  25. package/esm2022/lib/components/filter/quality-matrix-filter.component.mjs +0 -47
  26. package/esm2022/lib/components/loading_indicator/overlay/overlay.service.mjs +0 -41
  27. package/esm2022/lib/components/loading_indicator/progress-spinner/progress-spinner.component.mjs +0 -65
  28. package/esm2022/lib/components/material-issues/material-issues.component.mjs +0 -23
  29. package/esm2022/lib/components/node-entry/node-entry.component.mjs +0 -35
  30. package/esm2022/lib/components/node-list/node-list.component.mjs +0 -112
  31. package/esm2022/lib/components/quality-matrix/quality_matrix.mjs +0 -413
  32. package/esm2022/lib/components/quality-matrix/scroll-marker.directive.mjs +0 -17
  33. package/esm2022/lib/config-helper.service.mjs +0 -32
  34. package/esm2022/lib/core/svg-icons.service.mjs +0 -44
  35. package/esm2022/lib/core/tooltip.service.mjs +0 -146
  36. package/esm2022/lib/counts-with-history/counts-with-history.component.mjs +0 -203
  37. package/esm2022/lib/java-api/api/api.mjs +0 -12
  38. package/esm2022/lib/java-api/api/authProxyController.service.mjs +0 -107
  39. package/esm2022/lib/java-api/api/collectionAPI.service.mjs +0 -409
  40. package/esm2022/lib/java-api/api/editorsAPI.service.mjs +0 -157
  41. package/esm2022/lib/java-api/api/filterAPI.service.mjs +0 -237
  42. package/esm2022/lib/java-api/api/replicationSourceAPI.service.mjs +0 -230
  43. package/esm2022/lib/java-api/api.base.service.mjs +0 -66
  44. package/esm2022/lib/java-api/api.module.mjs +0 -40
  45. package/esm2022/lib/java-api/configuration.mjs +0 -103
  46. package/esm2022/lib/java-api/encoder.mjs +0 -19
  47. package/esm2022/lib/java-api/index.mjs +0 -7
  48. package/esm2022/lib/java-api/model/collectionWithMissingAttributes.mjs +0 -11
  49. package/esm2022/lib/java-api/model/count.mjs +0 -11
  50. package/esm2022/lib/java-api/model/eduCollection.mjs +0 -11
  51. package/esm2022/lib/java-api/model/filter.mjs +0 -2
  52. package/esm2022/lib/java-api/model/filterValue.mjs +0 -11
  53. package/esm2022/lib/java-api/model/materialCountDto.mjs +0 -2
  54. package/esm2022/lib/java-api/model/materialCountFilter.mjs +0 -11
  55. package/esm2022/lib/java-api/model/materialWithMissingAttributes.mjs +0 -11
  56. package/esm2022/lib/java-api/model/matrixRowWithCounts.mjs +0 -2
  57. package/esm2022/lib/java-api/model/matrixWithCounts.mjs +0 -2
  58. package/esm2022/lib/java-api/model/missingAttributeResult.mjs +0 -2
  59. package/esm2022/lib/java-api/model/models.mjs +0 -16
  60. package/esm2022/lib/java-api/model/qualityMatrix.mjs +0 -2
  61. package/esm2022/lib/java-api/model/qualityMatrixHeader.mjs +0 -11
  62. package/esm2022/lib/java-api/model/qualityMatrixReplicationSourceCounts.mjs +0 -11
  63. package/esm2022/lib/java-api/model/qualityMatrixRow.mjs +0 -2
  64. package/esm2022/lib/java-api/param.mjs +0 -2
  65. package/esm2022/lib/java-api/variables.mjs +0 -9
  66. package/esm2022/lib/meta-api.service.mjs +0 -77
  67. package/esm2022/lib/ng-meta-widgets-lib.module.mjs +0 -198
  68. package/esm2022/lib/node-image-url.pipe.mjs +0 -29
  69. package/esm2022/lib/tree-collection-details/tree-collection-details.component.mjs +0 -87
  70. package/esm2022/lib/tree-license/tree-license.component.mjs +0 -136
  71. package/esm2022/lib/tree-search-counts/inline-worker.mjs +0 -102
  72. package/esm2022/lib/tree-search-counts/tree-search-counts.component.mjs +0 -209
  73. package/esm2022/lib/wrap-observable.pipe.mjs +0 -21
  74. package/esm2022/ngx-edu-sharing-metaqs2.mjs +0 -5
  75. package/esm2022/public-api.mjs +0 -18
  76. 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, false, 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, false, 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: Observable<any>;
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, false, 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, false, 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, false, 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, false, 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 "./wrap-observable.pipe";
6
- import * as i2 from "./components/collection-issues/collection-issues.component";
7
- import * as i3 from "./components/material-issues/material-issues.component";
8
- import * as i4 from "./components/node-entry/node-entry.component";
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 "./node-image-url.pipe";
11
- import * as i7 from "./components/donut-chart-tooltip/donut-chart-tooltip.component";
12
- import * as i8 from "@angular/platform-browser";
13
- import * as i9 from "./java-api/api.module";
14
- import * as i10 from "@angular/material/card";
15
- import * as i11 from "@angular/material/tree";
16
- import * as i12 from "./components/donut-chart/donut-chart.component";
17
- import * as i13 from "./components/donut-chart/donut-chart.pipe";
18
- import * as i14 from "@angular/platform-browser/animations";
19
- import * as i15 from "@angular/material/icon";
20
- import * as i16 from "@angular/material/slider";
21
- import * as i17 from "./components/quality-matrix/quality_matrix";
22
- import * as i18 from "@angular/material/slide-toggle";
23
- import * as i19 from "@angular/material/button";
24
- import * as i20 from "@angular/material/progress-spinner";
25
- import * as i21 from "@angular/material/table";
26
- import * as i22 from "@angular/material/grid-list";
27
- import * as i23 from "@angular/material/form-field";
28
- import * as i24 from "@angular/material/input";
29
- import * as i25 from "@angular/material/sidenav";
30
- import * as i26 from "@angular/forms";
31
- import * as i27 from "@angular/material/select";
32
- import * as i28 from "@angular/material/tooltip";
33
- import * as i29 from "@angular/material/list";
34
- import * as i30 from "@angular/material/sort";
35
- import * as i31 from "@angular/material/checkbox";
36
- import * as i32 from "@ngx-translate/core";
37
- import * as i33 from "./components/filter/quality-matrix-filter.component";
38
- import * as i34 from "@angular/material/datepicker";
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.WrapObservablePipe, typeof i2.CollectionIssuesComponent, typeof i3.MaterialIssuesComponent, typeof i4.NodeEntryComponent, typeof i5.NodeListComponent, typeof i6.NodeImageUrlPipe, typeof i7.DonutChartTooltipComponent], [typeof i8.BrowserModule, typeof i9.ApiModule, typeof i10.MatCardModule, typeof i11.MatTreeModule, typeof i12.DonutChartComponent, typeof i13.DonutChartPipe, typeof i14.BrowserAnimationsModule, typeof i15.MatIconModule, typeof i16.MatSliderModule, typeof i17.QualityMatrixComponent, typeof i18.MatSlideToggleModule, typeof i19.MatButtonModule, typeof i20.MatProgressSpinnerModule, typeof i21.MatTableModule, typeof i22.MatGridListModule, typeof i23.MatFormFieldModule, typeof i24.MatInputModule, typeof i25.MatSidenavModule, typeof i26.FormsModule, typeof i27.MatSelectModule, typeof i26.ReactiveFormsModule, typeof i28.MatTooltipModule, typeof i29.MatListModule, typeof i30.MatSort, typeof i30.MatSortModule, typeof i31.MatCheckbox, typeof i32.TranslateModule, typeof i33.QualityMatrixFilterComponent, typeof i34.MatDateRangeInput, typeof i34.MatDatepickerToggle, typeof i34.MatDatepickerModule, typeof i34.MatDateRangePicker, typeof i34.MatDatepickerInput, typeof i34.MatDatepicker, typeof i35.DatepickerComponent, typeof i36.ProgressSpinnerComponent, typeof i37.ScrollMarkerDirective], [typeof i2.CollectionIssuesComponent, typeof i3.MaterialIssuesComponent, typeof i5.NodeListComponent, typeof i17.QualityMatrixComponent]>;
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", false>;
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", false>;
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.53",
5
+ "version": "0.9.54",
6
6
  "author": "Torsten Simon",
7
7
  "peerDependencies": {
8
- "@angular/common": ">=16.0.0",
9
- "@angular/core": ">=16.0.0",
10
- "@angular/cdk": ">=16.0.0",
11
- "@angular/elements": ">=16.0.0",
12
- "@angular/material": ">=16.0.0",
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=