@myrmidon/cadmus-ui 4.0.4 → 4.0.5
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/esm2020/lib/components/facet-badge/facet-badge.component.mjs +18 -32
- package/esm2020/lib/components/flags-badge/flags-badge.component.mjs +11 -26
- package/fesm2015/myrmidon-cadmus-ui.mjs +30 -57
- package/fesm2015/myrmidon-cadmus-ui.mjs.map +1 -1
- package/fesm2020/myrmidon-cadmus-ui.mjs +27 -56
- package/fesm2020/myrmidon-cadmus-ui.mjs.map +1 -1
- package/lib/components/facet-badge/facet-badge.component.d.ts +9 -11
- package/lib/components/flags-badge/flags-badge.component.d.ts +12 -10
- package/package.json +1 -1
|
@@ -5,34 +5,22 @@ import * as i2 from "@angular/material/tooltip";
|
|
|
5
5
|
export class FacetBadgeComponent {
|
|
6
6
|
constructor(_colorService) {
|
|
7
7
|
this._colorService = _colorService;
|
|
8
|
-
this.
|
|
9
|
-
|
|
8
|
+
this._data = {
|
|
9
|
+
definitions: [],
|
|
10
|
+
};
|
|
10
11
|
this._facetColors = {};
|
|
11
12
|
this._facetTips = {};
|
|
12
13
|
this.color = 'transparent';
|
|
13
14
|
this.contrastColor = 'black';
|
|
14
15
|
}
|
|
15
16
|
/**
|
|
16
|
-
* The facet
|
|
17
|
+
* The facet data.
|
|
17
18
|
*/
|
|
18
|
-
get
|
|
19
|
-
return this.
|
|
19
|
+
get data() {
|
|
20
|
+
return this._data;
|
|
20
21
|
}
|
|
21
|
-
set
|
|
22
|
-
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
this._facetId = value;
|
|
26
|
-
this.updateBadge();
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* The facets definitions.
|
|
30
|
-
*/
|
|
31
|
-
get facetDefinitions() {
|
|
32
|
-
return this._facetDefinitions;
|
|
33
|
-
}
|
|
34
|
-
set facetDefinitions(value) {
|
|
35
|
-
this._facetDefinitions = value;
|
|
22
|
+
set data(value) {
|
|
23
|
+
this._data = value;
|
|
36
24
|
this._facetColors = {};
|
|
37
25
|
this._facetTips = {};
|
|
38
26
|
this.updateBadge();
|
|
@@ -41,10 +29,10 @@ export class FacetBadgeComponent {
|
|
|
41
29
|
if (this._facetColors[facetId]) {
|
|
42
30
|
return this._facetColors[facetId];
|
|
43
31
|
}
|
|
44
|
-
if (!this.
|
|
32
|
+
if (!this._data?.definitions?.length) {
|
|
45
33
|
return 'transparent';
|
|
46
34
|
}
|
|
47
|
-
const facet = this.
|
|
35
|
+
const facet = this._data.definitions.find((f) => {
|
|
48
36
|
return f.id === facetId;
|
|
49
37
|
});
|
|
50
38
|
if (facet?.colorKey) {
|
|
@@ -59,10 +47,10 @@ export class FacetBadgeComponent {
|
|
|
59
47
|
if (this._facetTips[facetId]) {
|
|
60
48
|
return this._facetTips[facetId];
|
|
61
49
|
}
|
|
62
|
-
if (!this.
|
|
50
|
+
if (!this._data?.definitions?.length) {
|
|
63
51
|
return null;
|
|
64
52
|
}
|
|
65
|
-
const facet = this.
|
|
53
|
+
const facet = this._data.definitions.find((f) => {
|
|
66
54
|
return f.id === facetId;
|
|
67
55
|
});
|
|
68
56
|
if (!facet) {
|
|
@@ -84,19 +72,17 @@ export class FacetBadgeComponent {
|
|
|
84
72
|
return this._facetTips[facetId];
|
|
85
73
|
}
|
|
86
74
|
updateBadge() {
|
|
87
|
-
this.color = this.getFacetColor(this.
|
|
75
|
+
this.color = this.getFacetColor(this._data?.facetId || '');
|
|
88
76
|
this.contrastColor = this._colorService.getContrastColor(this.color);
|
|
89
|
-
this.tip = this.getFacetTip(this.
|
|
77
|
+
this.tip = this.getFacetTip(this._data?.facetId || '') ?? undefined;
|
|
90
78
|
}
|
|
91
79
|
}
|
|
92
80
|
FacetBadgeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FacetBadgeComponent, deps: [{ token: i1.ColorService }], target: i0.ɵɵFactoryTarget.Component });
|
|
93
|
-
FacetBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FacetBadgeComponent, selector: "cadmus-facet-badge", inputs: {
|
|
81
|
+
FacetBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FacetBadgeComponent, selector: "cadmus-facet-badge", inputs: { data: "data" }, ngImport: i0, template: "<span\r\n class=\"model-type\"\r\n [style.background-color]=\"color\"\r\n [style.color]=\"contrastColor\"\r\n matTooltip=\"{{ tip }}\"\r\n >{{ data?.facetId }}\r\n</span>\r\n", styles: ["span.model-type{padding:4px;border-radius:6px}\n"], dependencies: [{ kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
|
94
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FacetBadgeComponent, decorators: [{
|
|
95
83
|
type: Component,
|
|
96
|
-
args: [{ selector: 'cadmus-facet-badge', template: "<span\r\n class=\"model-type\"\r\n [style.background-color]=\"color\"\r\n [style.color]=\"contrastColor\"\r\n matTooltip=\"{{ tip }}\"\r\n >{{ facetId }}\r\n</span>\r\n", styles: ["span.model-type{padding:4px;border-radius:6px}\n"] }]
|
|
97
|
-
}], ctorParameters: function () { return [{ type: i1.ColorService }]; }, propDecorators: {
|
|
98
|
-
type: Input
|
|
99
|
-
}], facetDefinitions: [{
|
|
84
|
+
args: [{ selector: 'cadmus-facet-badge', template: "<span\r\n class=\"model-type\"\r\n [style.background-color]=\"color\"\r\n [style.color]=\"contrastColor\"\r\n matTooltip=\"{{ tip }}\"\r\n >{{ data?.facetId }}\r\n</span>\r\n", styles: ["span.model-type{padding:4px;border-radius:6px}\n"] }]
|
|
85
|
+
}], ctorParameters: function () { return [{ type: i1.ColorService }]; }, propDecorators: { data: [{
|
|
100
86
|
type: Input
|
|
101
87
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"facet-badge.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrmidon/cadmus-ui/src/lib/components/facet-badge/facet-badge.component.ts","../../../../../../../projects/myrmidon/cadmus-ui/src/lib/components/facet-badge/facet-badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { FacetDefinition } from '@myrmidon/cadmus-core';\r\n\r\nimport { ColorService } from '../../services/color.service';\r\n\r\nexport interface FacetBadgeData {\r\n  definitions: FacetDefinition[];\r\n  facetId?: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'cadmus-facet-badge',\r\n  templateUrl: './facet-badge.component.html',\r\n  styleUrls: ['./facet-badge.component.css'],\r\n})\r\nexport class FacetBadgeComponent {\r\n  private _facetColors: { [key: string]: string };\r\n  private _facetTips: { [key: string]: string };\r\n  private _data?: FacetBadgeData | null;\r\n\r\n  public color: string;\r\n  public contrastColor: string;\r\n  public tip?: string;\r\n\r\n  /**\r\n   * The facet data.\r\n   */\r\n  @Input()\r\n  public get data(): FacetBadgeData | undefined | null {\r\n    return this._data;\r\n  }\r\n  public set data(value: FacetBadgeData | undefined | null) {\r\n    this._data = value;\r\n    this._facetColors = {};\r\n    this._facetTips = {};\r\n    this.updateBadge();\r\n  }\r\n\r\n  constructor(private _colorService: ColorService) {\r\n    this._data = {\r\n      definitions: [],\r\n    };\r\n    this._facetColors = {};\r\n    this._facetTips = {};\r\n    this.color = 'transparent';\r\n    this.contrastColor = 'black';\r\n  }\r\n\r\n  private getFacetColor(facetId: string): string {\r\n    if (this._facetColors[facetId]) {\r\n      return this._facetColors[facetId];\r\n    }\r\n    if (!this._data?.definitions?.length) {\r\n      return 'transparent';\r\n    }\r\n\r\n    const facet = this._data.definitions.find((f) => {\r\n      return f.id === facetId;\r\n    });\r\n    if (facet?.colorKey) {\r\n      this._facetColors[facetId] = '#' + facet.colorKey;\r\n    } else {\r\n      this._facetColors[facetId] = 'transparent';\r\n    }\r\n    return this._facetColors[facetId];\r\n  }\r\n\r\n  private getFacetTip(facetId: string): string | null {\r\n    if (this._facetTips[facetId]) {\r\n      return this._facetTips[facetId];\r\n    }\r\n\r\n    if (!this._data?.definitions?.length) {\r\n      return null;\r\n    }\r\n\r\n    const facet = this._data.definitions.find((f) => {\r\n      return f.id === facetId;\r\n    });\r\n    if (!facet) {\r\n      this._facetTips[facetId] = facetId;\r\n    } else {\r\n      const sb: string[] = [];\r\n      for (let i = 0; i < facet.partDefinitions.length; i++) {\r\n        if (i > 0) {\r\n          sb.push(', ');\r\n        }\r\n        sb.push(facet.partDefinitions[i].name);\r\n        if (facet.partDefinitions[i].isRequired) {\r\n          sb.push('*');\r\n        }\r\n      }\r\n      this._facetTips[facetId] = sb.join('');\r\n    }\r\n    return this._facetTips[facetId];\r\n  }\r\n\r\n  private updateBadge() {\r\n    this.color = this.getFacetColor(this._data?.facetId || '');\r\n    this.contrastColor = this._colorService.getContrastColor(this.color);\r\n    this.tip = this.getFacetTip(this._data?.facetId || '') ?? undefined;\r\n  }\r\n}\r\n","<span\r\n  class=\"model-type\"\r\n  [style.background-color]=\"color\"\r\n  [style.color]=\"contrastColor\"\r\n  matTooltip=\"{{ tip }}\"\r\n  >{{ data?.facetId }}\r\n</span>\r\n"]}
|
|
@@ -8,46 +8,31 @@ import * as i2 from "@angular/material/tooltip";
|
|
|
8
8
|
*/
|
|
9
9
|
export class FlagsBadgeComponent {
|
|
10
10
|
constructor() {
|
|
11
|
-
this._flags = 0;
|
|
12
|
-
this._flagDefinitions = [];
|
|
13
11
|
this.badgeFlags = [];
|
|
14
12
|
}
|
|
15
|
-
get
|
|
16
|
-
return this.
|
|
13
|
+
get data() {
|
|
14
|
+
return this._data;
|
|
17
15
|
}
|
|
18
|
-
set
|
|
19
|
-
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
this._flags = value;
|
|
23
|
-
this.updateBadge();
|
|
24
|
-
}
|
|
25
|
-
get flagDefinitions() {
|
|
26
|
-
return this._flagDefinitions;
|
|
27
|
-
}
|
|
28
|
-
set flagDefinitions(value) {
|
|
29
|
-
this._flagDefinitions = value;
|
|
16
|
+
set data(value) {
|
|
17
|
+
this._data = value;
|
|
30
18
|
this.updateBadge();
|
|
31
19
|
}
|
|
32
|
-
ngOnInit() { }
|
|
33
20
|
updateBadge() {
|
|
34
|
-
if (!this.
|
|
21
|
+
if (!this._data) {
|
|
35
22
|
return;
|
|
36
23
|
}
|
|
37
|
-
this.badgeFlags = this.
|
|
24
|
+
this.badgeFlags = this._data.definitions.filter((def) => {
|
|
38
25
|
// tslint:disable-next-line: no-bitwise
|
|
39
|
-
return def.id & this.
|
|
26
|
+
return def.id & this._data.flags;
|
|
40
27
|
});
|
|
41
28
|
}
|
|
42
29
|
}
|
|
43
30
|
FlagsBadgeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FlagsBadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
44
|
-
FlagsBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FlagsBadgeComponent, selector: "cadmus-flags-badge", inputs: {
|
|
31
|
+
FlagsBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FlagsBadgeComponent, selector: "cadmus-flags-badge", inputs: { data: "data" }, ngImport: i0, template: "<div>\r\n <span\r\n class=\"badge-flag\"\r\n *ngFor=\"let def of badgeFlags\"\r\n [style.color]=\"'#' + def.colorKey\"\r\n [matTooltip]=\"def.label\"\r\n >\r\n ⬤\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{font-size:1rem;cursor:default}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
|
45
32
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FlagsBadgeComponent, decorators: [{
|
|
46
33
|
type: Component,
|
|
47
|
-
args: [{ selector: 'cadmus-flags-badge', template: "<div>\r\n <span\r\n class=\"badge-flag\"\r\n *ngFor=\"let def of badgeFlags\"\r\n [style.color]=\"'#' + def.colorKey\"\r\n [matTooltip]=\"def.label\"\r\n >\r\n &#
|
|
48
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
49
|
-
type: Input
|
|
50
|
-
}], flagDefinitions: [{
|
|
34
|
+
args: [{ selector: 'cadmus-flags-badge', template: "<div>\r\n <span\r\n class=\"badge-flag\"\r\n *ngFor=\"let def of badgeFlags\"\r\n [style.color]=\"'#' + def.colorKey\"\r\n [matTooltip]=\"def.label\"\r\n >\r\n ⬤\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{font-size:1rem;cursor:default}\n"] }]
|
|
35
|
+
}], ctorParameters: function () { return []; }, propDecorators: { data: [{
|
|
51
36
|
type: Input
|
|
52
37
|
}] } });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhZ3MtYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlybWlkb24vY2FkbXVzLXVpL3NyYy9saWIvY29tcG9uZW50cy9mbGFncy1iYWRnZS9mbGFncy1iYWRnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJtaWRvbi9jYWRtdXMtdWkvc3JjL2xpYi9jb21wb25lbnRzL2ZsYWdzLWJhZGdlL2ZsYWdzLWJhZGdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBV2pEOzs7R0FHRztBQU1ILE1BQU0sT0FBTyxtQkFBbUI7SUFjOUI7UUFDRSxJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBWEQsSUFDVyxJQUFJO1FBQ2IsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFDRCxJQUFXLElBQUksQ0FBQyxLQUF3QztRQUN0RCxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQU1PLFdBQVc7UUFDakIsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDZixPQUFPO1NBQ1I7UUFDRCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3RELHVDQUF1QztZQUN2QyxPQUFPLEdBQUcsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQU0sQ0FBQyxLQUFLLENBQUM7UUFDcEMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOztnSEExQlUsbUJBQW1CO29HQUFuQixtQkFBbUIsb0ZDcEJoQyxzTkFVQTsyRkRVYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0Usb0JBQW9COzBFQVVuQixJQUFJO3NCQURkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZsYWdEZWZpbml0aW9uIH0gZnJvbSAnQG15cm1pZG9uL2NhZG11cy1jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBEYXRhIGZvciBGbGFnc0JhZGdlQ29tcG9uZW50LCBpbmNsdWRpbmcgZmxhZ3MgYW5kIHRoZWlyIGRlZmluaXRpb25zLlxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBGbGFnc0JhZGdlRGF0YSB7XHJcbiAgZGVmaW5pdGlvbnM6IEZsYWdEZWZpbml0aW9uW107XHJcbiAgZmxhZ3M6IG51bWJlcjtcclxufVxyXG5cclxuLyoqXHJcbiAqIEJhZGdlIHdpdGggaXRlbSdzIGZsYWdzLiBFYWNoIGZsYWcgaXMgcmVwcmVzZW50ZWQgYnkgYSBjaXJjbGUgZmlsbGVkXHJcbiAqIHdpdGggdGhlIGZsYWcncyBjb2xvciBrZXkuXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NhZG11cy1mbGFncy1iYWRnZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2ZsYWdzLWJhZGdlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9mbGFncy1iYWRnZS5jb21wb25lbnQuY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGbGFnc0JhZGdlQ29tcG9uZW50IHtcclxuICBwcml2YXRlIF9kYXRhPzogRmxhZ3NCYWRnZURhdGEgfCBudWxsO1xyXG5cclxuICBwdWJsaWMgYmFkZ2VGbGFnczogRmxhZ0RlZmluaXRpb25bXTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZ2V0IGRhdGEoKTogRmxhZ3NCYWRnZURhdGEgfCB1bmRlZmluZWQgfCBudWxsIHtcclxuICAgIHJldHVybiB0aGlzLl9kYXRhO1xyXG4gIH1cclxuICBwdWJsaWMgc2V0IGRhdGEodmFsdWU6IEZsYWdzQmFkZ2VEYXRhIHwgdW5kZWZpbmVkIHwgbnVsbCkge1xyXG4gICAgdGhpcy5fZGF0YSA9IHZhbHVlO1xyXG4gICAgdGhpcy51cGRhdGVCYWRnZSgpO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcbiAgICB0aGlzLmJhZGdlRmxhZ3MgPSBbXTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgdXBkYXRlQmFkZ2UoKSB7XHJcbiAgICBpZiAoIXRoaXMuX2RhdGEpIHtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG4gICAgdGhpcy5iYWRnZUZsYWdzID0gdGhpcy5fZGF0YS5kZWZpbml0aW9ucy5maWx0ZXIoKGRlZikgPT4ge1xyXG4gICAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6IG5vLWJpdHdpc2VcclxuICAgICAgcmV0dXJuIGRlZi5pZCAmIHRoaXMuX2RhdGEhLmZsYWdzO1xyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXY+XHJcbiAgPHNwYW5cclxuICAgIGNsYXNzPVwiYmFkZ2UtZmxhZ1wiXHJcbiAgICAqbmdGb3I9XCJsZXQgZGVmIG9mIGJhZGdlRmxhZ3NcIlxyXG4gICAgW3N0eWxlLmNvbG9yXT1cIicjJyArIGRlZi5jb2xvcktleVwiXHJcbiAgICBbbWF0VG9vbHRpcF09XCJkZWYubGFiZWxcIlxyXG4gID5cclxuICAgICYjeDJiMjQ7XHJcbiAgPC9zcGFuPlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -203,46 +203,35 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.2", ngImpor
|
|
|
203
203
|
class FacetBadgeComponent {
|
|
204
204
|
constructor(_colorService) {
|
|
205
205
|
this._colorService = _colorService;
|
|
206
|
-
this.
|
|
207
|
-
|
|
206
|
+
this._data = {
|
|
207
|
+
definitions: [],
|
|
208
|
+
};
|
|
208
209
|
this._facetColors = {};
|
|
209
210
|
this._facetTips = {};
|
|
210
211
|
this.color = 'transparent';
|
|
211
212
|
this.contrastColor = 'black';
|
|
212
213
|
}
|
|
213
214
|
/**
|
|
214
|
-
* The facet
|
|
215
|
-
*/
|
|
216
|
-
get facetId() {
|
|
217
|
-
return this._facetId;
|
|
218
|
-
}
|
|
219
|
-
set facetId(value) {
|
|
220
|
-
if (this._facetId === value) {
|
|
221
|
-
return;
|
|
222
|
-
}
|
|
223
|
-
this._facetId = value;
|
|
224
|
-
this.updateBadge();
|
|
225
|
-
}
|
|
226
|
-
/**
|
|
227
|
-
* The facets definitions.
|
|
215
|
+
* The facet data.
|
|
228
216
|
*/
|
|
229
|
-
get
|
|
230
|
-
return this.
|
|
217
|
+
get data() {
|
|
218
|
+
return this._data;
|
|
231
219
|
}
|
|
232
|
-
set
|
|
233
|
-
this.
|
|
220
|
+
set data(value) {
|
|
221
|
+
this._data = value;
|
|
234
222
|
this._facetColors = {};
|
|
235
223
|
this._facetTips = {};
|
|
236
224
|
this.updateBadge();
|
|
237
225
|
}
|
|
238
226
|
getFacetColor(facetId) {
|
|
227
|
+
var _a, _b;
|
|
239
228
|
if (this._facetColors[facetId]) {
|
|
240
229
|
return this._facetColors[facetId];
|
|
241
230
|
}
|
|
242
|
-
if (!this.
|
|
231
|
+
if (!((_b = (_a = this._data) === null || _a === void 0 ? void 0 : _a.definitions) === null || _b === void 0 ? void 0 : _b.length)) {
|
|
243
232
|
return 'transparent';
|
|
244
233
|
}
|
|
245
|
-
const facet = this.
|
|
234
|
+
const facet = this._data.definitions.find((f) => {
|
|
246
235
|
return f.id === facetId;
|
|
247
236
|
});
|
|
248
237
|
if (facet === null || facet === void 0 ? void 0 : facet.colorKey) {
|
|
@@ -254,13 +243,14 @@ class FacetBadgeComponent {
|
|
|
254
243
|
return this._facetColors[facetId];
|
|
255
244
|
}
|
|
256
245
|
getFacetTip(facetId) {
|
|
246
|
+
var _a, _b;
|
|
257
247
|
if (this._facetTips[facetId]) {
|
|
258
248
|
return this._facetTips[facetId];
|
|
259
249
|
}
|
|
260
|
-
if (!this.
|
|
250
|
+
if (!((_b = (_a = this._data) === null || _a === void 0 ? void 0 : _a.definitions) === null || _b === void 0 ? void 0 : _b.length)) {
|
|
261
251
|
return null;
|
|
262
252
|
}
|
|
263
|
-
const facet = this.
|
|
253
|
+
const facet = this._data.definitions.find((f) => {
|
|
264
254
|
return f.id === facetId;
|
|
265
255
|
});
|
|
266
256
|
if (!facet) {
|
|
@@ -282,20 +272,18 @@ class FacetBadgeComponent {
|
|
|
282
272
|
return this._facetTips[facetId];
|
|
283
273
|
}
|
|
284
274
|
updateBadge() {
|
|
285
|
-
var _a;
|
|
286
|
-
this.color = this.getFacetColor(this.
|
|
275
|
+
var _a, _b, _c;
|
|
276
|
+
this.color = this.getFacetColor(((_a = this._data) === null || _a === void 0 ? void 0 : _a.facetId) || '');
|
|
287
277
|
this.contrastColor = this._colorService.getContrastColor(this.color);
|
|
288
|
-
this.tip = (
|
|
278
|
+
this.tip = (_c = this.getFacetTip(((_b = this._data) === null || _b === void 0 ? void 0 : _b.facetId) || '')) !== null && _c !== void 0 ? _c : undefined;
|
|
289
279
|
}
|
|
290
280
|
}
|
|
291
281
|
FacetBadgeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FacetBadgeComponent, deps: [{ token: ColorService }], target: i0.ɵɵFactoryTarget.Component });
|
|
292
|
-
FacetBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FacetBadgeComponent, selector: "cadmus-facet-badge", inputs: {
|
|
282
|
+
FacetBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FacetBadgeComponent, selector: "cadmus-facet-badge", inputs: { data: "data" }, ngImport: i0, template: "<span\r\n class=\"model-type\"\r\n [style.background-color]=\"color\"\r\n [style.color]=\"contrastColor\"\r\n matTooltip=\"{{ tip }}\"\r\n >{{ data?.facetId }}\r\n</span>\r\n", styles: ["span.model-type{padding:4px;border-radius:6px}\n"], dependencies: [{ kind: "directive", type: i2$1.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
|
293
283
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FacetBadgeComponent, decorators: [{
|
|
294
284
|
type: Component,
|
|
295
|
-
args: [{ selector: 'cadmus-facet-badge', template: "<span\r\n class=\"model-type\"\r\n [style.background-color]=\"color\"\r\n [style.color]=\"contrastColor\"\r\n matTooltip=\"{{ tip }}\"\r\n >{{ facetId }}\r\n</span>\r\n", styles: ["span.model-type{padding:4px;border-radius:6px}\n"] }]
|
|
296
|
-
}], ctorParameters: function () { return [{ type: ColorService }]; }, propDecorators: {
|
|
297
|
-
type: Input
|
|
298
|
-
}], facetDefinitions: [{
|
|
285
|
+
args: [{ selector: 'cadmus-facet-badge', template: "<span\r\n class=\"model-type\"\r\n [style.background-color]=\"color\"\r\n [style.color]=\"contrastColor\"\r\n matTooltip=\"{{ tip }}\"\r\n >{{ data?.facetId }}\r\n</span>\r\n", styles: ["span.model-type{padding:4px;border-radius:6px}\n"] }]
|
|
286
|
+
}], ctorParameters: function () { return [{ type: ColorService }]; }, propDecorators: { data: [{
|
|
299
287
|
type: Input
|
|
300
288
|
}] } });
|
|
301
289
|
|
|
@@ -305,46 +293,31 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.2", ngImpor
|
|
|
305
293
|
*/
|
|
306
294
|
class FlagsBadgeComponent {
|
|
307
295
|
constructor() {
|
|
308
|
-
this._flags = 0;
|
|
309
|
-
this._flagDefinitions = [];
|
|
310
296
|
this.badgeFlags = [];
|
|
311
297
|
}
|
|
312
|
-
get
|
|
313
|
-
return this.
|
|
314
|
-
}
|
|
315
|
-
set flags(value) {
|
|
316
|
-
if (this._flags === value) {
|
|
317
|
-
return;
|
|
318
|
-
}
|
|
319
|
-
this._flags = value;
|
|
320
|
-
this.updateBadge();
|
|
321
|
-
}
|
|
322
|
-
get flagDefinitions() {
|
|
323
|
-
return this._flagDefinitions;
|
|
298
|
+
get data() {
|
|
299
|
+
return this._data;
|
|
324
300
|
}
|
|
325
|
-
set
|
|
326
|
-
this.
|
|
301
|
+
set data(value) {
|
|
302
|
+
this._data = value;
|
|
327
303
|
this.updateBadge();
|
|
328
304
|
}
|
|
329
|
-
ngOnInit() { }
|
|
330
305
|
updateBadge() {
|
|
331
|
-
if (!this.
|
|
306
|
+
if (!this._data) {
|
|
332
307
|
return;
|
|
333
308
|
}
|
|
334
|
-
this.badgeFlags = this.
|
|
309
|
+
this.badgeFlags = this._data.definitions.filter((def) => {
|
|
335
310
|
// tslint:disable-next-line: no-bitwise
|
|
336
|
-
return def.id & this.
|
|
311
|
+
return def.id & this._data.flags;
|
|
337
312
|
});
|
|
338
313
|
}
|
|
339
314
|
}
|
|
340
315
|
FlagsBadgeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FlagsBadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
341
|
-
FlagsBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FlagsBadgeComponent, selector: "cadmus-flags-badge", inputs: {
|
|
316
|
+
FlagsBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.2", type: FlagsBadgeComponent, selector: "cadmus-flags-badge", inputs: { data: "data" }, ngImport: i0, template: "<div>\r\n <span\r\n class=\"badge-flag\"\r\n *ngFor=\"let def of badgeFlags\"\r\n [style.color]=\"'#' + def.colorKey\"\r\n [matTooltip]=\"def.label\"\r\n >\r\n ⬤\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{font-size:1rem;cursor:default}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
|
342
317
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.2", ngImport: i0, type: FlagsBadgeComponent, decorators: [{
|
|
343
318
|
type: Component,
|
|
344
|
-
args: [{ selector: 'cadmus-flags-badge', template: "<div>\r\n <span\r\n class=\"badge-flag\"\r\n *ngFor=\"let def of badgeFlags\"\r\n [style.color]=\"'#' + def.colorKey\"\r\n [matTooltip]=\"def.label\"\r\n >\r\n &#
|
|
345
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
346
|
-
type: Input
|
|
347
|
-
}], flagDefinitions: [{
|
|
319
|
+
args: [{ selector: 'cadmus-flags-badge', template: "<div>\r\n <span\r\n class=\"badge-flag\"\r\n *ngFor=\"let def of badgeFlags\"\r\n [style.color]=\"'#' + def.colorKey\"\r\n [matTooltip]=\"def.label\"\r\n >\r\n ⬤\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{font-size:1rem;cursor:default}\n"] }]
|
|
320
|
+
}], ctorParameters: function () { return []; }, propDecorators: { data: [{
|
|
348
321
|
type: Input
|
|
349
322
|
}] } });
|
|
350
323
|
|