@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.
@@ -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._facetId = '';
9
- this._facetDefinitions = [];
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 ID.
17
+ * The facet data.
17
18
  */
18
- get facetId() {
19
- return this._facetId;
19
+ get data() {
20
+ return this._data;
20
21
  }
21
- set facetId(value) {
22
- if (this._facetId === value) {
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._facetDefinitions) {
32
+ if (!this._data?.definitions?.length) {
45
33
  return 'transparent';
46
34
  }
47
- const facet = this._facetDefinitions.find((f) => {
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.facetDefinitions) {
50
+ if (!this._data?.definitions?.length) {
63
51
  return null;
64
52
  }
65
- const facet = this.facetDefinitions.find((f) => {
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._facetId);
75
+ this.color = this.getFacetColor(this._data?.facetId || '');
88
76
  this.contrastColor = this._colorService.getContrastColor(this.color);
89
- this.tip = this.getFacetTip(this._facetId) ?? undefined;
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: { facetId: "facetId", facetDefinitions: "facetDefinitions" }, 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 >{{ 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"] }] });
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: { facetId: [{
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,{"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\nimport { ColorService } from '../../services/color.service';\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 _facetId: string;\r\n  private _facetDefinitions: FacetDefinition[];\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 ID.\r\n   */\r\n  @Input()\r\n  public get facetId(): string {\r\n    return this._facetId;\r\n  }\r\n  public set facetId(value: string) {\r\n    if (this._facetId === value) {\r\n      return;\r\n    }\r\n    this._facetId = value;\r\n    this.updateBadge();\r\n  }\r\n\r\n  /**\r\n   * The facets definitions.\r\n   */\r\n  @Input()\r\n  public get facetDefinitions(): FacetDefinition[] {\r\n    return this._facetDefinitions;\r\n  }\r\n  public set facetDefinitions(value: FacetDefinition[]) {\r\n    this._facetDefinitions = 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._facetId = '';\r\n    this._facetDefinitions = [];\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._facetDefinitions) {\r\n      return 'transparent';\r\n    }\r\n\r\n    const facet = this._facetDefinitions.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.facetDefinitions) {\r\n      return null;\r\n    }\r\n\r\n    const facet = this.facetDefinitions.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._facetId);\r\n    this.contrastColor = this._colorService.getContrastColor(this.color);\r\n    this.tip = this.getFacetTip(this._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  >{{ facetId }}\r\n</span>\r\n"]}
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":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;;;;AAejD,MAAM,OAAO,mBAAmB;IAuB9B,YAAoB,aAA2B;QAA3B,kBAAa,GAAb,aAAa,CAAc;QAC7C,IAAI,CAAC,KAAK,GAAG;YACX,WAAW,EAAE,EAAE;SAChB,CAAC;QACF,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;IAC/B,CAAC;IAtBD;;OAEG;IACH,IACW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACD,IAAW,IAAI,CAAC,KAAwC;QACtD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAYO,aAAa,CAAC,OAAe;QACnC,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE;YAC9B,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE;YACpC,OAAO,aAAa,CAAC;SACtB;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;YAC9C,OAAO,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI,KAAK,EAAE,QAAQ,EAAE;YACnB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,GAAG,GAAG,KAAK,CAAC,QAAQ,CAAC;SACnD;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,aAAa,CAAC;SAC5C;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC;IAEO,WAAW,CAAC,OAAe;QACjC,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;YAC5B,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;SACjC;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE;YACpC,OAAO,IAAI,CAAC;SACb;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;YAC9C,OAAO,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,EAAE;YACV,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;SACpC;aAAM;YACL,MAAM,EAAE,GAAa,EAAE,CAAC;YACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACrD,IAAI,CAAC,GAAG,CAAC,EAAE;oBACT,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACf;gBACD,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBACvC,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE;oBACvC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBACd;aACF;YACD,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SACxC;QACD,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC;QAC3D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACrE,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,IAAI,EAAE,CAAC,IAAI,SAAS,CAAC;IACtE,CAAC;;gHAtFU,mBAAmB;oGAAnB,mBAAmB,oFCfhC,qLAOA;2FDQa,mBAAmB;kBAL/B,SAAS;+BACE,oBAAoB;mGAiBnB,IAAI;sBADd,KAAK","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 flags() {
16
- return this._flags;
13
+ get data() {
14
+ return this._data;
17
15
  }
18
- set flags(value) {
19
- if (this._flags === value) {
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._flagDefinitions) {
21
+ if (!this._data) {
35
22
  return;
36
23
  }
37
- this.badgeFlags = this._flagDefinitions.filter((def) => {
24
+ this.badgeFlags = this._data.definitions.filter((def) => {
38
25
  // tslint:disable-next-line: no-bitwise
39
- return def.id & this._flags;
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: { flags: "flags", flagDefinitions: "flagDefinitions" }, 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 &#x25cf;\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{margin-right:4px;font-size:24px;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"] }] });
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 &#x2b24;\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 &#x25cf;\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{margin-right:4px;font-size:24px;cursor:default}\n"] }]
48
- }], ctorParameters: function () { return []; }, propDecorators: { flags: [{
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 &#x2b24;\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhZ3MtYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlybWlkb24vY2FkbXVzLXVpL3NyYy9saWIvY29tcG9uZW50cy9mbGFncy1iYWRnZS9mbGFncy1iYWRnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJtaWRvbi9jYWRtdXMtdWkvc3JjL2xpYi9jb21wb25lbnRzL2ZsYWdzLWJhZGdlL2ZsYWdzLWJhZGdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBR3pEOzs7R0FHRztBQU1ILE1BQU0sT0FBTyxtQkFBbUI7SUEyQjlCO1FBQ0UsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7UUFDaEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBekJELElBQ1csS0FBSztRQUNkLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBQ0QsSUFBVyxLQUFLLENBQUMsS0FBYTtRQUM1QixJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssS0FBSyxFQUFFO1lBQ3pCLE9BQU87U0FDUjtRQUNELElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsSUFDVyxlQUFlO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDO0lBQy9CLENBQUM7SUFDRCxJQUFXLGVBQWUsQ0FBQyxLQUF1QjtRQUNoRCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsS0FBSyxDQUFDO1FBQzlCLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBUUQsUUFBUSxLQUFVLENBQUM7SUFFWCxXQUFXO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUU7WUFDMUIsT0FBTztTQUNSO1FBQ0QsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDckQsdUNBQXVDO1lBQ3ZDLE9BQU8sR0FBRyxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQzlCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7Z0hBM0NVLG1CQUFtQjtvR0FBbkIsbUJBQW1CLDBIQ1poQyxzTkFVQTsyRkRFYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0Usb0JBQW9COzBFQVduQixLQUFLO3NCQURmLEtBQUs7Z0JBYUssZUFBZTtzQkFEekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGbGFnRGVmaW5pdGlvbiB9IGZyb20gJ0BteXJtaWRvbi9jYWRtdXMtY29yZSc7XHJcblxyXG4vKipcclxuICogQmFkZ2Ugd2l0aCBpdGVtJ3MgZmxhZ3MuIEVhY2ggZmxhZyBpcyByZXByZXNlbnRlZCBieSBhIGNpcmNsZSBmaWxsZWRcclxuICogd2l0aCB0aGUgZmxhZydzIGNvbG9yIGtleS5cclxuICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY2FkbXVzLWZsYWdzLWJhZGdlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZmxhZ3MtYmFkZ2UuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2ZsYWdzLWJhZGdlLmNvbXBvbmVudC5jc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEZsYWdzQmFkZ2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIHByaXZhdGUgX2ZsYWdzOiBudW1iZXI7XHJcbiAgcHJpdmF0ZSBfZmxhZ0RlZmluaXRpb25zOiBGbGFnRGVmaW5pdGlvbltdO1xyXG5cclxuICBwdWJsaWMgYmFkZ2VGbGFnczogRmxhZ0RlZmluaXRpb25bXTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZ2V0IGZsYWdzKCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gdGhpcy5fZmxhZ3M7XHJcbiAgfVxyXG4gIHB1YmxpYyBzZXQgZmxhZ3ModmFsdWU6IG51bWJlcikge1xyXG4gICAgaWYgKHRoaXMuX2ZsYWdzID09PSB2YWx1ZSkge1xyXG4gICAgICByZXR1cm47XHJcbiAgICB9XHJcbiAgICB0aGlzLl9mbGFncyA9IHZhbHVlO1xyXG4gICAgdGhpcy51cGRhdGVCYWRnZSgpO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZ2V0IGZsYWdEZWZpbml0aW9ucygpOiBGbGFnRGVmaW5pdGlvbltdIHtcclxuICAgIHJldHVybiB0aGlzLl9mbGFnRGVmaW5pdGlvbnM7XHJcbiAgfVxyXG4gIHB1YmxpYyBzZXQgZmxhZ0RlZmluaXRpb25zKHZhbHVlOiBGbGFnRGVmaW5pdGlvbltdKSB7XHJcbiAgICB0aGlzLl9mbGFnRGVmaW5pdGlvbnMgPSB2YWx1ZTtcclxuICAgIHRoaXMudXBkYXRlQmFkZ2UoKTtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgdGhpcy5fZmxhZ3MgPSAwO1xyXG4gICAgdGhpcy5fZmxhZ0RlZmluaXRpb25zID0gW107XHJcbiAgICB0aGlzLmJhZGdlRmxhZ3MgPSBbXTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge31cclxuXHJcbiAgcHJpdmF0ZSB1cGRhdGVCYWRnZSgpIHtcclxuICAgIGlmICghdGhpcy5fZmxhZ0RlZmluaXRpb25zKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuICAgIHRoaXMuYmFkZ2VGbGFncyA9IHRoaXMuX2ZsYWdEZWZpbml0aW9ucy5maWx0ZXIoKGRlZikgPT4ge1xyXG4gICAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6IG5vLWJpdHdpc2VcclxuICAgICAgcmV0dXJuIGRlZi5pZCAmIHRoaXMuX2ZsYWdzO1xyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXY+XHJcbiAgPHNwYW5cclxuICAgIGNsYXNzPVwiYmFkZ2UtZmxhZ1wiXHJcbiAgICAqbmdGb3I9XCJsZXQgZGVmIG9mIGJhZGdlRmxhZ3NcIlxyXG4gICAgW3N0eWxlLmNvbG9yXT1cIicjJyArIGRlZi5jb2xvcktleVwiXHJcbiAgICBbbWF0VG9vbHRpcF09XCJkZWYubGFiZWxcIlxyXG4gID5cclxuICAgICYjeDI1Y2Y7XHJcbiAgPC9zcGFuPlxyXG48L2Rpdj5cclxuIl19
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._facetId = '';
207
- this._facetDefinitions = [];
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 ID.
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 facetDefinitions() {
230
- return this._facetDefinitions;
217
+ get data() {
218
+ return this._data;
231
219
  }
232
- set facetDefinitions(value) {
233
- this._facetDefinitions = value;
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._facetDefinitions) {
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._facetDefinitions.find((f) => {
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.facetDefinitions) {
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.facetDefinitions.find((f) => {
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._facetId);
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 = (_a = this.getFacetTip(this._facetId)) !== null && _a !== void 0 ? _a : undefined;
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: { facetId: "facetId", facetDefinitions: "facetDefinitions" }, 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 >{{ 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"] }] });
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: { facetId: [{
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 flags() {
313
- return this._flags;
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 flagDefinitions(value) {
326
- this._flagDefinitions = value;
301
+ set data(value) {
302
+ this._data = value;
327
303
  this.updateBadge();
328
304
  }
329
- ngOnInit() { }
330
305
  updateBadge() {
331
- if (!this._flagDefinitions) {
306
+ if (!this._data) {
332
307
  return;
333
308
  }
334
- this.badgeFlags = this._flagDefinitions.filter((def) => {
309
+ this.badgeFlags = this._data.definitions.filter((def) => {
335
310
  // tslint:disable-next-line: no-bitwise
336
- return def.id & this._flags;
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: { flags: "flags", flagDefinitions: "flagDefinitions" }, 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 &#x25cf;\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{margin-right:4px;font-size:24px;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"] }] });
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 &#x2b24;\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 &#x25cf;\r\n </span>\r\n</div>\r\n", styles: ["span.badge-flag{margin-right:4px;font-size:24px;cursor:default}\n"] }]
345
- }], ctorParameters: function () { return []; }, propDecorators: { flags: [{
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 &#x2b24;\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