ngx-edu-sharing-metaqs2 0.9.53 → 0.9.54
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -14
- package/fesm2022/ngx-edu-sharing-metaqs2.mjs +195 -197
- package/fesm2022/ngx-edu-sharing-metaqs2.mjs.map +1 -1
- package/lib/components/collection-issues/collection-issues.component.d.ts +1 -1
- package/lib/components/donut-chart-tooltip/donut-chart-tooltip.component.d.ts +1 -1
- package/lib/components/filter/quality-matrix-filter.component.d.ts +4 -6
- package/lib/components/material-issues/material-issues.component.d.ts +1 -1
- package/lib/components/node-entry/node-entry.component.d.ts +1 -1
- package/lib/components/node-list/node-list.component.d.ts +1 -1
- package/lib/components/quality-matrix/quality_matrix.d.ts +1 -3
- package/lib/counts-with-history/counts-with-history.component.d.ts +1 -1
- package/lib/ng-meta-widgets-lib.module.d.ts +34 -37
- package/lib/node-image-url.pipe.d.ts +1 -1
- package/lib/wrap-observable.pipe.d.ts +1 -1
- package/package.json +6 -8
- package/esm2022/lib/collection-count-history/collection-count-history.component.mjs +0 -131
- package/esm2022/lib/collection-count-history/monthpicker/monthpicker.component.mjs +0 -114
- package/esm2022/lib/components/collection-issues/collection-issues.component.mjs +0 -23
- package/esm2022/lib/components/donut-chart/donut-chart.component.mjs +0 -85
- package/esm2022/lib/components/donut-chart/donut-chart.model.mjs +0 -2
- package/esm2022/lib/components/donut-chart/donut-chart.pipe.mjs +0 -50
- package/esm2022/lib/components/donut-chart-tooltip/donut-chart-tooltip.component.mjs +0 -79
- package/esm2022/lib/components/editorial-link-service/editorial-link.service.mjs +0 -169
- package/esm2022/lib/components/filter/datepicker/datepicker.component.mjs +0 -99
- package/esm2022/lib/components/filter/quality-matrix-filter.component.mjs +0 -47
- package/esm2022/lib/components/loading_indicator/overlay/overlay.service.mjs +0 -41
- package/esm2022/lib/components/loading_indicator/progress-spinner/progress-spinner.component.mjs +0 -65
- package/esm2022/lib/components/material-issues/material-issues.component.mjs +0 -23
- package/esm2022/lib/components/node-entry/node-entry.component.mjs +0 -35
- package/esm2022/lib/components/node-list/node-list.component.mjs +0 -112
- package/esm2022/lib/components/quality-matrix/quality_matrix.mjs +0 -413
- package/esm2022/lib/components/quality-matrix/scroll-marker.directive.mjs +0 -17
- package/esm2022/lib/config-helper.service.mjs +0 -32
- package/esm2022/lib/core/svg-icons.service.mjs +0 -44
- package/esm2022/lib/core/tooltip.service.mjs +0 -146
- package/esm2022/lib/counts-with-history/counts-with-history.component.mjs +0 -203
- package/esm2022/lib/java-api/api/api.mjs +0 -12
- package/esm2022/lib/java-api/api/authProxyController.service.mjs +0 -107
- package/esm2022/lib/java-api/api/collectionAPI.service.mjs +0 -409
- package/esm2022/lib/java-api/api/editorsAPI.service.mjs +0 -157
- package/esm2022/lib/java-api/api/filterAPI.service.mjs +0 -237
- package/esm2022/lib/java-api/api/replicationSourceAPI.service.mjs +0 -230
- package/esm2022/lib/java-api/api.base.service.mjs +0 -66
- package/esm2022/lib/java-api/api.module.mjs +0 -40
- package/esm2022/lib/java-api/configuration.mjs +0 -103
- package/esm2022/lib/java-api/encoder.mjs +0 -19
- package/esm2022/lib/java-api/index.mjs +0 -7
- package/esm2022/lib/java-api/model/collectionWithMissingAttributes.mjs +0 -11
- package/esm2022/lib/java-api/model/count.mjs +0 -11
- package/esm2022/lib/java-api/model/eduCollection.mjs +0 -11
- package/esm2022/lib/java-api/model/filter.mjs +0 -2
- package/esm2022/lib/java-api/model/filterValue.mjs +0 -11
- package/esm2022/lib/java-api/model/materialCountDto.mjs +0 -2
- package/esm2022/lib/java-api/model/materialCountFilter.mjs +0 -11
- package/esm2022/lib/java-api/model/materialWithMissingAttributes.mjs +0 -11
- package/esm2022/lib/java-api/model/matrixRowWithCounts.mjs +0 -2
- package/esm2022/lib/java-api/model/matrixWithCounts.mjs +0 -2
- package/esm2022/lib/java-api/model/missingAttributeResult.mjs +0 -2
- package/esm2022/lib/java-api/model/models.mjs +0 -16
- package/esm2022/lib/java-api/model/qualityMatrix.mjs +0 -2
- package/esm2022/lib/java-api/model/qualityMatrixHeader.mjs +0 -11
- package/esm2022/lib/java-api/model/qualityMatrixReplicationSourceCounts.mjs +0 -11
- package/esm2022/lib/java-api/model/qualityMatrixRow.mjs +0 -2
- package/esm2022/lib/java-api/param.mjs +0 -2
- package/esm2022/lib/java-api/variables.mjs +0 -9
- package/esm2022/lib/meta-api.service.mjs +0 -77
- package/esm2022/lib/ng-meta-widgets-lib.module.mjs +0 -198
- package/esm2022/lib/node-image-url.pipe.mjs +0 -29
- package/esm2022/lib/tree-collection-details/tree-collection-details.component.mjs +0 -87
- package/esm2022/lib/tree-license/tree-license.component.mjs +0 -136
- package/esm2022/lib/tree-search-counts/inline-worker.mjs +0 -102
- package/esm2022/lib/tree-search-counts/tree-search-counts.component.mjs +0 -209
- package/esm2022/lib/wrap-observable.pipe.mjs +0 -21
- package/esm2022/ngx-edu-sharing-metaqs2.mjs +0 -5
- package/esm2022/public-api.mjs +0 -18
- package/esm2022/web-components.mjs +0 -36
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
-
import { DonutChartPipe } from './donut-chart.pipe';
|
|
3
|
-
import { NgForOf, NgIf } from '@angular/common';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
/**
|
|
6
|
-
* A donut chart component that displays a list of slices.
|
|
7
|
-
* The chart is divided into slices, each slice has a color and a label.
|
|
8
|
-
* Each slice is represented by a percentage of the total chart.
|
|
9
|
-
* borrowed from https://medium.com/@theAngularGuy/how-to-create-an-interactive-donut-chart-using-svg-107cbf0b5b6
|
|
10
|
-
*/
|
|
11
|
-
export class DonutChartComponent {
|
|
12
|
-
constructor() {
|
|
13
|
-
this.radius = 50;
|
|
14
|
-
this.viewBox = 100;
|
|
15
|
-
this.borderSize = 20;
|
|
16
|
-
this.strokeWidth = 5;
|
|
17
|
-
this.data = [];
|
|
18
|
-
}
|
|
19
|
-
ngOnInit() {
|
|
20
|
-
const sum = this.data?.reduce((accu, slice) => accu + slice.percent, 0);
|
|
21
|
-
if (sum !== 100) {
|
|
22
|
-
throw new Error(`The sum of all slices of the donut chart must equal to 100%. Found: ${sum}.`);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
trackByFn(index, slice) {
|
|
26
|
-
return slice.id;
|
|
27
|
-
}
|
|
28
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DonutChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
29
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DonutChartComponent, isStandalone: true, selector: "metaqs2-donut-chart", inputs: { radius: "radius", viewBox: "viewBox", borderSize: "borderSize", strokeWidth: "strokeWidth", data: "data" }, ngImport: i0, template: `
|
|
30
|
-
<svg [attr.viewBox]="'0 0 ' + viewBox + ' ' + viewBox" *ngIf="data">
|
|
31
|
-
<path
|
|
32
|
-
*ngFor="
|
|
33
|
-
let slice of data | slicesWithCommandsAndOffset : radius : viewBox : borderSize;
|
|
34
|
-
trackBy: trackByFn;
|
|
35
|
-
let index = index
|
|
36
|
-
"
|
|
37
|
-
[attr.fill]="slice.color"
|
|
38
|
-
stroke="white"
|
|
39
|
-
paint-order="stroke"
|
|
40
|
-
stroke-opacity="1"
|
|
41
|
-
[attr.stroke-width]="strokeWidth"
|
|
42
|
-
[attr.d]="slice.commands"
|
|
43
|
-
[attr.transform]="'rotate(' + slice.offset + ')'"
|
|
44
|
-
(click)="slice.onClickCb?.()"
|
|
45
|
-
>
|
|
46
|
-
<title>{{ slice.label }}</title>
|
|
47
|
-
</path>
|
|
48
|
-
</svg>
|
|
49
|
-
`, isInline: true, styles: [":host{display:block}svg{overflow:visible;transform-origin:center;width:3.5rem;aspect-ratio:1/1;rotate:-90deg}path{transform-origin:center;fill-opacity:.7;cursor:pointer}path:hover{fill-opacity:1}\n"], dependencies: [{ kind: "pipe", type: DonutChartPipe, name: "slicesWithCommandsAndOffset" }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
50
|
-
}
|
|
51
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DonutChartComponent, decorators: [{
|
|
52
|
-
type: Component,
|
|
53
|
-
args: [{ selector: 'metaqs2-donut-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: `
|
|
54
|
-
<svg [attr.viewBox]="'0 0 ' + viewBox + ' ' + viewBox" *ngIf="data">
|
|
55
|
-
<path
|
|
56
|
-
*ngFor="
|
|
57
|
-
let slice of data | slicesWithCommandsAndOffset : radius : viewBox : borderSize;
|
|
58
|
-
trackBy: trackByFn;
|
|
59
|
-
let index = index
|
|
60
|
-
"
|
|
61
|
-
[attr.fill]="slice.color"
|
|
62
|
-
stroke="white"
|
|
63
|
-
paint-order="stroke"
|
|
64
|
-
stroke-opacity="1"
|
|
65
|
-
[attr.stroke-width]="strokeWidth"
|
|
66
|
-
[attr.d]="slice.commands"
|
|
67
|
-
[attr.transform]="'rotate(' + slice.offset + ')'"
|
|
68
|
-
(click)="slice.onClickCb?.()"
|
|
69
|
-
>
|
|
70
|
-
<title>{{ slice.label }}</title>
|
|
71
|
-
</path>
|
|
72
|
-
</svg>
|
|
73
|
-
`, imports: [DonutChartPipe, NgForOf, NgIf], standalone: true, styles: [":host{display:block}svg{overflow:visible;transform-origin:center;width:3.5rem;aspect-ratio:1/1;rotate:-90deg}path{transform-origin:center;fill-opacity:.7;cursor:pointer}path:hover{fill-opacity:1}\n"] }]
|
|
74
|
-
}], propDecorators: { radius: [{
|
|
75
|
-
type: Input
|
|
76
|
-
}], viewBox: [{
|
|
77
|
-
type: Input
|
|
78
|
-
}], borderSize: [{
|
|
79
|
-
type: Input
|
|
80
|
-
}], strokeWidth: [{
|
|
81
|
-
type: Input
|
|
82
|
-
}], data: [{
|
|
83
|
-
type: Input
|
|
84
|
-
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9udXQtY2hhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctbWV0YS13aWRnZXRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvZG9udXQtY2hhcnQvZG9udXQtY2hhcnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRWxGLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUVoRDs7Ozs7R0FLRztBQTZCSCxNQUFNLE9BQU8sbUJBQW1CO0lBNUJoQztRQTZCVyxXQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ1osWUFBTyxHQUFHLEdBQUcsQ0FBQztRQUNkLGVBQVUsR0FBRyxFQUFFLENBQUM7UUFDaEIsZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFDaEIsU0FBSSxHQUFpQixFQUFFLENBQUM7S0FZbEM7SUFWQyxRQUFRO1FBQ04sTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQztRQUN4RSxJQUFJLEdBQUcsS0FBSyxHQUFHLEVBQUUsQ0FBQztZQUNoQixNQUFNLElBQUksS0FBSyxDQUFDLHVFQUF1RSxHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ2pHLENBQUM7SUFDSCxDQUFDO0lBRUQsU0FBUyxDQUFDLEtBQWEsRUFBRSxLQUFpQjtRQUN4QyxPQUFPLEtBQUssQ0FBQyxFQUFFLENBQUM7SUFDbEIsQ0FBQzsrR0FoQlUsbUJBQW1CO21HQUFuQixtQkFBbUIscU1BeEJwQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQlQsMFFBQ1MsY0FBYyxvRUFBRSxPQUFPLG1IQUFFLElBQUk7OzRGQUc1QixtQkFBbUI7a0JBNUIvQixTQUFTOytCQUNFLHFCQUFxQixtQkFFZCx1QkFBdUIsQ0FBQyxNQUFNLFlBQ3JDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CVCxXQUNRLENBQUMsY0FBYyxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsY0FDNUIsSUFBSTs4QkFHUCxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb251dFNsaWNlIH0gZnJvbSAnLi9kb251dC1jaGFydC5tb2RlbCc7XG5pbXBvcnQgeyBEb251dENoYXJ0UGlwZSB9IGZyb20gJy4vZG9udXQtY2hhcnQucGlwZSc7XG5pbXBvcnQgeyBOZ0Zvck9mLCBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuLyoqXG4gKiBBIGRvbnV0IGNoYXJ0IGNvbXBvbmVudCB0aGF0IGRpc3BsYXlzIGEgbGlzdCBvZiBzbGljZXMuXG4gKiBUaGUgY2hhcnQgaXMgZGl2aWRlZCBpbnRvIHNsaWNlcywgZWFjaCBzbGljZSBoYXMgYSBjb2xvciBhbmQgYSBsYWJlbC5cbiAqIEVhY2ggc2xpY2UgaXMgcmVwcmVzZW50ZWQgYnkgYSBwZXJjZW50YWdlIG9mIHRoZSB0b3RhbCBjaGFydC5cbiAqIGJvcnJvd2VkIGZyb20gaHR0cHM6Ly9tZWRpdW0uY29tL0B0aGVBbmd1bGFyR3V5L2hvdy10by1jcmVhdGUtYW4taW50ZXJhY3RpdmUtZG9udXQtY2hhcnQtdXNpbmctc3ZnLTEwN2NiZjBiNWI2XG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21ldGFxczItZG9udXQtY2hhcnQnLFxuICBzdHlsZVVybHM6IFsnLi9kb251dC1jaGFydC5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgdGVtcGxhdGU6IGBcbiAgICA8c3ZnIFthdHRyLnZpZXdCb3hdPVwiJzAgMCAnICsgdmlld0JveCArICcgJyArIHZpZXdCb3hcIiAqbmdJZj1cImRhdGFcIj5cbiAgICAgIDxwYXRoXG4gICAgICAgICpuZ0Zvcj1cIlxuICAgICAgICAgIGxldCBzbGljZSBvZiBkYXRhIHwgc2xpY2VzV2l0aENvbW1hbmRzQW5kT2Zmc2V0IDogcmFkaXVzIDogdmlld0JveCA6IGJvcmRlclNpemU7XG4gICAgICAgICAgdHJhY2tCeTogdHJhY2tCeUZuO1xuICAgICAgICAgIGxldCBpbmRleCA9IGluZGV4XG4gICAgICAgIFwiXG4gICAgICAgIFthdHRyLmZpbGxdPVwic2xpY2UuY29sb3JcIlxuICAgICAgICBzdHJva2U9XCJ3aGl0ZVwiXG4gICAgICAgIHBhaW50LW9yZGVyPVwic3Ryb2tlXCJcbiAgICAgICAgc3Ryb2tlLW9wYWNpdHk9XCIxXCJcbiAgICAgICAgW2F0dHIuc3Ryb2tlLXdpZHRoXT1cInN0cm9rZVdpZHRoXCJcbiAgICAgICAgW2F0dHIuZF09XCJzbGljZS5jb21tYW5kc1wiXG4gICAgICAgIFthdHRyLnRyYW5zZm9ybV09XCIncm90YXRlKCcgKyBzbGljZS5vZmZzZXQgKyAnKSdcIlxuICAgICAgICAoY2xpY2spPVwic2xpY2Uub25DbGlja0NiPy4oKVwiXG4gICAgICA+XG4gICAgICAgIDx0aXRsZT57eyBzbGljZS5sYWJlbCB9fTwvdGl0bGU+XG4gICAgICA8L3BhdGg+XG4gICAgPC9zdmc+XG4gIGAsXG4gIGltcG9ydHM6IFtEb251dENoYXJ0UGlwZSwgTmdGb3JPZiwgTmdJZl0sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIERvbnV0Q2hhcnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSByYWRpdXMgPSA1MDtcbiAgQElucHV0KCkgdmlld0JveCA9IDEwMDtcbiAgQElucHV0KCkgYm9yZGVyU2l6ZSA9IDIwO1xuICBASW5wdXQoKSBzdHJva2VXaWR0aCA9IDU7XG4gIEBJbnB1dCgpIGRhdGE6IERvbnV0U2xpY2VbXSA9IFtdO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIGNvbnN0IHN1bSA9IHRoaXMuZGF0YT8ucmVkdWNlKChhY2N1LCBzbGljZSkgPT4gYWNjdSArIHNsaWNlLnBlcmNlbnQsIDApO1xuICAgIGlmIChzdW0gIT09IDEwMCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBUaGUgc3VtIG9mIGFsbCBzbGljZXMgb2YgdGhlIGRvbnV0IGNoYXJ0IG11c3QgZXF1YWwgdG8gMTAwJS4gRm91bmQ6ICR7c3VtfS5gKTtcbiAgICB9XG4gIH1cblxuICB0cmFja0J5Rm4oaW5kZXg6IG51bWJlciwgc2xpY2U6IERvbnV0U2xpY2UpIHtcbiAgICByZXR1cm4gc2xpY2UuaWQ7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9udXQtY2hhcnQubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1tZXRhLXdpZGdldHMtbGliL3NyYy9saWIvY29tcG9uZW50cy9kb251dC1jaGFydC9kb251dC1jaGFydC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBEb251dFNsaWNlIHtcbiAgaWQ6IG51bWJlcjtcbiAgcGVyY2VudDogbnVtYmVyO1xuICBjb2xvcjogc3RyaW5nO1xuICBsYWJlbD86IHN0cmluZztcbiAgdmVyYm9zZUxhYmVsPzogc3RyaW5nO1xuICBvbkNsaWNrQ2I/OiAoKSA9PiB2b2lkO1xufVxuIl19
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { Pipe } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class DonutChartPipe {
|
|
4
|
-
transform(donutSlices, radius, svgSize, borderSize) {
|
|
5
|
-
let previousPercent = 0;
|
|
6
|
-
return donutSlices.map((slice) => {
|
|
7
|
-
// this is a hack to that the circle is rendered when the percent is 100
|
|
8
|
-
slice.percent = slice.percent === 100 ? 99.999 : slice.percent;
|
|
9
|
-
const sliceWithCommands = {
|
|
10
|
-
...slice,
|
|
11
|
-
commands: `${this.getSliceCommands(slice, radius, svgSize, borderSize)} z`,
|
|
12
|
-
offset: previousPercent * 3.6 * -1,
|
|
13
|
-
};
|
|
14
|
-
previousPercent += slice.percent;
|
|
15
|
-
return sliceWithCommands;
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
getSliceCommands(donutSlice, radius, svgSize, borderSize) {
|
|
19
|
-
const degrees = this.percentToDegrees(donutSlice.percent);
|
|
20
|
-
const longPathFlag = degrees > 180 ? 1 : 0;
|
|
21
|
-
const innerRadius = radius - borderSize;
|
|
22
|
-
const commands = [];
|
|
23
|
-
commands.push(`M ${svgSize / 2 + radius} ${svgSize / 2}`);
|
|
24
|
-
commands.push(`A ${radius} ${radius} 0 ${longPathFlag} 0 ${this.getCoordFromDegrees(degrees, radius, svgSize)}`);
|
|
25
|
-
commands.push(`L ${this.getCoordFromDegrees(degrees, innerRadius, svgSize)}`);
|
|
26
|
-
commands.push(`A ${innerRadius} ${innerRadius} 0 ${longPathFlag} 1 ${svgSize / 2 + innerRadius} ${svgSize / 2}`);
|
|
27
|
-
return commands.join(' ');
|
|
28
|
-
}
|
|
29
|
-
getCoordFromDegrees(angle, radius, svgSize) {
|
|
30
|
-
const x = Math.cos((angle * Math.PI) / 180);
|
|
31
|
-
const y = Math.sin((angle * Math.PI) / 180);
|
|
32
|
-
const coordX = x * radius + svgSize / 2;
|
|
33
|
-
const coordY = y * -radius + svgSize / 2;
|
|
34
|
-
return `${coordX} ${coordY}`;
|
|
35
|
-
}
|
|
36
|
-
percentToDegrees(percent) {
|
|
37
|
-
return percent * 3.6;
|
|
38
|
-
}
|
|
39
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DonutChartPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
40
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: DonutChartPipe, isStandalone: true, name: "slicesWithCommandsAndOffset" }); }
|
|
41
|
-
}
|
|
42
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DonutChartPipe, decorators: [{
|
|
43
|
-
type: Pipe,
|
|
44
|
-
args: [{
|
|
45
|
-
name: 'slicesWithCommandsAndOffset',
|
|
46
|
-
pure: true,
|
|
47
|
-
standalone: true,
|
|
48
|
-
}]
|
|
49
|
-
}] });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9udXQtY2hhcnQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLW1ldGEtd2lkZ2V0cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL2RvbnV0LWNoYXJ0L2RvbnV0LWNoYXJ0LnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBYXBELE1BQU0sT0FBTyxjQUFjO0lBQ3pCLFNBQVMsQ0FBQyxXQUF5QixFQUFFLE1BQWMsRUFBRSxPQUFlLEVBQUUsVUFBa0I7UUFDdEYsSUFBSSxlQUFlLEdBQUcsQ0FBQyxDQUFDO1FBQ3hCLE9BQU8sV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQy9CLHdFQUF3RTtZQUN4RSxLQUFLLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQyxPQUFPLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUM7WUFDL0QsTUFBTSxpQkFBaUIsR0FBMkI7Z0JBQ2hELEdBQUcsS0FBSztnQkFDUixRQUFRLEVBQUUsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsVUFBVSxDQUFDLElBQUk7Z0JBQzFFLE1BQU0sRUFBRSxlQUFlLEdBQUcsR0FBRyxHQUFHLENBQUMsQ0FBQzthQUNuQyxDQUFDO1lBQ0YsZUFBZSxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUM7WUFDakMsT0FBTyxpQkFBaUIsQ0FBQztRQUMzQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxVQUFzQixFQUFFLE1BQWMsRUFBRSxPQUFlLEVBQUUsVUFBa0I7UUFDMUYsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMxRCxNQUFNLFlBQVksR0FBRyxPQUFPLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMzQyxNQUFNLFdBQVcsR0FBRyxNQUFNLEdBQUcsVUFBVSxDQUFDO1FBRXhDLE1BQU0sUUFBUSxHQUFhLEVBQUUsQ0FBQztRQUM5QixRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssT0FBTyxHQUFHLENBQUMsR0FBRyxNQUFNLElBQUksT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDMUQsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLE1BQU0sSUFBSSxNQUFNLE1BQU0sWUFBWSxNQUFNLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNqSCxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzlFLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxXQUFXLElBQUksV0FBVyxNQUFNLFlBQVksTUFBTSxPQUFPLEdBQUcsQ0FBQyxHQUFHLFdBQVcsSUFBSSxPQUFPLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNqSCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVELG1CQUFtQixDQUFDLEtBQWEsRUFBRSxNQUFjLEVBQUUsT0FBZTtRQUNoRSxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQztRQUM1QyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQztRQUM1QyxNQUFNLE1BQU0sR0FBRyxDQUFDLEdBQUcsTUFBTSxHQUFHLE9BQU8sR0FBRyxDQUFDLENBQUM7UUFDeEMsTUFBTSxNQUFNLEdBQUcsQ0FBQyxHQUFHLENBQUMsTUFBTSxHQUFHLE9BQU8sR0FBRyxDQUFDLENBQUM7UUFDekMsT0FBTyxHQUFHLE1BQU0sSUFBSSxNQUFNLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsT0FBZTtRQUM5QixPQUFPLE9BQU8sR0FBRyxHQUFHLENBQUM7SUFDdkIsQ0FBQzsrR0F2Q1UsY0FBYzs2R0FBZCxjQUFjOzs0RkFBZCxjQUFjO2tCQUwxQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSw2QkFBNkI7b0JBQ25DLElBQUksRUFBRSxJQUFJO29CQUNWLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERvbnV0U2xpY2UgfSBmcm9tICcuL2RvbnV0LWNoYXJ0Lm1vZGVsJztcblxuaW50ZXJmYWNlIERvbnV0U2xpY2VXaXRoQ29tbWFuZHMgZXh0ZW5kcyBEb251dFNsaWNlIHtcbiAgb2Zmc2V0OiBudW1iZXI7XG4gIGNvbW1hbmRzOiBzdHJpbmc7XG59XG5cbkBQaXBlKHtcbiAgbmFtZTogJ3NsaWNlc1dpdGhDb21tYW5kc0FuZE9mZnNldCcsXG4gIHB1cmU6IHRydWUsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIERvbnV0Q2hhcnRQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybShkb251dFNsaWNlczogRG9udXRTbGljZVtdLCByYWRpdXM6IG51bWJlciwgc3ZnU2l6ZTogbnVtYmVyLCBib3JkZXJTaXplOiBudW1iZXIpOiBEb251dFNsaWNlV2l0aENvbW1hbmRzW10ge1xuICAgIGxldCBwcmV2aW91c1BlcmNlbnQgPSAwO1xuICAgIHJldHVybiBkb251dFNsaWNlcy5tYXAoKHNsaWNlKSA9PiB7XG4gICAgICAvLyB0aGlzIGlzIGEgaGFjayB0byB0aGF0IHRoZSBjaXJjbGUgaXMgcmVuZGVyZWQgd2hlbiB0aGUgcGVyY2VudCBpcyAxMDBcbiAgICAgIHNsaWNlLnBlcmNlbnQgPSBzbGljZS5wZXJjZW50ID09PSAxMDAgPyA5OS45OTkgOiBzbGljZS5wZXJjZW50O1xuICAgICAgY29uc3Qgc2xpY2VXaXRoQ29tbWFuZHM6IERvbnV0U2xpY2VXaXRoQ29tbWFuZHMgPSB7XG4gICAgICAgIC4uLnNsaWNlLFxuICAgICAgICBjb21tYW5kczogYCR7dGhpcy5nZXRTbGljZUNvbW1hbmRzKHNsaWNlLCByYWRpdXMsIHN2Z1NpemUsIGJvcmRlclNpemUpfSB6YCxcbiAgICAgICAgb2Zmc2V0OiBwcmV2aW91c1BlcmNlbnQgKiAzLjYgKiAtMSxcbiAgICAgIH07XG4gICAgICBwcmV2aW91c1BlcmNlbnQgKz0gc2xpY2UucGVyY2VudDtcbiAgICAgIHJldHVybiBzbGljZVdpdGhDb21tYW5kcztcbiAgICB9KTtcbiAgfVxuXG4gIGdldFNsaWNlQ29tbWFuZHMoZG9udXRTbGljZTogRG9udXRTbGljZSwgcmFkaXVzOiBudW1iZXIsIHN2Z1NpemU6IG51bWJlciwgYm9yZGVyU2l6ZTogbnVtYmVyKTogc3RyaW5nIHtcbiAgICBjb25zdCBkZWdyZWVzID0gdGhpcy5wZXJjZW50VG9EZWdyZWVzKGRvbnV0U2xpY2UucGVyY2VudCk7XG4gICAgY29uc3QgbG9uZ1BhdGhGbGFnID0gZGVncmVlcyA+IDE4MCA/IDEgOiAwO1xuICAgIGNvbnN0IGlubmVyUmFkaXVzID0gcmFkaXVzIC0gYm9yZGVyU2l6ZTtcblxuICAgIGNvbnN0IGNvbW1hbmRzOiBzdHJpbmdbXSA9IFtdO1xuICAgIGNvbW1hbmRzLnB1c2goYE0gJHtzdmdTaXplIC8gMiArIHJhZGl1c30gJHtzdmdTaXplIC8gMn1gKTtcbiAgICBjb21tYW5kcy5wdXNoKGBBICR7cmFkaXVzfSAke3JhZGl1c30gMCAke2xvbmdQYXRoRmxhZ30gMCAke3RoaXMuZ2V0Q29vcmRGcm9tRGVncmVlcyhkZWdyZWVzLCByYWRpdXMsIHN2Z1NpemUpfWApO1xuICAgIGNvbW1hbmRzLnB1c2goYEwgJHt0aGlzLmdldENvb3JkRnJvbURlZ3JlZXMoZGVncmVlcywgaW5uZXJSYWRpdXMsIHN2Z1NpemUpfWApO1xuICAgIGNvbW1hbmRzLnB1c2goYEEgJHtpbm5lclJhZGl1c30gJHtpbm5lclJhZGl1c30gMCAke2xvbmdQYXRoRmxhZ30gMSAke3N2Z1NpemUgLyAyICsgaW5uZXJSYWRpdXN9ICR7c3ZnU2l6ZSAvIDJ9YCk7XG4gICAgcmV0dXJuIGNvbW1hbmRzLmpvaW4oJyAnKTtcbiAgfVxuXG4gIGdldENvb3JkRnJvbURlZ3JlZXMoYW5nbGU6IG51bWJlciwgcmFkaXVzOiBudW1iZXIsIHN2Z1NpemU6IG51bWJlcik6IHN0cmluZyB7XG4gICAgY29uc3QgeCA9IE1hdGguY29zKChhbmdsZSAqIE1hdGguUEkpIC8gMTgwKTtcbiAgICBjb25zdCB5ID0gTWF0aC5zaW4oKGFuZ2xlICogTWF0aC5QSSkgLyAxODApO1xuICAgIGNvbnN0IGNvb3JkWCA9IHggKiByYWRpdXMgKyBzdmdTaXplIC8gMjtcbiAgICBjb25zdCBjb29yZFkgPSB5ICogLXJhZGl1cyArIHN2Z1NpemUgLyAyO1xuICAgIHJldHVybiBgJHtjb29yZFh9ICR7Y29vcmRZfWA7XG4gIH1cblxuICBwZXJjZW50VG9EZWdyZWVzKHBlcmNlbnQ6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIHBlcmNlbnQgKiAzLjY7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import { Component, HostBinding, inject } from '@angular/core';
|
|
2
|
-
import { TOOLTIP_DATA } from '../../core/tooltip.service';
|
|
3
|
-
import { animate, style, transition, trigger } from '@angular/animations';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/common";
|
|
6
|
-
import * as i2 from "../donut-chart/donut-chart.component";
|
|
7
|
-
export function transformDonutChartData(data) {
|
|
8
|
-
return data.map((slice) => [
|
|
9
|
-
// inverted order is necessary for the donut chart to go clockwise
|
|
10
|
-
{
|
|
11
|
-
percent: 100 - slice.percent,
|
|
12
|
-
color: 'transparent',
|
|
13
|
-
id: 999999,
|
|
14
|
-
},
|
|
15
|
-
slice,
|
|
16
|
-
]);
|
|
17
|
-
}
|
|
18
|
-
export class DonutChartTooltipComponent {
|
|
19
|
-
constructor() {
|
|
20
|
-
this.animationState = true;
|
|
21
|
-
this.data = inject(TOOLTIP_DATA);
|
|
22
|
-
}
|
|
23
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DonutChartTooltipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
24
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DonutChartTooltipComponent, selector: "metaqs2-donut-chart-tooltip", host: { properties: { "@fadeInOut": "this.animationState" } }, ngImport: i0, template: "<h4>{{ data.label }}</h4>\n<p>Status</p>\n<ng-container *ngFor=\"let slicePair of data.data\">\n <ng-container *ngIf=\"slicePair[1].percent > 0\">\n <div style=\"display: flex; justify-content: flex-start; align-items: center; gap: 0.25rem\">\n <metaqs2-donut-chart [data]=\"slicePair\" [borderSize]=\"25\"></metaqs2-donut-chart>\n <p>{{ slicePair[1].verboseLabel }}</p>\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;margin:1rem}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DonutChartComponent, selector: "metaqs2-donut-chart", inputs: ["radius", "viewBox", "borderSize", "strokeWidth", "data"] }], animations: [
|
|
25
|
-
trigger('fadeInOut', [
|
|
26
|
-
transition(':enter', [
|
|
27
|
-
style({
|
|
28
|
-
opacity: 0,
|
|
29
|
-
scale: 0.5,
|
|
30
|
-
}),
|
|
31
|
-
animate('100ms ease-in', style({
|
|
32
|
-
opacity: 1,
|
|
33
|
-
scale: 1,
|
|
34
|
-
})),
|
|
35
|
-
]),
|
|
36
|
-
transition(':leave', [
|
|
37
|
-
style({
|
|
38
|
-
opacity: 1,
|
|
39
|
-
scale: 1,
|
|
40
|
-
}),
|
|
41
|
-
animate('100ms ease-out', style({
|
|
42
|
-
opacity: 0,
|
|
43
|
-
scale: 0.5,
|
|
44
|
-
})),
|
|
45
|
-
]),
|
|
46
|
-
]),
|
|
47
|
-
] }); }
|
|
48
|
-
}
|
|
49
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DonutChartTooltipComponent, decorators: [{
|
|
50
|
-
type: Component,
|
|
51
|
-
args: [{ selector: 'metaqs2-donut-chart-tooltip', animations: [
|
|
52
|
-
trigger('fadeInOut', [
|
|
53
|
-
transition(':enter', [
|
|
54
|
-
style({
|
|
55
|
-
opacity: 0,
|
|
56
|
-
scale: 0.5,
|
|
57
|
-
}),
|
|
58
|
-
animate('100ms ease-in', style({
|
|
59
|
-
opacity: 1,
|
|
60
|
-
scale: 1,
|
|
61
|
-
})),
|
|
62
|
-
]),
|
|
63
|
-
transition(':leave', [
|
|
64
|
-
style({
|
|
65
|
-
opacity: 1,
|
|
66
|
-
scale: 1,
|
|
67
|
-
}),
|
|
68
|
-
animate('100ms ease-out', style({
|
|
69
|
-
opacity: 0,
|
|
70
|
-
scale: 0.5,
|
|
71
|
-
})),
|
|
72
|
-
]),
|
|
73
|
-
]),
|
|
74
|
-
], template: "<h4>{{ data.label }}</h4>\n<p>Status</p>\n<ng-container *ngFor=\"let slicePair of data.data\">\n <ng-container *ngIf=\"slicePair[1].percent > 0\">\n <div style=\"display: flex; justify-content: flex-start; align-items: center; gap: 0.25rem\">\n <metaqs2-donut-chart [data]=\"slicePair\" [borderSize]=\"25\"></metaqs2-donut-chart>\n <p>{{ slicePair[1].verboseLabel }}</p>\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;margin:1rem}\n"] }]
|
|
75
|
-
}], propDecorators: { animationState: [{
|
|
76
|
-
type: HostBinding,
|
|
77
|
-
args: ['@fadeInOut']
|
|
78
|
-
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9udXQtY2hhcnQtdG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1tZXRhLXdpZGdldHMtbGliL3NyYy9saWIvY29tcG9uZW50cy9kb251dC1jaGFydC10b29sdGlwL2RvbnV0LWNoYXJ0LXRvb2x0aXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctbWV0YS13aWRnZXRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvZG9udXQtY2hhcnQtdG9vbHRpcC9kb251dC1jaGFydC10b29sdGlwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvRCxPQUFPLEVBQWUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkUsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7O0FBTzFFLE1BQU0sVUFBVSx1QkFBdUIsQ0FBQyxJQUFrQjtJQUN4RCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQTRCLEVBQUUsQ0FBQztRQUNuRCxrRUFBa0U7UUFDbEU7WUFDRSxPQUFPLEVBQUUsR0FBRyxHQUFHLEtBQUssQ0FBQyxPQUFPO1lBQzVCLEtBQUssRUFBRSxhQUFhO1lBQ3BCLEVBQUUsRUFBRSxNQUFNO1NBQ1g7UUFDRCxLQUFLO0tBQ04sQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQXFDRCxNQUFNLE9BQU8sMEJBQTBCO0lBbkN2QztRQW9DNkIsbUJBQWMsR0FBRyxJQUFJLENBQUM7UUFDakMsU0FBSSxHQUFHLE1BQU0sQ0FBd0IsWUFBWSxDQUFDLENBQUM7S0FDcEU7K0dBSFksMEJBQTBCO21HQUExQiwwQkFBMEIsa0lDekR2QyxvYkFVQSw2Z0JEZ0JjO1lBQ1YsT0FBTyxDQUFDLFdBQVcsRUFBRTtnQkFDbkIsVUFBVSxDQUFDLFFBQVEsRUFBRTtvQkFDbkIsS0FBSyxDQUFDO3dCQUNKLE9BQU8sRUFBRSxDQUFDO3dCQUNWLEtBQUssRUFBRSxHQUFHO3FCQUNYLENBQUM7b0JBQ0YsT0FBTyxDQUNMLGVBQWUsRUFDZixLQUFLLENBQUM7d0JBQ0osT0FBTyxFQUFFLENBQUM7d0JBQ1YsS0FBSyxFQUFFLENBQUM7cUJBQ1QsQ0FBQyxDQUNIO2lCQUNGLENBQUM7Z0JBQ0YsVUFBVSxDQUFDLFFBQVEsRUFBRTtvQkFDbkIsS0FBSyxDQUFDO3dCQUNKLE9BQU8sRUFBRSxDQUFDO3dCQUNWLEtBQUssRUFBRSxDQUFDO3FCQUNULENBQUM7b0JBQ0YsT0FBTyxDQUNMLGdCQUFnQixFQUNoQixLQUFLLENBQUM7d0JBQ0osT0FBTyxFQUFFLENBQUM7d0JBQ1YsS0FBSyxFQUFFLEdBQUc7cUJBQ1gsQ0FBQyxDQUNIO2lCQUNGLENBQUM7YUFDSCxDQUFDO1NBQ0g7OzRGQUVVLDBCQUEwQjtrQkFuQ3RDLFNBQVM7K0JBQ0UsNkJBQTZCLGNBRzNCO3dCQUNWLE9BQU8sQ0FBQyxXQUFXLEVBQUU7NEJBQ25CLFVBQVUsQ0FBQyxRQUFRLEVBQUU7Z0NBQ25CLEtBQUssQ0FBQztvQ0FDSixPQUFPLEVBQUUsQ0FBQztvQ0FDVixLQUFLLEVBQUUsR0FBRztpQ0FDWCxDQUFDO2dDQUNGLE9BQU8sQ0FDTCxlQUFlLEVBQ2YsS0FBSyxDQUFDO29DQUNKLE9BQU8sRUFBRSxDQUFDO29DQUNWLEtBQUssRUFBRSxDQUFDO2lDQUNULENBQUMsQ0FDSDs2QkFDRixDQUFDOzRCQUNGLFVBQVUsQ0FBQyxRQUFRLEVBQUU7Z0NBQ25CLEtBQUssQ0FBQztvQ0FDSixPQUFPLEVBQUUsQ0FBQztvQ0FDVixLQUFLLEVBQUUsQ0FBQztpQ0FDVCxDQUFDO2dDQUNGLE9BQU8sQ0FDTCxnQkFBZ0IsRUFDaEIsS0FBSyxDQUFDO29DQUNKLE9BQU8sRUFBRSxDQUFDO29DQUNWLEtBQUssRUFBRSxHQUFHO2lDQUNYLENBQUMsQ0FDSDs2QkFDRixDQUFDO3lCQUNILENBQUM7cUJBQ0g7OEJBRzBCLGNBQWM7c0JBQXhDLFdBQVc7dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRG9udXRTbGljZSB9IGZyb20gJy4uL2RvbnV0LWNoYXJ0L2RvbnV0LWNoYXJ0Lm1vZGVsJztcbmltcG9ydCB7IERhdGFUb29sdGlwLCBUT09MVElQX0RBVEEgfSBmcm9tICcuLi8uLi9jb3JlL3Rvb2x0aXAuc2VydmljZSc7XG5pbXBvcnQgeyBhbmltYXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERvbnV0Q2hhcnRUb29sdGlwRGF0YSB7XG4gIGRhdGE6IEFycmF5PFtEb251dFNsaWNlLCBEb251dFNsaWNlXT47XG4gIGxhYmVsOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0cmFuc2Zvcm1Eb251dENoYXJ0RGF0YShkYXRhOiBEb251dFNsaWNlW10pOiBBcnJheTxbRG9udXRTbGljZSwgRG9udXRTbGljZV0+IHtcbiAgcmV0dXJuIGRhdGEubWFwKChzbGljZSk6IFtEb251dFNsaWNlLCBEb251dFNsaWNlXSA9PiBbXG4gICAgLy8gaW52ZXJ0ZWQgb3JkZXIgaXMgbmVjZXNzYXJ5IGZvciB0aGUgZG9udXQgY2hhcnQgdG8gZ28gY2xvY2t3aXNlXG4gICAge1xuICAgICAgcGVyY2VudDogMTAwIC0gc2xpY2UucGVyY2VudCxcbiAgICAgIGNvbG9yOiAndHJhbnNwYXJlbnQnLFxuICAgICAgaWQ6IDk5OTk5OSxcbiAgICB9LFxuICAgIHNsaWNlLFxuICBdKTtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbWV0YXFzMi1kb251dC1jaGFydC10b29sdGlwJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RvbnV0LWNoYXJ0LXRvb2x0aXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vZG9udXQtY2hhcnQtdG9vbHRpcC5jb21wb25lbnQuY3NzJyxcbiAgYW5pbWF0aW9uczogW1xuICAgIHRyaWdnZXIoJ2ZhZGVJbk91dCcsIFtcbiAgICAgIHRyYW5zaXRpb24oJzplbnRlcicsIFtcbiAgICAgICAgc3R5bGUoe1xuICAgICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgICAgc2NhbGU6IDAuNSxcbiAgICAgICAgfSksXG4gICAgICAgIGFuaW1hdGUoXG4gICAgICAgICAgJzEwMG1zIGVhc2UtaW4nLFxuICAgICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAgIG9wYWNpdHk6IDEsXG4gICAgICAgICAgICBzY2FsZTogMSxcbiAgICAgICAgICB9KVxuICAgICAgICApLFxuICAgICAgXSksXG4gICAgICB0cmFuc2l0aW9uKCc6bGVhdmUnLCBbXG4gICAgICAgIHN0eWxlKHtcbiAgICAgICAgICBvcGFjaXR5OiAxLFxuICAgICAgICAgIHNjYWxlOiAxLFxuICAgICAgICB9KSxcbiAgICAgICAgYW5pbWF0ZShcbiAgICAgICAgICAnMTAwbXMgZWFzZS1vdXQnLFxuICAgICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgICAgICBzY2FsZTogMC41LFxuICAgICAgICAgIH0pXG4gICAgICAgICksXG4gICAgICBdKSxcbiAgICBdKSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRG9udXRDaGFydFRvb2x0aXBDb21wb25lbnQgaW1wbGVtZW50cyBEYXRhVG9vbHRpcDxEb251dENoYXJ0VG9vbHRpcERhdGE+IHtcbiAgQEhvc3RCaW5kaW5nKCdAZmFkZUluT3V0JykgYW5pbWF0aW9uU3RhdGUgPSB0cnVlO1xuICBwdWJsaWMgcmVhZG9ubHkgZGF0YSA9IGluamVjdDxEb251dENoYXJ0VG9vbHRpcERhdGE+KFRPT0xUSVBfREFUQSk7XG59XG4iLCI8aDQ+e3sgZGF0YS5sYWJlbCB9fTwvaDQ+XG48cD5TdGF0dXM8L3A+XG48bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBzbGljZVBhaXIgb2YgZGF0YS5kYXRhXCI+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJzbGljZVBhaXJbMV0ucGVyY2VudCA+IDBcIj5cbiAgICA8ZGl2IHN0eWxlPVwiZGlzcGxheTogZmxleDsganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0OyBhbGlnbi1pdGVtczogY2VudGVyOyBnYXA6IDAuMjVyZW1cIj5cbiAgICAgIDxtZXRhcXMyLWRvbnV0LWNoYXJ0IFtkYXRhXT1cInNsaWNlUGFpclwiIFtib3JkZXJTaXplXT1cIjI1XCI+PC9tZXRhcXMyLWRvbnV0LWNoYXJ0PlxuICAgICAgPHA+e3sgc2xpY2VQYWlyWzFdLnZlcmJvc2VMYWJlbCB9fTwvcD5cbiAgICA8L2Rpdj5cbiAgPC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -1,169 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { inject } from '@angular/core';
|
|
3
|
-
import { ConfigHelperService } from '../../config-helper.service';
|
|
4
|
-
import { MetaApiService } from '../../meta-api.service';
|
|
5
|
-
import { BehaviorSubject } from 'rxjs';
|
|
6
|
-
import { take } from 'rxjs/operators';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
/**
|
|
9
|
-
* This service provides methods to create links to the editorial desk with specific filters.
|
|
10
|
-
*/
|
|
11
|
-
/* This map makes it easier for me to keep track which issues are mapped to which filters */
|
|
12
|
-
const FilterNames2Issues = {
|
|
13
|
-
//Lizenzen
|
|
14
|
-
'virtual:editorial_license': ['oer', 'other_cc', 'copyright', 'without_license'],
|
|
15
|
-
//Materialtypen werden im Constructor gesetzt
|
|
16
|
-
'virtual:oeh_lrt': [],
|
|
17
|
-
'virtual:editorial_exclusion': [
|
|
18
|
-
'outdated',
|
|
19
|
-
'without_preview',
|
|
20
|
-
'without_title',
|
|
21
|
-
'without_description',
|
|
22
|
-
'without_url',
|
|
23
|
-
'without_type',
|
|
24
|
-
'without_taxonomy_id',
|
|
25
|
-
'without_education_level',
|
|
26
|
-
'without_target_group',
|
|
27
|
-
'without_license',
|
|
28
|
-
'without_publisher',
|
|
29
|
-
],
|
|
30
|
-
};
|
|
31
|
-
// Here we map back the issues to the filter names in the editorial desk, so we can look up the filter name for a given issue
|
|
32
|
-
const Issues2FilterNames = Object.entries(FilterNames2Issues).reduce((map, [key, value]) => {
|
|
33
|
-
value.forEach((issue) => map.set(issue, key));
|
|
34
|
-
return map;
|
|
35
|
-
}, new Map());
|
|
36
|
-
// maps our values to the values of the filter in the editorial desk
|
|
37
|
-
const MapValuesForFilter = {
|
|
38
|
-
'virtual:editorial_exclusion': {
|
|
39
|
-
outdated: null,
|
|
40
|
-
without_preview: null,
|
|
41
|
-
without_title: ['missing_title'],
|
|
42
|
-
without_description: ['missing_description'],
|
|
43
|
-
without_url: ['links'],
|
|
44
|
-
without_type: ['missing_oeh_lrt'],
|
|
45
|
-
without_taxonomy_id: ['without_taxonomy_id'],
|
|
46
|
-
without_education_level: ['missing_educationalcontext'],
|
|
47
|
-
without_target_group: ['missing_educationalintendedenduserrole'],
|
|
48
|
-
without_license: ['missing_license'],
|
|
49
|
-
without_publisher: ['missing_replicationsource'],
|
|
50
|
-
},
|
|
51
|
-
'virtual:editorial_license': {
|
|
52
|
-
oer: ['oer'],
|
|
53
|
-
copyright: ['none_oer'],
|
|
54
|
-
without_license: ['none'],
|
|
55
|
-
},
|
|
56
|
-
'virtual:oeh_lrt': {},
|
|
57
|
-
};
|
|
58
|
-
/*
|
|
59
|
-
This is a map from properties of a document to filter names
|
|
60
|
-
*/
|
|
61
|
-
const PROPERTIES2FILTERS = new Map([
|
|
62
|
-
['metadata.educationalContexts', 'ccm:educationalcontext'],
|
|
63
|
-
['metadata.disciplines', 'virtual:taxonid'],
|
|
64
|
-
//["responsibility", "virtual:collection_id_primary"] // das zeigt auf "sammlungszugehörigkeit" und ist falsch
|
|
65
|
-
]);
|
|
66
|
-
export class EditorialLinkService {
|
|
67
|
-
constructor() {
|
|
68
|
-
this.env = inject(ConfigHelperService);
|
|
69
|
-
this.api = inject(MetaApiService);
|
|
70
|
-
this.typesLoaded$ = new BehaviorSubject(false);
|
|
71
|
-
this.api
|
|
72
|
-
.getMaterialTypesMapping()
|
|
73
|
-
.pipe(take(1))
|
|
74
|
-
.subscribe((types) => {
|
|
75
|
-
for (const [key, value] of Object.entries(types)) {
|
|
76
|
-
Issues2FilterNames.set(key, 'virtual:oeh_lrt');
|
|
77
|
-
MapValuesForFilter['virtual:oeh_lrt'][key] = value;
|
|
78
|
-
}
|
|
79
|
-
this.typesLoaded$.next(true);
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
openByReplicationsourceAndIssueTypeWithFilters(source, issue, selectedFilters) {
|
|
83
|
-
const filters = {};
|
|
84
|
-
filters['virtual:audit_filter'] = ['all'];
|
|
85
|
-
filters['ccm:oeh_publisher_combined'] = [source];
|
|
86
|
-
filters['virtual:editorial_exclusion'] = MapValuesForFilter['virtual:editorial_exclusion'][issue];
|
|
87
|
-
for (const [field, values] of Object.entries(selectedFilters)) {
|
|
88
|
-
if (values && values.length) {
|
|
89
|
-
const editorialFiltername = PROPERTIES2FILTERS.get(field);
|
|
90
|
-
filters[editorialFiltername] = values;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
const theUrl = this.env.eduSharingPath + '/components/editorial-desk';
|
|
94
|
-
const params = new URLSearchParams();
|
|
95
|
-
params.set('mode', 'audit');
|
|
96
|
-
params.set('filters', JSON.stringify(filters));
|
|
97
|
-
window.open(`${theUrl}?${params}`, 'editor_frontend');
|
|
98
|
-
}
|
|
99
|
-
openByCollectionAndIssueType(collectionId, issueType, pageTitle) {
|
|
100
|
-
const filters = {};
|
|
101
|
-
filters['virtual:audit_filter'] = ['all'];
|
|
102
|
-
filters['virtual:editorial_exclusion'] = MapValuesForFilter['virtual:editorial_exclusion'][issueType];
|
|
103
|
-
filters['virtual:collection_id_primary'] = [collectionId];
|
|
104
|
-
const theUrl = this.env.eduSharingPath + '/components/editorial-desk';
|
|
105
|
-
const params = new URLSearchParams();
|
|
106
|
-
params.set('title', pageTitle);
|
|
107
|
-
params.set('mode', 'audit');
|
|
108
|
-
// this provides information to the editorial desk that any global group filter needs to be reset for this query
|
|
109
|
-
params.set('resetGroup', 'true');
|
|
110
|
-
params.set('filters', JSON.stringify(filters));
|
|
111
|
-
window.open(`${theUrl}?${params}`, 'editor_frontend');
|
|
112
|
-
}
|
|
113
|
-
openByCollectionId(collectionId) {
|
|
114
|
-
const theUrl = this.env.eduSharingPath + '/components/editorial-desk';
|
|
115
|
-
const params = new URLSearchParams();
|
|
116
|
-
params.set('ids', collectionId);
|
|
117
|
-
params.set('mode', 'render');
|
|
118
|
-
window.open(`${theUrl}?${params}`, 'editor_frontend');
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* This method creates a link to the editorial desk with specific filters.
|
|
122
|
-
* It returns the URL to the editorial desk with the filters applied or null if the issueId is not mapped to a filter.
|
|
123
|
-
* With this we can render a link with an href attribute to the editorial desk in the frontend.
|
|
124
|
-
* @see the counts-with-history.component.scss how we style links only if their hrefs are not null
|
|
125
|
-
*
|
|
126
|
-
* @param sourceType The type of the source, e.g. "replicationSource" or "collection"
|
|
127
|
-
* @param sourceId The id of the source. This is the first column in the table.
|
|
128
|
-
* @param issueId The id of the issue. These are the other columns in the table.
|
|
129
|
-
*/
|
|
130
|
-
createLinkForCountsWithHistory(sourceType, sourceId, issueId) {
|
|
131
|
-
const filters = {};
|
|
132
|
-
filters['virtual:audit_filter'] = ['all'];
|
|
133
|
-
// determine the "main" filter
|
|
134
|
-
if (sourceType === 'replicationSource') {
|
|
135
|
-
filters['ccm:oeh_publisher_combined'] = [sourceId];
|
|
136
|
-
}
|
|
137
|
-
else if (sourceType === 'collection') {
|
|
138
|
-
filters['virtual:collection_id_primary'] = [sourceId];
|
|
139
|
-
}
|
|
140
|
-
if (!Issues2FilterNames.has(issueId)) {
|
|
141
|
-
return null;
|
|
142
|
-
}
|
|
143
|
-
const filterName = Issues2FilterNames.get(issueId);
|
|
144
|
-
if (!filterName) {
|
|
145
|
-
// console.debug("No filter name found for issue id: " + issueId);
|
|
146
|
-
return null;
|
|
147
|
-
}
|
|
148
|
-
const filterValue = MapValuesForFilter[filterName][issueId];
|
|
149
|
-
if (!filterValue) {
|
|
150
|
-
// console.debug("No filter value found for issue id: " + issueId);
|
|
151
|
-
return null;
|
|
152
|
-
}
|
|
153
|
-
filters[filterName] = filterValue;
|
|
154
|
-
const theUrl = this.env.eduSharingPath + '/components/editorial-desk';
|
|
155
|
-
const params = new URLSearchParams();
|
|
156
|
-
params.set('mode', 'audit');
|
|
157
|
-
params.set('filters', JSON.stringify(filters));
|
|
158
|
-
return `${theUrl}?${params}`;
|
|
159
|
-
}
|
|
160
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EditorialLinkService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
161
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EditorialLinkService, providedIn: 'root' }); }
|
|
162
|
-
}
|
|
163
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EditorialLinkService, decorators: [{
|
|
164
|
-
type: Injectable,
|
|
165
|
-
args: [{
|
|
166
|
-
providedIn: 'root',
|
|
167
|
-
}]
|
|
168
|
-
}], ctorParameters: () => [] });
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editorial-link.service.js","sourceRoot":"","sources":["../../../../../../projects/ng-meta-widgets-lib/src/lib/components/editorial-link-service/editorial-link.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { inject } from '@angular/core';\nimport { ConfigHelperService } from '../../config-helper.service';\nimport { MetaApiService } from '../../meta-api.service';\nimport { BehaviorSubject } from 'rxjs';\nimport { take } from 'rxjs/operators';\n\n/**\n * This service provides methods to create links to the editorial desk with specific filters.\n */\n/*  This map makes it easier for me to keep track which issues are mapped to which filters */\nconst FilterNames2Issues: { [key: string]: string[] } = {\n  //Lizenzen\n  'virtual:editorial_license': ['oer', 'other_cc', 'copyright', 'without_license'],\n  //Materialtypen werden im Constructor gesetzt\n  'virtual:oeh_lrt': [],\n  'virtual:editorial_exclusion': [\n    'outdated',\n    'without_preview',\n    'without_title',\n    'without_description',\n    'without_url',\n    'without_type',\n    'without_taxonomy_id',\n    'without_education_level',\n    'without_target_group',\n    'without_license',\n    'without_publisher',\n  ],\n};\n// Here we map back the issues to the filter names in the editorial desk, so we can look up the filter name for a given issue\nconst Issues2FilterNames: Map<string, string> = Object.entries(FilterNames2Issues).reduce((map, [key, value]) => {\n  value.forEach((issue) => map.set(issue, key));\n  return map;\n}, new Map<string, string>());\n\n// maps our values to the values of the filter in the editorial desk\nconst MapValuesForFilter: { [key: string]: { [key: string]: string[] | null } } = {\n  'virtual:editorial_exclusion': {\n    outdated: null,\n    without_preview: null,\n    without_title: ['missing_title'],\n    without_description: ['missing_description'],\n    without_url: ['links'],\n    without_type: ['missing_oeh_lrt'],\n    without_taxonomy_id: ['without_taxonomy_id'],\n    without_education_level: ['missing_educationalcontext'],\n    without_target_group: ['missing_educationalintendedenduserrole'],\n    without_license: ['missing_license'],\n    without_publisher: ['missing_replicationsource'],\n  },\n  'virtual:editorial_license': {\n    oer: ['oer'],\n    copyright: ['none_oer'],\n    without_license: ['none'],\n  },\n  'virtual:oeh_lrt': {},\n};\n\n/*\nThis is a map from properties of a document to filter names\n */\nconst PROPERTIES2FILTERS = new Map<string, string>([\n  ['metadata.educationalContexts', 'ccm:educationalcontext'],\n  ['metadata.disciplines', 'virtual:taxonid'],\n  //[\"responsibility\", \"virtual:collection_id_primary\"] // das zeigt auf \"sammlungszugehörigkeit\" und ist falsch\n]);\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class EditorialLinkService {\n  private env = inject(ConfigHelperService);\n  private api = inject(MetaApiService);\n  public typesLoaded$ = new BehaviorSubject(false);\n\n  constructor() {\n    this.api\n      .getMaterialTypesMapping()\n      .pipe(take(1))\n      .subscribe((types) => {\n        for (const [key, value] of Object.entries(types)) {\n          Issues2FilterNames.set(key, 'virtual:oeh_lrt');\n          MapValuesForFilter['virtual:oeh_lrt'][key] = value;\n        }\n        this.typesLoaded$.next(true);\n      });\n  }\n\n  public openByReplicationsourceAndIssueTypeWithFilters(\n    source: string,\n    issue: string,\n    selectedFilters: { [key: string]: string[] | undefined }\n  ): void {\n    const filters: any = {};\n    filters['virtual:audit_filter'] = ['all'];\n    filters['ccm:oeh_publisher_combined'] = [source];\n    filters['virtual:editorial_exclusion'] = MapValuesForFilter['virtual:editorial_exclusion'][issue];\n    for (const [field, values] of Object.entries(selectedFilters)) {\n      if (values && values.length) {\n        const editorialFiltername = PROPERTIES2FILTERS.get(field) as string;\n        filters[editorialFiltername] = values;\n      }\n    }\n\n    const theUrl: string = this.env.eduSharingPath + '/components/editorial-desk';\n    const params = new URLSearchParams();\n    params.set('mode', 'audit');\n    params.set('filters', JSON.stringify(filters));\n    window.open(`${theUrl}?${params}`, 'editor_frontend');\n  }\n\n  public openByCollectionAndIssueType(collectionId: string, issueType: string, pageTitle: string): void {\n    const filters: any = {};\n    filters['virtual:audit_filter'] = ['all'];\n    filters['virtual:editorial_exclusion'] = MapValuesForFilter['virtual:editorial_exclusion'][issueType];\n    filters['virtual:collection_id_primary'] = [collectionId];\n    const theUrl: string = this.env.eduSharingPath + '/components/editorial-desk';\n    const params = new URLSearchParams();\n    params.set('title', pageTitle);\n    params.set('mode', 'audit');\n    // this provides information to the editorial desk that any global group filter needs to be reset for this query\n    params.set('resetGroup', 'true');\n    params.set('filters', JSON.stringify(filters));\n    window.open(`${theUrl}?${params}`, 'editor_frontend');\n  }\n\n  public openByCollectionId(collectionId: string): void {\n    const theUrl: string = this.env.eduSharingPath + '/components/editorial-desk';\n    const params = new URLSearchParams();\n    params.set('ids', collectionId);\n    params.set('mode', 'render');\n    window.open(`${theUrl}?${params}`, 'editor_frontend');\n  }\n\n  /**\n   * This method creates a link to the editorial desk with specific filters.\n   * It returns the URL to the editorial desk with the filters applied or null if the issueId is not mapped to a filter.\n   * With this we can render a link with an href attribute to the editorial desk in the frontend.\n   * @see the counts-with-history.component.scss how we style links only if their hrefs are not null\n   *\n   * @param sourceType The type of the source, e.g. \"replicationSource\" or \"collection\"\n   * @param sourceId The id of the source. This is the first column in the table.\n   * @param issueId The id of the issue. These are the other columns in the table.\n   */\n  public createLinkForCountsWithHistory(sourceType: string, sourceId: string, issueId: string): string | null {\n    const filters: { [key: string]: string[] } = {};\n    filters['virtual:audit_filter'] = ['all'];\n    // determine the \"main\" filter\n    if (sourceType === 'replicationSource') {\n      filters['ccm:oeh_publisher_combined'] = [sourceId];\n    } else if (sourceType === 'collection') {\n      filters['virtual:collection_id_primary'] = [sourceId];\n    }\n    if (!Issues2FilterNames.has(issueId)) {\n      return null;\n    }\n    const filterName = Issues2FilterNames.get(issueId);\n    if (!filterName) {\n      // console.debug(\"No filter name found for issue id: \" + issueId);\n      return null;\n    }\n    const filterValue = MapValuesForFilter[filterName][issueId];\n    if (!filterValue) {\n      // console.debug(\"No filter value found for issue id: \" + issueId);\n      return null;\n    }\n    filters[filterName] = filterValue;\n\n    const theUrl: string = this.env.eduSharingPath + '/components/editorial-desk';\n    const params = new URLSearchParams();\n    params.set('mode', 'audit');\n    params.set('filters', JSON.stringify(filters));\n    return `${theUrl}?${params}`;\n  }\n}\n"]}
|
|
@@ -1,99 +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
|
-
const datePickerFormats = {
|
|
11
|
-
parse: {
|
|
12
|
-
dateInput: 'D',
|
|
13
|
-
},
|
|
14
|
-
display: {
|
|
15
|
-
dateInput: 'D',
|
|
16
|
-
monthYearLabel: 'MMMM yyyy',
|
|
17
|
-
dateA11yLabel: 'DDD',
|
|
18
|
-
monthYearA11yLabel: 'MMMM yyyy',
|
|
19
|
-
},
|
|
20
|
-
};
|
|
21
|
-
export class DatepickerComponent {
|
|
22
|
-
constructor() {
|
|
23
|
-
this.disabled = false;
|
|
24
|
-
}
|
|
25
|
-
ngOnInit() {
|
|
26
|
-
this.focus();
|
|
27
|
-
}
|
|
28
|
-
ngOnDestroy() {
|
|
29
|
-
//defer this to avoid an ExpressionChangedAfterItHasBeenCheckedError on the parent component
|
|
30
|
-
Promise.resolve().then(() => this.inputGroup.reset());
|
|
31
|
-
}
|
|
32
|
-
focus() {
|
|
33
|
-
this.start?.nativeElement.focus();
|
|
34
|
-
this.ripple.launch({
|
|
35
|
-
centered: true, // Angular Material bug: disabled ripples do not trigger unless centered
|
|
36
|
-
radius: 1000,
|
|
37
|
-
animation: {
|
|
38
|
-
exitDuration: 1000,
|
|
39
|
-
},
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
43
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DatepickerComponent, isStandalone: true, selector: "metaqs2-datepicker", inputs: { disabled: "disabled", inputGroup: "inputGroup" }, providers: [
|
|
44
|
-
{
|
|
45
|
-
provide: DateAdapter,
|
|
46
|
-
useClass: LuxonDateAdapter,
|
|
47
|
-
deps: [MAT_DATE_LOCALE, MAT_LUXON_DATE_ADAPTER_OPTIONS],
|
|
48
|
-
},
|
|
49
|
-
{ provide: MAT_DATE_FORMATS, useValue: datePickerFormats },
|
|
50
|
-
//provideLuxonDateAdapter(datePickerFormats),
|
|
51
|
-
{ provide: LOCALE_ID, useValue: 'de-DE' },
|
|
52
|
-
{ provide: MAT_DATE_LOCALE, useValue: 'de-DE' },
|
|
53
|
-
{ provide: MAT_LUXON_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true, firstDayOfWeek: 1 } },
|
|
54
|
-
], 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: "<div [formGroup]=\"inputGroup\" matRipple #ripple=\"matRipple\" [matRippleDisabled]=\"true\">\n <!-- start date -->\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 <!--\n <mat-hint>d.M.yyyy</mat-hint>\n -->\n <mat-datepicker-toggle matIconSuffix [for]=\"picker1\"></mat-datepicker-toggle>\n <mat-datepicker [disabled]=\"disabled\" #picker1 [startAt]=\"inputGroup.controls.start.defaultValue\">\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 <!--\n <mat-hint>d.M.yyyy</mat-hint>\n -->\n <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n <mat-datepicker [disabled]=\"disabled\" #picker2 [startAt]=\"inputGroup.controls.end.value\">\n </mat-datepicker>\n </mat-form-field>\n <!-- /end date -->\n</div>\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"] }] }); }
|
|
55
|
-
}
|
|
56
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatepickerComponent, decorators: [{
|
|
57
|
-
type: Component,
|
|
58
|
-
args: [{ selector: 'metaqs2-datepicker', standalone: true, imports: [
|
|
59
|
-
FormsModule,
|
|
60
|
-
MatDatepicker,
|
|
61
|
-
MatDatepickerInput,
|
|
62
|
-
MatDatepickerToggle,
|
|
63
|
-
MatFormField,
|
|
64
|
-
MatInput,
|
|
65
|
-
MatLabel,
|
|
66
|
-
MatSuffix,
|
|
67
|
-
ReactiveFormsModule,
|
|
68
|
-
MatRipple,
|
|
69
|
-
], providers: [
|
|
70
|
-
{
|
|
71
|
-
provide: DateAdapter,
|
|
72
|
-
useClass: LuxonDateAdapter,
|
|
73
|
-
deps: [MAT_DATE_LOCALE, MAT_LUXON_DATE_ADAPTER_OPTIONS],
|
|
74
|
-
},
|
|
75
|
-
{ provide: MAT_DATE_FORMATS, useValue: datePickerFormats },
|
|
76
|
-
//provideLuxonDateAdapter(datePickerFormats),
|
|
77
|
-
{ provide: LOCALE_ID, useValue: 'de-DE' },
|
|
78
|
-
{ provide: MAT_DATE_LOCALE, useValue: 'de-DE' },
|
|
79
|
-
{ provide: MAT_LUXON_DATE_ADAPTER_OPTIONS, useValue: { useUtc: true, firstDayOfWeek: 1 } },
|
|
80
|
-
], template: "<div [formGroup]=\"inputGroup\" matRipple #ripple=\"matRipple\" [matRippleDisabled]=\"true\">\n <!-- start date -->\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 <!--\n <mat-hint>d.M.yyyy</mat-hint>\n -->\n <mat-datepicker-toggle matIconSuffix [for]=\"picker1\"></mat-datepicker-toggle>\n <mat-datepicker [disabled]=\"disabled\" #picker1 [startAt]=\"inputGroup.controls.start.defaultValue\">\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 <!--\n <mat-hint>d.M.yyyy</mat-hint>\n -->\n <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n <mat-datepicker [disabled]=\"disabled\" #picker2 [startAt]=\"inputGroup.controls.end.value\">\n </mat-datepicker>\n </mat-form-field>\n <!-- /end date -->\n</div>\n" }]
|
|
81
|
-
}], propDecorators: { disabled: [{
|
|
82
|
-
type: Input
|
|
83
|
-
}], inputGroup: [{
|
|
84
|
-
type: Input,
|
|
85
|
-
args: [{ required: true }]
|
|
86
|
-
}], start: [{
|
|
87
|
-
type: ViewChild,
|
|
88
|
-
args: ['start', {
|
|
89
|
-
read: ElementRef,
|
|
90
|
-
static: true,
|
|
91
|
-
}]
|
|
92
|
-
}], ripple: [{
|
|
93
|
-
type: ViewChild,
|
|
94
|
-
args: ['ripple', {
|
|
95
|
-
read: MatRipple,
|
|
96
|
-
static: true,
|
|
97
|
-
}]
|
|
98
|
-
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../projects/ng-meta-widgets-lib/src/lib/components/filter/datepicker/datepicker.component.ts","../../../../../../../projects/ng-meta-widgets-lib/src/lib/components/filter/datepicker/datepicker.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\nconst datePickerFormats: MatDateFormats = {\n  parse: {\n    dateInput: 'D',\n  },\n  display: {\n    dateInput: 'D',\n    monthYearLabel: 'MMMM yyyy',\n    dateA11yLabel: 'DDD',\n    monthYearA11yLabel: 'MMMM yyyy',\n  },\n};\n\n@Component({\n  selector: 'metaqs2-datepicker',\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\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: './datepicker.component.html',\n  styleUrl: './datepicker.component.css',\n})\nexport class DatepickerComponent implements OnInit, OnDestroy {\n  @Input()\n  disabled: boolean = false;\n\n  @Input({ required: true })\n  inputGroup!: FormGroup<{ start: FormControl<DateTime<boolean>>; end: FormControl<DateTime<boolean>> }>;\n\n  @ViewChild('start', {\n    read: ElementRef,\n    static: true,\n  })\n  protected start!: ElementRef<HTMLInputElement>;\n\n  @ViewChild('ripple', {\n    read: MatRipple,\n    static: true,\n  })\n  protected ripple!: MatRipple;\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, // Angular Material bug: disabled ripples do not trigger unless centered\n      radius: 1000,\n      animation: {\n        exitDuration: 1000,\n      },\n    });\n  }\n}\n","<div [formGroup]=\"inputGroup\" matRipple #ripple=\"matRipple\" [matRippleDisabled]=\"true\">\n  <!-- start date -->\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    <!--\n          <mat-hint>d.M.yyyy</mat-hint>\n    -->\n    <mat-datepicker-toggle matIconSuffix [for]=\"picker1\"></mat-datepicker-toggle>\n    <mat-datepicker [disabled]=\"disabled\" #picker1 [startAt]=\"inputGroup.controls.start.defaultValue\">\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    <!--\n    <mat-hint>d.M.yyyy</mat-hint>\n    -->\n    <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n    <mat-datepicker [disabled]=\"disabled\" #picker2 [startAt]=\"inputGroup.controls.end.value\">\n    </mat-datepicker>\n  </mat-form-field>\n  <!-- /end date -->\n</div>\n"]}
|