@onecx/angular-accelerator 5.28.0 → 5.30.0
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/assets/i18n/de.json +1 -0
- package/assets/i18n/en.json +1 -0
- package/esm2022/lib/components/column-group-selection/column-group-selection.component.mjs +3 -3
- package/esm2022/lib/components/data-table/data-table.component.mjs +14 -13
- package/esm2022/lib/components/diagram/diagram.component.mjs +26 -3
- package/esm2022/lib/components/group-by-count-diagram/group-by-count-diagram.component.mjs +24 -6
- package/esm2022/lib/components/page-header/page-header.component.mjs +4 -3
- package/esm2022/lib/model/diagram-data.mjs +1 -1
- package/fesm2022/onecx-angular-accelerator.mjs +69 -27
- package/fesm2022/onecx-angular-accelerator.mjs.map +1 -1
- package/lib/components/diagram/diagram.component.d.ts +8 -1
- package/lib/components/group-by-count-diagram/group-by-count-diagram.component.d.ts +10 -1
- package/lib/components/page-header/page-header.component.d.ts +2 -0
- package/lib/model/diagram-data.d.ts +1 -0
- package/package.json +5 -5
|
@@ -54,6 +54,12 @@ export class DiagramComponent {
|
|
|
54
54
|
constructor(translateService) {
|
|
55
55
|
this.translateService = translateService;
|
|
56
56
|
this.sumKey = 'OCX_DIAGRAM.SUM';
|
|
57
|
+
/**
|
|
58
|
+
* This property determines if diagram should generate the colors for the data that does not have any set.
|
|
59
|
+
*
|
|
60
|
+
* Setting this property to false will result in using the provided colors only if every data item has one. In the scenario where at least one item does not have a color set, diagram will generate all colors.
|
|
61
|
+
*/
|
|
62
|
+
this.fillMissingColors = true;
|
|
57
63
|
this._diagramType = "PIE" /* DiagramType.PIE */;
|
|
58
64
|
this.chartType = 'pie';
|
|
59
65
|
this._supportedDiagramTypes = [];
|
|
@@ -80,7 +86,7 @@ export class DiagramComponent {
|
|
|
80
86
|
if (this.data) {
|
|
81
87
|
const inputData = this.data.map((diagramData) => diagramData.value);
|
|
82
88
|
this.amountOfData = this.data.reduce((acc, current) => acc + current.value, 0);
|
|
83
|
-
const COLORS =
|
|
89
|
+
const COLORS = this.generateColors(this.data, colorScale, colorRangeInfo);
|
|
84
90
|
this.chartData = {
|
|
85
91
|
labels: this.data.map((data) => data.label),
|
|
86
92
|
datasets: [
|
|
@@ -109,6 +115,21 @@ export class DiagramComponent {
|
|
|
109
115
|
}),
|
|
110
116
|
};
|
|
111
117
|
}
|
|
118
|
+
generateColors(data, colorScale, colorRangeInfo) {
|
|
119
|
+
const dataColors = data.map((diagramData) => diagramData.backgroundColor);
|
|
120
|
+
if (dataColors.filter((v) => v !== undefined).length === data.length) {
|
|
121
|
+
return dataColors;
|
|
122
|
+
}
|
|
123
|
+
else if (this.fillMissingColors) {
|
|
124
|
+
// it is intended to generate more colors than needed, so interval for generated colors is same as amount of items on the diagram
|
|
125
|
+
const interpolatedColors = interpolateColors(dataColors.length, colorScale, colorRangeInfo);
|
|
126
|
+
let interpolatedIndex = 0;
|
|
127
|
+
return dataColors.map((color) => (color === undefined ? interpolatedColors[interpolatedIndex++] : color));
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
return interpolateColors(data.length, colorScale, colorRangeInfo);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
112
133
|
generateTotal(data) {
|
|
113
134
|
return data.reduce((acc, current) => acc + current.value, 0);
|
|
114
135
|
}
|
|
@@ -134,7 +155,7 @@ export class DiagramComponent {
|
|
|
134
155
|
});
|
|
135
156
|
}
|
|
136
157
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: DiagramComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
137
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: DiagramComponent, selector: "ocx-diagram", inputs: { data: "data", sumKey: "sumKey", diagramType: "diagramType", supportedDiagramTypes: "supportedDiagramTypes" }, outputs: { dataSelected: "dataSelected", diagramTypeChanged: "diagramTypeChanged", componentStateChanged: "componentStateChanged" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"this.data\">\n <div class=\"flex justify-content-center pb-2\" *ngIf=\"shownDiagramTypes.length > 1\">\n <p-selectButton\n [options]=\"shownDiagramTypes\"\n [(ngModel)]=\"selectedDiagramType\"\n optionLabel=\"id\"\n (onChange)=\"onDiagramTypeChanged($event)\"\n name=\"diagram-type-select-button\"\n >\n <ng-template let-item pTemplate>\n <i\n [class]=\"item.icon\"\n [pTooltip]=\"item.tooltip || (item.tooltipKey | translate)\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n ></i>\n <label style=\"display: none\" id=\"{{item.id}}\"> {{item.label ? item.label : item.labelKey | translate}} </label>\n </ng-template>\n </p-selectButton>\n </div>\n <div class=\"w-full flex justify-content-center\">\n <p-chart\n id=\"diagram\"\n [type]=\"chartType\"\n [data]=\"chartData\"\n [responsive]=\"false\"\n [options]=\"chartOptions\"\n (onDataSelect)=\"dataClicked($event)\"\n [ariaLabel]=\"(data ? 'OCX_DIAGRAM.ARIA_LABEL' : 'OCX_DIAGRAM.EMPTY_ARIA_LABEL') | translate: {total: generateTotal(data), valueString: generateDiagramValueString(data)}\"\n ></p-chart>\n </div>\n <div class=\"w-full flex justify-content-center mt-2 sumKey\">\n <p class=\"text-md font-medium text-700\">\n <span name=\"sumLabel\"> {{ sumKey | translate }}</span> : <span name=\"amountOfData\">{{ amountOfData}}</span>\n </p>\n </div>\n</ng-container>\n\n<div *ngIf=\"!this.data\" class=\"w-full flex justify-content-center\">\n <p-message severity=\"info\" text=\"{{ 'OCX_DIAGRAM.NO_DATA' | translate }}\"></p-message>\n</div>\n", styles: ["::ng-deep .p-buttonset .p-button{min-width:auto}::ng-deep .p-buttonset{display:flex}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i5.SelectButton, selector: "p-selectButton", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "style", "styleClass", "ariaLabelledBy", "disabled", "dataKey", "autofocus"], outputs: ["onOptionClick", "onChange"] }, { kind: "component", type: i6.UIChart, selector: "p-chart", inputs: ["type", "plugins", "width", "height", "responsive", "ariaLabel", "ariaLabelledBy", "data", "options"], outputs: ["onDataSelect"] }, { kind: "component", type: i7.UIMessage, selector: "p-message", inputs: ["severity", "text", "escape", "style", "styleClass"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
|
|
158
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: DiagramComponent, selector: "ocx-diagram", inputs: { data: "data", sumKey: "sumKey", fillMissingColors: "fillMissingColors", diagramType: "diagramType", supportedDiagramTypes: "supportedDiagramTypes" }, outputs: { dataSelected: "dataSelected", diagramTypeChanged: "diagramTypeChanged", componentStateChanged: "componentStateChanged" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"this.data\">\n <div class=\"flex justify-content-center pb-2\" *ngIf=\"shownDiagramTypes.length > 1\">\n <p-selectButton\n [options]=\"shownDiagramTypes\"\n [(ngModel)]=\"selectedDiagramType\"\n optionLabel=\"id\"\n (onChange)=\"onDiagramTypeChanged($event)\"\n name=\"diagram-type-select-button\"\n >\n <ng-template let-item pTemplate>\n <i\n [class]=\"item.icon\"\n [pTooltip]=\"item.tooltip || (item.tooltipKey | translate)\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n ></i>\n <label style=\"display: none\" id=\"{{item.id}}\"> {{item.label ? item.label : item.labelKey | translate}} </label>\n </ng-template>\n </p-selectButton>\n </div>\n <div class=\"w-full flex justify-content-center\">\n <p-chart\n id=\"diagram\"\n [type]=\"chartType\"\n [data]=\"chartData\"\n [responsive]=\"false\"\n [options]=\"chartOptions\"\n (onDataSelect)=\"dataClicked($event)\"\n [ariaLabel]=\"(data ? 'OCX_DIAGRAM.ARIA_LABEL' : 'OCX_DIAGRAM.EMPTY_ARIA_LABEL') | translate: {total: generateTotal(data), valueString: generateDiagramValueString(data)}\"\n ></p-chart>\n </div>\n <div class=\"w-full flex justify-content-center mt-2 sumKey\">\n <p class=\"text-md font-medium text-700\">\n <span name=\"sumLabel\"> {{ sumKey | translate }}</span> : <span name=\"amountOfData\">{{ amountOfData}}</span>\n </p>\n </div>\n</ng-container>\n\n<div *ngIf=\"!this.data\" class=\"w-full flex justify-content-center\">\n <p-message severity=\"info\" text=\"{{ 'OCX_DIAGRAM.NO_DATA' | translate }}\"></p-message>\n</div>\n", styles: ["::ng-deep .p-buttonset .p-button{min-width:auto}::ng-deep .p-buttonset{display:flex}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i5.SelectButton, selector: "p-selectButton", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "style", "styleClass", "ariaLabelledBy", "disabled", "dataKey", "autofocus"], outputs: ["onOptionClick", "onChange"] }, { kind: "component", type: i6.UIChart, selector: "p-chart", inputs: ["type", "plugins", "width", "height", "responsive", "ariaLabel", "ariaLabelledBy", "data", "options"], outputs: ["onDataSelect"] }, { kind: "component", type: i7.UIMessage, selector: "p-message", inputs: ["severity", "text", "escape", "style", "styleClass"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
|
|
138
159
|
}
|
|
139
160
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: DiagramComponent, decorators: [{
|
|
140
161
|
type: Component,
|
|
@@ -143,6 +164,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
143
164
|
type: Input
|
|
144
165
|
}], sumKey: [{
|
|
145
166
|
type: Input
|
|
167
|
+
}], fillMissingColors: [{
|
|
168
|
+
type: Input
|
|
146
169
|
}], diagramType: [{
|
|
147
170
|
type: Input
|
|
148
171
|
}], supportedDiagramTypes: [{
|
|
@@ -157,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
157
180
|
function interpolateColors(amountOfData, colorScale, colorRangeInfo) {
|
|
158
181
|
return ColorUtils.interpolateColors(amountOfData, colorScale, colorRangeInfo);
|
|
159
182
|
}
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"diagram.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/diagram/diagram.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/diagram/diagram.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { ChartData, ChartOptions } from 'chart.js'\nimport * as d3 from 'd3-scale-chromatic'\nimport { PrimeIcons } from 'primeng/api'\nimport { DiagramData } from '../../model/diagram-data'\nimport { DiagramType } from '../../model/diagram-type'\nimport { ColorUtils } from '../../utils/colorutils'\nimport { PrimeIcon } from '../../utils/primeicon.utils'\n\nexport interface DiagramLayouts {\n  id: string\n  icon: PrimeIcon\n  layout: DiagramType\n  tooltip?: string\n  tooltipKey: string\n  label?: string\n  labelKey: string\n}\n\nexport interface DiagramComponentState {\n  activeDiagramType?: DiagramType\n}\n\nconst allDiagramTypes: DiagramLayouts[] = [\n  {\n    id: 'diagram-pie',\n    icon: PrimeIcons.CHART_PIE,\n    layout: DiagramType.PIE,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',\n  },\n  {\n    id: 'diagram-horizontal-bar',\n    icon: PrimeIcons.BARS,\n    layout: DiagramType.HORIZONTAL_BAR,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',\n  },\n  {\n    id: 'diagram-vertical-bar',\n    icon: PrimeIcons.CHART_BAR,\n    layout: DiagramType.VERTICAL_BAR,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',\n  },\n]\n\n@Component({\n  selector: 'ocx-diagram',\n  templateUrl: './diagram.component.html',\n  styleUrls: ['./diagram.component.scss'],\n})\nexport class DiagramComponent implements OnInit, OnChanges {\n  @Input() data: DiagramData[] | undefined\n  @Input() sumKey = 'OCX_DIAGRAM.SUM'\n  private _diagramType: DiagramType = DiagramType.PIE\n  selectedDiagramType: DiagramLayouts | undefined\n  public chartType: 'bar' | 'line' | 'scatter' | 'bubble' | 'pie' | 'doughnut' | 'polarArea' | 'radar' = 'pie'\n  @Input()\n  get diagramType(): DiagramType {\n    return this._diagramType\n  }\n  set diagramType(value: DiagramType) {\n    this._diagramType = value\n    this.selectedDiagramType = allDiagramTypes.find((v) => v.layout === value)\n    this.chartType = this.diagramTypeToChartType(value)\n  }\n  private _supportedDiagramTypes: DiagramType[] = []\n  @Input()\n  get supportedDiagramTypes(): DiagramType[] {\n    return this._supportedDiagramTypes\n  }\n  set supportedDiagramTypes(value: DiagramType[]) {\n    this._supportedDiagramTypes = value\n    this.shownDiagramTypes = allDiagramTypes.filter((vl) => this.supportedDiagramTypes.includes(vl.layout))\n  }\n  @Output() dataSelected: EventEmitter<any> = new EventEmitter()\n  @Output() diagramTypeChanged: EventEmitter<DiagramType> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<DiagramComponentState> = new EventEmitter()\n  chartOptions: ChartOptions | undefined\n  chartData: ChartData | undefined\n  amountOfData: number | undefined | null\n  shownDiagramTypes: DiagramLayouts[] = []\n  // Changing the colorRangeInfo, will change the range of the color palette of the diagram.\n  private colorRangeInfo = {\n    colorStart: 0,\n    colorEnd: 1,\n    useEndAsStart: false,\n  }\n  // Changing the colorScale, will change the thematic color appearance of the diagram.\n  private colorScale = d3.interpolateCool\n\n  constructor(private translateService: TranslateService) {}\n\n  ngOnChanges(): void {\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n  }\n  ngOnInit(): void {\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n  }\n\n  public generateChart(colorScale: any, colorRangeInfo: any) {\n    if (this.data) {\n      const inputData = this.data.map((diagramData) => diagramData.value)\n\n      this.amountOfData = this.data.reduce((acc, current) => acc + current.value, 0)\n      const COLORS = interpolateColors(this.data.length, colorScale, colorRangeInfo)\n      this.chartData = {\n        labels: this.data.map((data) => data.label),\n        datasets: [\n          {\n            data: inputData,\n            backgroundColor: COLORS,\n          },\n        ],\n      }\n    }\n\n    this.chartOptions = {\n      plugins: {\n        legend: {\n          position: 'bottom',\n        },\n      },\n      maintainAspectRatio: false,\n      ...(this._diagramType === DiagramType.VERTICAL_BAR && {\n        plugins: { legend: { display: false } },\n        scales: { y: { ticks: { precision: 0 } } },\n      }),\n      ...(this._diagramType === DiagramType.HORIZONTAL_BAR && {\n        indexAxis: 'y',\n        plugins: { legend: { display: false } },\n        scales: { x: { ticks: { precision: 0 } } },\n      }),\n    }\n  }\n\n  generateTotal(data: DiagramData[]): number {\n    return data.reduce((acc, current) => acc + current.value, 0)\n  }\n\n  generateDiagramValueString(data: DiagramData[]): string {\n    return data.map((item) => `${item.label}:${item.value}`).join(', ')\n  }\n\n  private diagramTypeToChartType(\n    value: DiagramType\n  ): 'bar' | 'line' | 'scatter' | 'bubble' | 'pie' | 'doughnut' | 'polarArea' | 'radar' {\n    if (value === DiagramType.PIE) return 'pie'\n    else if (value === DiagramType.HORIZONTAL_BAR || value === DiagramType.VERTICAL_BAR) return 'bar'\n    return 'pie'\n  }\n\n  dataClicked(event: []) {\n    this.dataSelected.emit(event.length)\n  }\n\n  onDiagramTypeChanged(event: any) {\n    this.diagramType = event.value.layout\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n    this.diagramTypeChanged.emit(event.value.layout)\n    this.componentStateChanged.emit({\n      activeDiagramType: event.value.layout,\n    })\n  }\n}\nfunction interpolateColors(amountOfData: number, colorScale: any, colorRangeInfo: any) {\n  return ColorUtils.interpolateColors(amountOfData, colorScale, colorRangeInfo)\n}\n","<ng-container *ngIf=\"this.data\">\n  <div class=\"flex justify-content-center pb-2\" *ngIf=\"shownDiagramTypes.length > 1\">\n    <p-selectButton\n      [options]=\"shownDiagramTypes\"\n      [(ngModel)]=\"selectedDiagramType\"\n      optionLabel=\"id\"\n      (onChange)=\"onDiagramTypeChanged($event)\"\n      name=\"diagram-type-select-button\"\n    >\n      <ng-template let-item pTemplate>\n        <i\n          [class]=\"item.icon\"\n          [pTooltip]=\"item.tooltip || (item.tooltipKey | translate)\"\n          tooltipPosition=\"top\"\n          tooltipEvent=\"hover\"\n        ></i>\n        <label style=\"display: none\" id=\"{{item.id}}\"> {{item.label ? item.label : item.labelKey | translate}} </label>\n      </ng-template>\n    </p-selectButton>\n  </div>\n  <div class=\"w-full flex justify-content-center\">\n    <p-chart\n      id=\"diagram\"\n      [type]=\"chartType\"\n      [data]=\"chartData\"\n      [responsive]=\"false\"\n      [options]=\"chartOptions\"\n      (onDataSelect)=\"dataClicked($event)\"\n      [ariaLabel]=\"(data ? 'OCX_DIAGRAM.ARIA_LABEL' : 'OCX_DIAGRAM.EMPTY_ARIA_LABEL') | translate: {total: generateTotal(data), valueString: generateDiagramValueString(data)}\"\n    ></p-chart>\n  </div>\n  <div class=\"w-full flex justify-content-center mt-2 sumKey\">\n    <p class=\"text-md font-medium text-700\">\n      <span name=\"sumLabel\"> {{ sumKey | translate }}</span> : <span name=\"amountOfData\">{{ amountOfData}}</span>\n    </p>\n  </div>\n</ng-container>\n\n<div *ngIf=\"!this.data\" class=\"w-full flex justify-content-center\">\n  <p-message severity=\"info\" text=\"{{ 'OCX_DIAGRAM.NO_DATA' | translate }}\"></p-message>\n</div>\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"diagram.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/diagram/diagram.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/diagram/diagram.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { ChartData, ChartOptions } from 'chart.js'\nimport * as d3 from 'd3-scale-chromatic'\nimport { PrimeIcons } from 'primeng/api'\nimport { DiagramData } from '../../model/diagram-data'\nimport { DiagramType } from '../../model/diagram-type'\nimport { ColorUtils } from '../../utils/colorutils'\nimport { PrimeIcon } from '../../utils/primeicon.utils'\n\nexport interface DiagramLayouts {\n  id: string\n  icon: PrimeIcon\n  layout: DiagramType\n  tooltip?: string\n  tooltipKey: string\n  label?: string\n  labelKey: string\n}\n\nexport interface DiagramComponentState {\n  activeDiagramType?: DiagramType\n}\n\nconst allDiagramTypes: DiagramLayouts[] = [\n  {\n    id: 'diagram-pie',\n    icon: PrimeIcons.CHART_PIE,\n    layout: DiagramType.PIE,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.PIE',\n  },\n  {\n    id: 'diagram-horizontal-bar',\n    icon: PrimeIcons.BARS,\n    layout: DiagramType.HORIZONTAL_BAR,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.HORIZONTAL_BAR',\n  },\n  {\n    id: 'diagram-vertical-bar',\n    icon: PrimeIcons.CHART_BAR,\n    layout: DiagramType.VERTICAL_BAR,\n    tooltipKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',\n    labelKey: 'OCX_DIAGRAM.SWITCH_DIAGRAM_TYPE.VERTICAL_BAR',\n  },\n]\n\n@Component({\n  selector: 'ocx-diagram',\n  templateUrl: './diagram.component.html',\n  styleUrls: ['./diagram.component.scss'],\n})\nexport class DiagramComponent implements OnInit, OnChanges {\n  @Input() data: DiagramData[] | undefined\n  @Input() sumKey = 'OCX_DIAGRAM.SUM'\n  /**\n   * This property determines if diagram should generate the colors for the data that does not have any set.\n   *\n   * Setting this property to false will result in using the provided colors only if every data item has one. In the scenario where at least one item does not have a color set, diagram will generate all colors.\n   */\n  @Input() fillMissingColors = true\n  private _diagramType: DiagramType = DiagramType.PIE\n  selectedDiagramType: DiagramLayouts | undefined\n  public chartType: 'bar' | 'line' | 'scatter' | 'bubble' | 'pie' | 'doughnut' | 'polarArea' | 'radar' = 'pie'\n  @Input()\n  get diagramType(): DiagramType {\n    return this._diagramType\n  }\n  set diagramType(value: DiagramType) {\n    this._diagramType = value\n    this.selectedDiagramType = allDiagramTypes.find((v) => v.layout === value)\n    this.chartType = this.diagramTypeToChartType(value)\n  }\n  private _supportedDiagramTypes: DiagramType[] = []\n  @Input()\n  get supportedDiagramTypes(): DiagramType[] {\n    return this._supportedDiagramTypes\n  }\n  set supportedDiagramTypes(value: DiagramType[]) {\n    this._supportedDiagramTypes = value\n    this.shownDiagramTypes = allDiagramTypes.filter((vl) => this.supportedDiagramTypes.includes(vl.layout))\n  }\n  @Output() dataSelected: EventEmitter<any> = new EventEmitter()\n  @Output() diagramTypeChanged: EventEmitter<DiagramType> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<DiagramComponentState> = new EventEmitter()\n  chartOptions: ChartOptions | undefined\n  chartData: ChartData | undefined\n  amountOfData: number | undefined | null\n  shownDiagramTypes: DiagramLayouts[] = []\n  // Changing the colorRangeInfo, will change the range of the color palette of the diagram.\n  private colorRangeInfo = {\n    colorStart: 0,\n    colorEnd: 1,\n    useEndAsStart: false,\n  }\n  // Changing the colorScale, will change the thematic color appearance of the diagram.\n  private colorScale = d3.interpolateCool\n\n  constructor(private translateService: TranslateService) {}\n\n  ngOnChanges(): void {\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n  }\n  ngOnInit(): void {\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n  }\n\n  public generateChart(colorScale: any, colorRangeInfo: any) {\n    if (this.data) {\n      const inputData = this.data.map((diagramData) => diagramData.value)\n\n      this.amountOfData = this.data.reduce((acc, current) => acc + current.value, 0)\n      const COLORS = this.generateColors(this.data, colorScale, colorRangeInfo)\n      this.chartData = {\n        labels: this.data.map((data) => data.label),\n        datasets: [\n          {\n            data: inputData,\n            backgroundColor: COLORS,\n          },\n        ],\n      }\n    }\n\n    this.chartOptions = {\n      plugins: {\n        legend: {\n          position: 'bottom',\n        },\n      },\n      maintainAspectRatio: false,\n      ...(this._diagramType === DiagramType.VERTICAL_BAR && {\n        plugins: { legend: { display: false } },\n        scales: { y: { ticks: { precision: 0 } } },\n      }),\n      ...(this._diagramType === DiagramType.HORIZONTAL_BAR && {\n        indexAxis: 'y',\n        plugins: { legend: { display: false } },\n        scales: { x: { ticks: { precision: 0 } } },\n      }),\n    }\n  }\n\n  generateColors(data: DiagramData[], colorScale: any, colorRangeInfo: any) {\n    const dataColors = data.map((diagramData) => diagramData.backgroundColor)\n    if (dataColors.filter((v) => v !== undefined).length === data.length) {\n      return dataColors\n    } else if (this.fillMissingColors) {\n      // it is intended to generate more colors than needed, so interval for generated colors is same as amount of items on the diagram\n      const interpolatedColors = interpolateColors(dataColors.length, colorScale, colorRangeInfo)\n      let interpolatedIndex = 0\n      return dataColors.map((color) => (color === undefined ? interpolatedColors[interpolatedIndex++] : color))\n    } else {\n      return interpolateColors(data.length, colorScale, colorRangeInfo)\n    }\n  }\n\n  generateTotal(data: DiagramData[]): number {\n    return data.reduce((acc, current) => acc + current.value, 0)\n  }\n\n  generateDiagramValueString(data: DiagramData[]): string {\n    return data.map((item) => `${item.label}:${item.value}`).join(', ')\n  }\n\n  private diagramTypeToChartType(\n    value: DiagramType\n  ): 'bar' | 'line' | 'scatter' | 'bubble' | 'pie' | 'doughnut' | 'polarArea' | 'radar' {\n    if (value === DiagramType.PIE) return 'pie'\n    else if (value === DiagramType.HORIZONTAL_BAR || value === DiagramType.VERTICAL_BAR) return 'bar'\n    return 'pie'\n  }\n\n  dataClicked(event: []) {\n    this.dataSelected.emit(event.length)\n  }\n\n  onDiagramTypeChanged(event: any) {\n    this.diagramType = event.value.layout\n    this.generateChart(this.colorScale, this.colorRangeInfo)\n    this.diagramTypeChanged.emit(event.value.layout)\n    this.componentStateChanged.emit({\n      activeDiagramType: event.value.layout,\n    })\n  }\n}\nfunction interpolateColors(amountOfData: number, colorScale: any, colorRangeInfo: any) {\n  return ColorUtils.interpolateColors(amountOfData, colorScale, colorRangeInfo)\n}\n","<ng-container *ngIf=\"this.data\">\n  <div class=\"flex justify-content-center pb-2\" *ngIf=\"shownDiagramTypes.length > 1\">\n    <p-selectButton\n      [options]=\"shownDiagramTypes\"\n      [(ngModel)]=\"selectedDiagramType\"\n      optionLabel=\"id\"\n      (onChange)=\"onDiagramTypeChanged($event)\"\n      name=\"diagram-type-select-button\"\n    >\n      <ng-template let-item pTemplate>\n        <i\n          [class]=\"item.icon\"\n          [pTooltip]=\"item.tooltip || (item.tooltipKey | translate)\"\n          tooltipPosition=\"top\"\n          tooltipEvent=\"hover\"\n        ></i>\n        <label style=\"display: none\" id=\"{{item.id}}\"> {{item.label ? item.label : item.labelKey | translate}} </label>\n      </ng-template>\n    </p-selectButton>\n  </div>\n  <div class=\"w-full flex justify-content-center\">\n    <p-chart\n      id=\"diagram\"\n      [type]=\"chartType\"\n      [data]=\"chartData\"\n      [responsive]=\"false\"\n      [options]=\"chartOptions\"\n      (onDataSelect)=\"dataClicked($event)\"\n      [ariaLabel]=\"(data ? 'OCX_DIAGRAM.ARIA_LABEL' : 'OCX_DIAGRAM.EMPTY_ARIA_LABEL') | translate: {total: generateTotal(data), valueString: generateDiagramValueString(data)}\"\n    ></p-chart>\n  </div>\n  <div class=\"w-full flex justify-content-center mt-2 sumKey\">\n    <p class=\"text-md font-medium text-700\">\n      <span name=\"sumLabel\"> {{ sumKey | translate }}</span> : <span name=\"amountOfData\">{{ amountOfData}}</span>\n    </p>\n  </div>\n</ng-container>\n\n<div *ngIf=\"!this.data\" class=\"w-full flex justify-content-center\">\n  <p-message severity=\"info\" text=\"{{ 'OCX_DIAGRAM.NO_DATA' | translate }}\"></p-message>\n</div>\n"]}
|
|
@@ -42,30 +42,44 @@ export class GroupByCountDiagramComponent {
|
|
|
42
42
|
this.columnType = value.columnType;
|
|
43
43
|
this.columnField = value.id;
|
|
44
44
|
}
|
|
45
|
+
get colors() {
|
|
46
|
+
return this._colors$.getValue();
|
|
47
|
+
}
|
|
48
|
+
set colors(value) {
|
|
49
|
+
this._colors$.next(value);
|
|
50
|
+
}
|
|
45
51
|
constructor(translateService) {
|
|
46
52
|
this.translateService = translateService;
|
|
47
53
|
this.sumKey = 'SEARCH.SUMMARY_TITLE';
|
|
48
54
|
this.diagramType = "PIE" /* DiagramType.PIE */;
|
|
55
|
+
/**
|
|
56
|
+
* This property determines if diagram should generate the colors for the data that does not have any set.
|
|
57
|
+
*
|
|
58
|
+
* Setting this property to false will result in using the provided colors only if every data item has one. In the scenario where at least one item does not have a color set, diagram will generate all colors.
|
|
59
|
+
*/
|
|
60
|
+
this.fillMissingColors = true;
|
|
49
61
|
this.supportedDiagramTypes = [];
|
|
50
62
|
this._data$ = new BehaviorSubject([]);
|
|
51
63
|
this._columnType$ = new BehaviorSubject(ColumnType.STRING);
|
|
52
64
|
this._columnField$ = new BehaviorSubject('');
|
|
65
|
+
this._colors$ = new BehaviorSubject({});
|
|
53
66
|
this.dataSelected = new EventEmitter();
|
|
54
67
|
this.diagramTypeChanged = new EventEmitter();
|
|
55
68
|
this.componentStateChanged = new EventEmitter();
|
|
56
69
|
}
|
|
57
70
|
ngOnInit() {
|
|
58
|
-
this.diagramData$ = combineLatest([this._data$, this._columnField$, this._columnType$]).pipe(mergeMap(([data, columnField, columnType]) => {
|
|
71
|
+
this.diagramData$ = combineLatest([this._data$, this._columnField$, this._columnType$, this._colors$]).pipe(mergeMap(([data, columnField, columnType, colors]) => {
|
|
59
72
|
const columnData = data.map((d) => ObjectUtils.resolveFieldData(d, columnField));
|
|
60
73
|
const occurrences = columnData.reduce((acc, current) => {
|
|
61
74
|
return acc.some((e) => e.label === current)
|
|
62
75
|
? (acc.find((e) => e.label === current).value++, acc)
|
|
63
|
-
: [...acc, { label: current, value: 1 }];
|
|
76
|
+
: [...acc, { label: current, value: 1, backgroundColor: colors[current.toString()] }];
|
|
64
77
|
}, []);
|
|
65
78
|
if (columnType === ColumnType.TRANSLATION_KEY && occurrences.length > 0) {
|
|
66
79
|
return this.translateService.get(occurrences.map((o) => o.label)).pipe(map((translations) => occurrences.map((o) => ({
|
|
67
80
|
label: translations[o.label],
|
|
68
81
|
value: o.value,
|
|
82
|
+
backgroundColor: o.backgroundColor,
|
|
69
83
|
}))));
|
|
70
84
|
}
|
|
71
85
|
else {
|
|
@@ -80,19 +94,21 @@ export class GroupByCountDiagramComponent {
|
|
|
80
94
|
this.diagramType = newDiagramType;
|
|
81
95
|
this.diagramTypeChanged.emit(newDiagramType);
|
|
82
96
|
this.componentStateChanged.emit({
|
|
83
|
-
activeDiagramType: newDiagramType
|
|
97
|
+
activeDiagramType: newDiagramType,
|
|
84
98
|
});
|
|
85
99
|
}
|
|
86
100
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: GroupByCountDiagramComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
87
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: GroupByCountDiagramComponent, selector: "ocx-group-by-count-diagram", inputs: { sumKey: "sumKey", diagramType: "diagramType", type: "type", supportedDiagramTypes: "supportedDiagramTypes", data: "data", columnType: "columnType", columnField: "columnField", column: "column" }, outputs: { dataSelected: "dataSelected", diagramTypeChanged: "diagramTypeChanged", componentStateChanged: "componentStateChanged" }, ngImport: i0, template: "<ocx-diagram\n [data]=\"(diagramData$ | async) || []\"\n [sumKey]=\"sumKey\"\n [diagramType]=\"diagramType\"\n (onDataSelect)=\"dataClicked($event)\"\n [supportedDiagramTypes]=\"supportedDiagramTypes\"\n (diagramTypeChanged)=\"onDiagramTypeChanged($event)\"\n></ocx-diagram>\n", dependencies: [{ kind: "component", type: i2.DiagramComponent, selector: "ocx-diagram", inputs: ["data", "sumKey", "diagramType", "supportedDiagramTypes"], outputs: ["dataSelected", "diagramTypeChanged", "componentStateChanged"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
|
|
101
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: GroupByCountDiagramComponent, selector: "ocx-group-by-count-diagram", inputs: { sumKey: "sumKey", diagramType: "diagramType", fillMissingColors: "fillMissingColors", type: "type", supportedDiagramTypes: "supportedDiagramTypes", data: "data", columnType: "columnType", columnField: "columnField", column: "column", colors: "colors" }, outputs: { dataSelected: "dataSelected", diagramTypeChanged: "diagramTypeChanged", componentStateChanged: "componentStateChanged" }, ngImport: i0, template: "<ocx-diagram\n [data]=\"(diagramData$ | async) || []\"\n [fillMissingColors]=\"fillMissingColors\"\n [sumKey]=\"sumKey\"\n [diagramType]=\"diagramType\"\n (onDataSelect)=\"dataClicked($event)\"\n [supportedDiagramTypes]=\"supportedDiagramTypes\"\n (diagramTypeChanged)=\"onDiagramTypeChanged($event)\"\n></ocx-diagram>\n", dependencies: [{ kind: "component", type: i2.DiagramComponent, selector: "ocx-diagram", inputs: ["data", "sumKey", "fillMissingColors", "diagramType", "supportedDiagramTypes"], outputs: ["dataSelected", "diagramTypeChanged", "componentStateChanged"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
|
|
88
102
|
}
|
|
89
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: GroupByCountDiagramComponent, decorators: [{
|
|
90
104
|
type: Component,
|
|
91
|
-
args: [{ selector: 'ocx-group-by-count-diagram', template: "<ocx-diagram\n [data]=\"(diagramData$ | async) || []\"\n [sumKey]=\"sumKey\"\n [diagramType]=\"diagramType\"\n (onDataSelect)=\"dataClicked($event)\"\n [supportedDiagramTypes]=\"supportedDiagramTypes\"\n (diagramTypeChanged)=\"onDiagramTypeChanged($event)\"\n></ocx-diagram>\n" }]
|
|
105
|
+
args: [{ selector: 'ocx-group-by-count-diagram', template: "<ocx-diagram\n [data]=\"(diagramData$ | async) || []\"\n [fillMissingColors]=\"fillMissingColors\"\n [sumKey]=\"sumKey\"\n [diagramType]=\"diagramType\"\n (onDataSelect)=\"dataClicked($event)\"\n [supportedDiagramTypes]=\"supportedDiagramTypes\"\n (diagramTypeChanged)=\"onDiagramTypeChanged($event)\"\n></ocx-diagram>\n" }]
|
|
92
106
|
}], ctorParameters: () => [{ type: i1.TranslateService }], propDecorators: { sumKey: [{
|
|
93
107
|
type: Input
|
|
94
108
|
}], diagramType: [{
|
|
95
109
|
type: Input
|
|
110
|
+
}], fillMissingColors: [{
|
|
111
|
+
type: Input
|
|
96
112
|
}], type: [{
|
|
97
113
|
type: Input
|
|
98
114
|
}], supportedDiagramTypes: [{
|
|
@@ -105,6 +121,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
105
121
|
type: Input
|
|
106
122
|
}], column: [{
|
|
107
123
|
type: Input
|
|
124
|
+
}], colors: [{
|
|
125
|
+
type: Input
|
|
108
126
|
}], dataSelected: [{
|
|
109
127
|
type: Output
|
|
110
128
|
}], diagramTypeChanged: [{
|
|
@@ -112,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
112
130
|
}], componentStateChanged: [{
|
|
113
131
|
type: Output
|
|
114
132
|
}] } });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-by-count-diagram.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { BehaviorSubject, Observable, combineLatest, map, mergeMap, of } from 'rxjs'\nimport { ColumnType } from '../../model/column-type.model'\nimport { DiagramColumn } from '../../model/diagram-column'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { DiagramData } from '../../model/diagram-data'\nimport { DiagramType } from '../../model/diagram-type'\n\nexport interface GroupByCountDiagramComponentState {\n  activeDiagramType?: DiagramType\n}\n\n@Component({\n  selector: 'ocx-group-by-count-diagram',\n  templateUrl: './group-by-count-diagram.component.html',\n})\nexport class GroupByCountDiagramComponent implements OnInit {\n  @Input() sumKey = 'SEARCH.SUMMARY_TITLE'\n  @Input() diagramType = DiagramType.PIE\n  /**\n   * @deprecated Will be replaced by diagramType\n   */\n  @Input()\n  get type(): DiagramType {\n    return this.diagramType\n  }\n  set type(value: DiagramType) {\n    this.diagramType = value\n  }\n  @Input() supportedDiagramTypes: DiagramType[] = []\n  private _data$ = new BehaviorSubject<unknown[]>([])\n  @Input()\n  get data(): unknown[] {\n    return this._data$.getValue()\n  }\n  set data(value: unknown[]) {\n    this._data$.next(value)\n  }\n  diagramData$: Observable<DiagramData[]> | undefined\n\n  private _columnType$ = new BehaviorSubject<ColumnType>(ColumnType.STRING)\n  @Input()\n  get columnType(): ColumnType {\n    return this._columnType$.getValue()\n  }\n  set columnType(value: ColumnType) {\n    this._columnType$.next(value)\n  }\n\n  private _columnField$ = new BehaviorSubject<string>('')\n  @Input()\n  get columnField(): string {\n    return this._columnField$.getValue()\n  }\n  set columnField(value: string) {\n    this._columnField$.next(value)\n  }\n\n  @Input()\n  get column(): DiagramColumn {\n    return { columnType: this.columnType, id: this.columnField }\n  }\n  set column(value: DiagramColumn) {\n    this.columnType = value.columnType\n    this.columnField = value.id\n  }\n\n  @Output() dataSelected: EventEmitter<any> = new EventEmitter()\n  @Output() diagramTypeChanged: EventEmitter<DiagramType> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<GroupByCountDiagramComponentState> = new EventEmitter()\n\n  constructor(private translateService: TranslateService) {}\n\n  ngOnInit(): void {\n    this.diagramData$ = combineLatest([this._data$, this._columnField$, this._columnType$]).pipe(\n      mergeMap(([data, columnField, columnType]) => {\n        const columnData = data.map((d) => ObjectUtils.resolveFieldData(d, columnField))\n        const occurrences = columnData.reduce((acc, current) => {\n          return acc.some((e: { label: any }) => e.label === current)\n            ? (acc.find((e: { label: any }) => e.label === current).value++, acc)\n            : [...acc, { label: current, value: 1 }]\n        }, [])\n        if (columnType === ColumnType.TRANSLATION_KEY && occurrences.length > 0) {\n          return this.translateService.get(occurrences.map((o: { label: any }) => o.label)).pipe(\n            map((translations: { [x: string]: any }) =>\n              occurrences.map((o: { label: string; value: any }) => ({\n                label: translations[o.label],\n                value: o.value,\n              }))\n            )\n          )\n        } else {\n          return of(occurrences)\n        }\n      })\n    )\n  }\n\n  dataClicked(event: any) {\n    this.dataSelected.emit(event)\n  }\n\n  onDiagramTypeChanged(newDiagramType: DiagramType) {\n    this.diagramType = newDiagramType\n    this.diagramTypeChanged.emit(newDiagramType)\n    this.componentStateChanged.emit({\n      activeDiagramType: newDiagramType\n    })\n  }\n}\n","<ocx-diagram\n  [data]=\"(diagramData$ | async) || []\"\n  [sumKey]=\"sumKey\"\n  [diagramType]=\"diagramType\"\n  (onDataSelect)=\"dataClicked($event)\"\n  [supportedDiagramTypes]=\"supportedDiagramTypes\"\n  (diagramTypeChanged)=\"onDiagramTypeChanged($event)\"\n></ocx-diagram>\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-by-count-diagram.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/group-by-count-diagram/group-by-count-diagram.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { BehaviorSubject, Observable, combineLatest, map, mergeMap, of } from 'rxjs'\nimport { ColumnType } from '../../model/column-type.model'\nimport { DiagramColumn } from '../../model/diagram-column'\nimport { ObjectUtils } from '../../utils/objectutils'\nimport { DiagramData } from '../../model/diagram-data'\nimport { DiagramType } from '../../model/diagram-type'\n\nexport interface GroupByCountDiagramComponentState {\n  activeDiagramType?: DiagramType\n}\n\n@Component({\n  selector: 'ocx-group-by-count-diagram',\n  templateUrl: './group-by-count-diagram.component.html',\n})\nexport class GroupByCountDiagramComponent implements OnInit {\n  @Input() sumKey = 'SEARCH.SUMMARY_TITLE'\n  @Input() diagramType = DiagramType.PIE\n  /**\n   * This property determines if diagram should generate the colors for the data that does not have any set.\n   *\n   * Setting this property to false will result in using the provided colors only if every data item has one. In the scenario where at least one item does not have a color set, diagram will generate all colors.\n   */\n  @Input() fillMissingColors = true\n  /**\n   * @deprecated Will be replaced by diagramType\n   */\n  @Input()\n  get type(): DiagramType {\n    return this.diagramType\n  }\n  set type(value: DiagramType) {\n    this.diagramType = value\n  }\n  @Input() supportedDiagramTypes: DiagramType[] = []\n  private _data$ = new BehaviorSubject<unknown[]>([])\n  @Input()\n  get data(): unknown[] {\n    return this._data$.getValue()\n  }\n  set data(value: unknown[]) {\n    this._data$.next(value)\n  }\n  diagramData$: Observable<DiagramData[]> | undefined\n\n  private _columnType$ = new BehaviorSubject<ColumnType>(ColumnType.STRING)\n  @Input()\n  get columnType(): ColumnType {\n    return this._columnType$.getValue()\n  }\n  set columnType(value: ColumnType) {\n    this._columnType$.next(value)\n  }\n\n  private _columnField$ = new BehaviorSubject<string>('')\n  @Input()\n  get columnField(): string {\n    return this._columnField$.getValue()\n  }\n  set columnField(value: string) {\n    this._columnField$.next(value)\n  }\n\n  @Input()\n  get column(): DiagramColumn {\n    return { columnType: this.columnType, id: this.columnField }\n  }\n  set column(value: DiagramColumn) {\n    this.columnType = value.columnType\n    this.columnField = value.id\n  }\n\n  private _colors$ = new BehaviorSubject<Record<string, string>>({})\n  @Input()\n  get colors(): Record<string, string> {\n    return this._colors$.getValue()\n  }\n  set colors(value: Record<string, string>) {\n    this._colors$.next(value)\n  }\n\n  @Output() dataSelected: EventEmitter<any> = new EventEmitter()\n  @Output() diagramTypeChanged: EventEmitter<DiagramType> = new EventEmitter()\n  @Output() componentStateChanged: EventEmitter<GroupByCountDiagramComponentState> = new EventEmitter()\n\n  constructor(private translateService: TranslateService) {}\n\n  ngOnInit(): void {\n    this.diagramData$ = combineLatest([this._data$, this._columnField$, this._columnType$, this._colors$]).pipe(\n      mergeMap(([data, columnField, columnType, colors]) => {\n        const columnData = data.map((d) => ObjectUtils.resolveFieldData(d, columnField))\n        const occurrences = columnData.reduce((acc, current) => {\n          return acc.some((e: { label: any }) => e.label === current)\n            ? (acc.find((e: { label: any }) => e.label === current).value++, acc)\n            : [...acc, { label: current, value: 1, backgroundColor: colors[current.toString()] }]\n        }, [])\n        if (columnType === ColumnType.TRANSLATION_KEY && occurrences.length > 0) {\n          return this.translateService.get(occurrences.map((o: { label: any }) => o.label)).pipe(\n            map((translations: { [x: string]: any }) =>\n              occurrences.map((o: { label: string; value: any; backgroundColor: string | undefined }) => ({\n                label: translations[o.label],\n                value: o.value,\n                backgroundColor: o.backgroundColor,\n              }))\n            )\n          )\n        } else {\n          return of(occurrences)\n        }\n      })\n    )\n  }\n\n  dataClicked(event: any) {\n    this.dataSelected.emit(event)\n  }\n\n  onDiagramTypeChanged(newDiagramType: DiagramType) {\n    this.diagramType = newDiagramType\n    this.diagramTypeChanged.emit(newDiagramType)\n    this.componentStateChanged.emit({\n      activeDiagramType: newDiagramType,\n    })\n  }\n}\n","<ocx-diagram\n  [data]=\"(diagramData$ | async) || []\"\n  [fillMissingColors]=\"fillMissingColors\"\n  [sumKey]=\"sumKey\"\n  [diagramType]=\"diagramType\"\n  (onDataSelect)=\"dataClicked($event)\"\n  [supportedDiagramTypes]=\"supportedDiagramTypes\"\n  (diagramTypeChanged)=\"onDiagramTypeChanged($event)\"\n></ocx-diagram>\n"]}
|
|
@@ -138,6 +138,7 @@ export class PageHeaderComponent {
|
|
|
138
138
|
});
|
|
139
139
|
this.overflowActions = [
|
|
140
140
|
...allowedActions.map((a) => ({
|
|
141
|
+
id: a.id,
|
|
141
142
|
label: a.labelKey ? translations[a.labelKey] : a.label,
|
|
142
143
|
icon: a.icon,
|
|
143
144
|
tooltipOptions: {
|
|
@@ -194,11 +195,11 @@ export class PageHeaderComponent {
|
|
|
194
195
|
}
|
|
195
196
|
}
|
|
196
197
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: PageHeaderComponent, deps: [{ token: i1.BreadcrumbService }, { token: i2.TranslateService }, { token: i3.AppStateService }, { token: i3.UserService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
197
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: PageHeaderComponent, selector: "ocx-page-header", inputs: { header: "header", loading: "loading", figureBackground: "figureBackground", showFigure: "showFigure", figureImage: "figureImage", disableDefaultActions: "disableDefaultActions", subheader: "subheader", actions: "actions", objectDetails: "objectDetails", showBreadcrumbs: "showBreadcrumbs", manualBreadcrumbs: "manualBreadcrumbs", enableGridView: "enableGridView", gridLayoutDesktopColumns: "gridLayoutDesktopColumns" }, outputs: { save: "save" }, queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n <ng-container *ngIf=\"showBreadcrumbs\">\n <p-breadcrumb\n [model]=\"items\"\n *ngIf=\"breadcrumbs$ | async as items\"\n [home]=\"(home$ | async)?.menuItem ?? {}\"\n [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n [attr.manual]=\"manualBreadcrumbs\"\n ></p-breadcrumb>\n </ng-container>\n <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n <div class=\"title-wrap\">\n <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n <ng-content select=\"[figureImage]\"></ng-content>\n <img\n *ngIf=\"figureImage && !figureImageLoadError\"\n [ocxSrc]=\"figureImage\"\n alt=\"Figure image\"\n class=\"w-full\"\n (error)=\"handleImageError()\"\n />\n </div>\n <div\n class=\"colorblob flex-1 border-round\"\n *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n ></div>\n </div>\n <ng-template #skeletonBar>\n <div class=\"header justify-content-evenly\">\n <p-skeleton width=\"10rem\"></p-skeleton>\n <p-skeleton width=\"10rem\"></p-skeleton>\n </div>\n </ng-template>\n <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n </div>\n </div>\n <div class=\"action-items-wrap mt-2 md:mt-0\">\n <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n </ng-container>\n\n <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n <ng-template #skeletonActions>\n <div class=\"flex\">\n <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n </div>\n </ng-template>\n <ng-container *ngIf=\"!loading; else skeletonActions\">\n <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n <ng-container *ngFor=\"let action of inlineActions\">\n <p-button\n id=\"{{ action.id }}\"\n [icon]=\"action.icon ?? ''\"\n type=\"button\"\n class=\"action-button\"\n [label]=\"action.labelKey ? (action.labelKey | translate) : action.label\"\n (onClick)=\"action.actionCallback()\"\n [pTooltip]=\"(action.titleKey ? (action.titleKey | translate) : action.title)\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [disabled]=\"action.disabled ? action.disabled : false\"\n [attr.name]=\"action.icon ? 'ocx-page-header-inline-action-icon-button' : 'ocx-page-header-inline-action-button'\"\n [ariaLabel]=\" (action.ariaLabelKey ? (action.ariaLabelKey | translate) : action.ariaLabel) || (action.titleKey ? (action.titleKey | translate) : action.title) || (action.labelKey ? (action.labelKey | translate) : action.label)\"\n ></p-button>\n </ng-container>\n </div>\n <ng-content select=\"[toolbarItems]\"></ng-content>\n <ng-container>\n <div *ngIf=\"overflowActions.length !== 0\">\n <button\n id=\"pageHeaderMenuButton\"\n type=\"button\"\n pButton\n icon=\"pi pi-ellipsis-v\"\n pTooltip=\"{{ 'OCX_PAGE_HEADER.MORE_ACTIONS' | translate }}\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n class=\"more-actions-menu-button action-button ml-2\"\n (click)=\"menu.toggle($event)\"\n name=\"ocx-page-header-overflow-action-button\"\n [attr.aria-label]=\"('OCX_PAGE_HEADER.MORE_ACTIONS' | translate)\"\n ></button>\n <p-menu #menu [popup]=\"true\" [model]=\"overflowActions\" appendTo=\"body\"></p-menu>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"additionalToolbarContent\" [ngTemplateOutlet]=\"additionalToolbarContent\"> </ng-container>\n </div>\n </div>\n\n <div class=\"object-panel\" [ngClass]=\"getObjectPanelLayoutClasses()\">\n <ng-container *ngIf=\"objectDetails\">\n <div class=\"object-info\" [ngClass]=\"getObjectInfoLayoutClasses()\" *ngFor=\"let item of objectDetails\">\n <span\n class=\"flex font-medium text-600 object-info-grid-label\"\n name=\"object-detail-label\"\n [pTooltip]=\"item.labelTooltip || ''\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n >{{ item.label | dynamicPipe:item.labelPipe }}</span\n >\n <span *ngIf=\"item.icon || item.value\" class=\"object-info-grid-value\">\n <span\n class=\"flex text-900 align-items-center gap-2 w-max\"\n [ngClass]=\"generateItemStyle(item)\"\n name=\"object-detail-value\"\n >\n <span\n class=\"flex align-items-center gap-2\"\n [pTooltip]=\"item.valueTooltip || item.tooltip || ''\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n >\n <i\n *ngIf=\"item.icon\"\n class='{{item.icon + \" \" + (item.iconStyleClass || \"\")}}'\n name=\"object-detail-icon\"\n ></i>\n {{ item.value | dynamicPipe:item.valuePipe:item.valuePipeArgs}}\n </span>\n <p-button\n *ngIf=\"item.actionItemIcon && item.actionItemCallback\"\n [icon]=\"item.actionItemIcon\"\n styleClass=\"p-button-text p-0 w-full\"\n [pTooltip]=\"item.actionItemTooltip || ''\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [ariaLabel]=\"(item.actionItemAriaLabelKey ? (item.actionItemAriaLabelKey | translate) : item.actionItemAriaLabel) || item.actionItemTooltip || ''\"\n (onClick)=\"item.actionItemCallback()\"\n ></p-button>\n </span>\n </span>\n </div>\n </ng-container>\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [":host(.p-button-label){font-weight:400}.onecx-page-header{display:flex;flex-flow:column;border-radius:.25rem;overflow:hidden;background:#fff;-webkit-box-shadow:0 2px 2px 0 rgba(0,0,0,.1);box-shadow:0 2px 2px #0000001a;border:1px solid #cdd0d3}.onecx-page-header .title-bar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;background-color:#f8f9fa;border-top-right-radius:inherit;border-top-left-radius:inherit}.onecx-page-header .title-bar .figure{width:3rem;height:3rem;margin-right:.5rem;position:relative}.onecx-page-header .title-bar .figure .figure-image img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.onecx-page-header .title-bar .figure .colorblob{background-color:var(--primary-color);position:absolute;inset:0}.onecx-page-header .title-bar .title-wrap{display:flex;flex-flow:row;align-items:center;gap:.25rem}.onecx-page-header .title-bar .title-wrap .header{display:flex;align-items:flex-start;justify-content:center;flex-direction:column}.onecx-page-header .title-bar .title-wrap h1{font-size:1em;font-weight:700;margin:0;padding:0}.onecx-page-header .title-bar .title-wrap h2{font-size:1em;font-weight:400;margin:0;padding:0}.onecx-page-header .title-bar .action-items-wrap{display:flex;height:fit-content;gap:.5rem;align-items:center;justify-content:space-between}.onecx-page-header .object-panel{border-top:1px solid #cdd0d3;padding:1rem}.onecx-page-header .object-panel:empty{display:none!important}.badge-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.scale{transform:scale(2)}.object-info-grid-label{flex:1}.object-info-grid-value{flex:3}.min-w-120{min-width:120px!important}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.Breadcrumb, selector: "p-breadcrumb", inputs: ["model", "style", "styleClass", "home", "homeAriaLabel"], outputs: ["onItemClick"] }, { kind: "directive", type: i6.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i7.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i7.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i8.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaLabel", "ariaLabelledBy", "id", "tabindex"], outputs: ["onShow", "onHide", "onBlur", "onFocus"] }, { kind: "component", type: i9.Skeleton, selector: "p-skeleton", inputs: ["styleClass", "style", "shape", "animation", "borderRadius", "size", "width", "height"] }, { kind: "directive", type: i10.SrcDirective, selector: "[ocxSrc]", inputs: ["ocxSrc"], outputs: ["error"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i11.DynamicPipe, name: "dynamicPipe" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
198
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: PageHeaderComponent, selector: "ocx-page-header", inputs: { header: "header", loading: "loading", figureBackground: "figureBackground", showFigure: "showFigure", figureImage: "figureImage", disableDefaultActions: "disableDefaultActions", subheader: "subheader", actions: "actions", objectDetails: "objectDetails", showBreadcrumbs: "showBreadcrumbs", manualBreadcrumbs: "manualBreadcrumbs", enableGridView: "enableGridView", gridLayoutDesktopColumns: "gridLayoutDesktopColumns" }, outputs: { save: "save" }, queries: [{ propertyName: "additionalToolbarContent", first: true, predicate: ["additionalToolbarContent"], descendants: true }, { propertyName: "additionalToolbarContentLeft", first: true, predicate: ["additionalToolbarContentLeft"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n <ng-container *ngIf=\"showBreadcrumbs\">\n <p-breadcrumb\n [model]=\"items\"\n *ngIf=\"breadcrumbs$ | async as items\"\n [home]=\"(home$ | async)?.menuItem ?? {}\"\n [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n [attr.manual]=\"manualBreadcrumbs\"\n ></p-breadcrumb>\n </ng-container>\n <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n <div class=\"title-wrap\">\n <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n <ng-content select=\"[figureImage]\"></ng-content>\n <img\n *ngIf=\"figureImage && !figureImageLoadError\"\n [ocxSrc]=\"figureImage\"\n alt=\"Figure image\"\n class=\"w-full\"\n (error)=\"handleImageError()\"\n />\n </div>\n <div\n class=\"colorblob flex-1 border-round\"\n *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n ></div>\n </div>\n <ng-template #skeletonBar>\n <div class=\"header justify-content-evenly\">\n <p-skeleton width=\"10rem\"></p-skeleton>\n <p-skeleton width=\"10rem\"></p-skeleton>\n </div>\n </ng-template>\n <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n </div>\n </div>\n <div class=\"action-items-wrap mt-2 md:mt-0\">\n <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n </ng-container>\n\n <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n <ng-template #skeletonActions>\n <div class=\"flex\">\n <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n </div>\n </ng-template>\n <ng-container *ngIf=\"!loading; else skeletonActions\">\n <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n <ng-container *ngFor=\"let action of inlineActions\">\n <span\n [pTooltip]=\"action.disabled ? (action.disabledTooltipKey ? (action.disabledTooltipKey | translate) : action.disabledTooltip) : (action.titleKey ? (action.titleKey | translate) : action.title)\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n >\n <p-button\n id=\"{{ action.id }}\"\n [icon]=\"action.icon ?? ''\"\n type=\"button\"\n class=\"action-button\"\n [label]=\"action.labelKey ? (action.labelKey | translate) : action.label\"\n (onClick)=\"action.actionCallback()\"\n [disabled]=\"action.disabled ? action.disabled : false\"\n [attr.name]=\"action.icon ? 'ocx-page-header-inline-action-icon-button' : 'ocx-page-header-inline-action-button'\"\n [ariaLabel]=\" (action.ariaLabelKey ? (action.ariaLabelKey | translate) : action.ariaLabel) || (action.titleKey ? (action.titleKey | translate) : action.title) || (action.labelKey ? (action.labelKey | translate) : action.label)\"\n ></p-button>\n </span>\n </ng-container>\n </div>\n <ng-content select=\"[toolbarItems]\"></ng-content>\n <ng-container>\n <div *ngIf=\"overflowActions.length !== 0\">\n <button\n id=\"pageHeaderMenuButton\"\n type=\"button\"\n pButton\n icon=\"pi pi-ellipsis-v\"\n pTooltip=\"{{ 'OCX_PAGE_HEADER.MORE_ACTIONS' | translate }}\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n class=\"more-actions-menu-button action-button ml-2\"\n (click)=\"menu.toggle($event)\"\n name=\"ocx-page-header-overflow-action-button\"\n [attr.aria-label]=\"('OCX_PAGE_HEADER.MORE_ACTIONS' | translate)\"\n ></button>\n <p-menu #menu [popup]=\"true\" [model]=\"overflowActions\" appendTo=\"body\"></p-menu>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"additionalToolbarContent\" [ngTemplateOutlet]=\"additionalToolbarContent\"> </ng-container>\n </div>\n </div>\n\n <div class=\"object-panel\" [ngClass]=\"getObjectPanelLayoutClasses()\">\n <ng-container *ngIf=\"objectDetails\">\n <div class=\"object-info\" [ngClass]=\"getObjectInfoLayoutClasses()\" *ngFor=\"let item of objectDetails\">\n <span\n class=\"flex font-medium text-600 object-info-grid-label\"\n name=\"object-detail-label\"\n [pTooltip]=\"item.labelTooltip || ''\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n >{{ item.label | dynamicPipe:item.labelPipe }}</span\n >\n <span *ngIf=\"item.icon || item.value\" class=\"object-info-grid-value\">\n <span\n class=\"flex text-900 align-items-center gap-2 w-max\"\n [ngClass]=\"generateItemStyle(item)\"\n name=\"object-detail-value\"\n >\n <span\n class=\"flex align-items-center gap-2\"\n [pTooltip]=\"item.valueTooltip || item.tooltip || ''\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n >\n <i\n *ngIf=\"item.icon\"\n class='{{item.icon + \" \" + (item.iconStyleClass || \"\")}}'\n name=\"object-detail-icon\"\n ></i>\n {{ item.value | dynamicPipe:item.valuePipe:item.valuePipeArgs}}\n </span>\n <p-button\n *ngIf=\"item.actionItemIcon && item.actionItemCallback\"\n [icon]=\"item.actionItemIcon\"\n styleClass=\"p-button-text p-0 w-full\"\n [pTooltip]=\"item.actionItemTooltip || ''\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [ariaLabel]=\"(item.actionItemAriaLabelKey ? (item.actionItemAriaLabelKey | translate) : item.actionItemAriaLabel) || item.actionItemTooltip || ''\"\n (onClick)=\"item.actionItemCallback()\"\n ></p-button>\n </span>\n </span>\n </div>\n </ng-container>\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [":host(.p-button-label){font-weight:400}.onecx-page-header{display:flex;flex-flow:column;border-radius:.25rem;overflow:hidden;background:#fff;-webkit-box-shadow:0 2px 2px 0 rgba(0,0,0,.1);box-shadow:0 2px 2px #0000001a;border:1px solid #cdd0d3}.onecx-page-header .title-bar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;background-color:#f8f9fa;border-top-right-radius:inherit;border-top-left-radius:inherit}.onecx-page-header .title-bar .figure{width:3rem;height:3rem;margin-right:.5rem;position:relative}.onecx-page-header .title-bar .figure .figure-image img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.onecx-page-header .title-bar .figure .colorblob{background-color:var(--primary-color);position:absolute;inset:0}.onecx-page-header .title-bar .title-wrap{display:flex;flex-flow:row;align-items:center;gap:.25rem}.onecx-page-header .title-bar .title-wrap .header{display:flex;align-items:flex-start;justify-content:center;flex-direction:column}.onecx-page-header .title-bar .title-wrap h1{font-size:1em;font-weight:700;margin:0;padding:0}.onecx-page-header .title-bar .title-wrap h2{font-size:1em;font-weight:400;margin:0;padding:0}.onecx-page-header .title-bar .action-items-wrap{display:flex;height:fit-content;gap:.5rem;align-items:center;justify-content:space-between}.onecx-page-header .object-panel{border-top:1px solid #cdd0d3;padding:1rem}.onecx-page-header .object-panel:empty{display:none!important}.badge-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.scale{transform:scale(2)}.object-info-grid-label{flex:1}.object-info-grid-value{flex:3}.min-w-120{min-width:120px!important}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.Breadcrumb, selector: "p-breadcrumb", inputs: ["model", "style", "styleClass", "home", "homeAriaLabel"], outputs: ["onItemClick"] }, { kind: "directive", type: i6.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i7.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i7.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i8.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaLabel", "ariaLabelledBy", "id", "tabindex"], outputs: ["onShow", "onHide", "onBlur", "onFocus"] }, { kind: "component", type: i9.Skeleton, selector: "p-skeleton", inputs: ["styleClass", "style", "shape", "animation", "borderRadius", "size", "width", "height"] }, { kind: "directive", type: i10.SrcDirective, selector: "[ocxSrc]", inputs: ["ocxSrc"], outputs: ["error"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i11.DynamicPipe, name: "dynamicPipe" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
198
199
|
}
|
|
199
200
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: PageHeaderComponent, decorators: [{
|
|
200
201
|
type: Component,
|
|
201
|
-
args: [{ selector: 'ocx-page-header', encapsulation: ViewEncapsulation.None, template: "<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n <ng-container *ngIf=\"showBreadcrumbs\">\n <p-breadcrumb\n [model]=\"items\"\n *ngIf=\"breadcrumbs$ | async as items\"\n [home]=\"(home$ | async)?.menuItem ?? {}\"\n [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n [attr.manual]=\"manualBreadcrumbs\"\n ></p-breadcrumb>\n </ng-container>\n <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n <div class=\"title-wrap\">\n <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n <ng-content select=\"[figureImage]\"></ng-content>\n <img\n *ngIf=\"figureImage && !figureImageLoadError\"\n [ocxSrc]=\"figureImage\"\n alt=\"Figure image\"\n class=\"w-full\"\n (error)=\"handleImageError()\"\n />\n </div>\n <div\n class=\"colorblob flex-1 border-round\"\n *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n ></div>\n </div>\n <ng-template #skeletonBar>\n <div class=\"header justify-content-evenly\">\n <p-skeleton width=\"10rem\"></p-skeleton>\n <p-skeleton width=\"10rem\"></p-skeleton>\n </div>\n </ng-template>\n <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n </div>\n </div>\n <div class=\"action-items-wrap mt-2 md:mt-0\">\n <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n </ng-container>\n\n <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n <ng-template #skeletonActions>\n <div class=\"flex\">\n <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n </div>\n </ng-template>\n <ng-container *ngIf=\"!loading; else skeletonActions\">\n <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n <ng-container *ngFor=\"let action of inlineActions\">\n <p-button\n
|
|
202
|
+
args: [{ selector: 'ocx-page-header', encapsulation: ViewEncapsulation.None, template: "<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n <ng-container *ngIf=\"showBreadcrumbs\">\n <p-breadcrumb\n [model]=\"items\"\n *ngIf=\"breadcrumbs$ | async as items\"\n [home]=\"(home$ | async)?.menuItem ?? {}\"\n [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n [attr.manual]=\"manualBreadcrumbs\"\n ></p-breadcrumb>\n </ng-container>\n <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n <div class=\"title-wrap\">\n <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n <ng-content select=\"[figureImage]\"></ng-content>\n <img\n *ngIf=\"figureImage && !figureImageLoadError\"\n [ocxSrc]=\"figureImage\"\n alt=\"Figure image\"\n class=\"w-full\"\n (error)=\"handleImageError()\"\n />\n </div>\n <div\n class=\"colorblob flex-1 border-round\"\n *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n ></div>\n </div>\n <ng-template #skeletonBar>\n <div class=\"header justify-content-evenly\">\n <p-skeleton width=\"10rem\"></p-skeleton>\n <p-skeleton width=\"10rem\"></p-skeleton>\n </div>\n </ng-template>\n <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n </div>\n </div>\n <div class=\"action-items-wrap mt-2 md:mt-0\">\n <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n </ng-container>\n\n <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n <ng-template #skeletonActions>\n <div class=\"flex\">\n <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n </div>\n </ng-template>\n <ng-container *ngIf=\"!loading; else skeletonActions\">\n <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n <ng-container *ngFor=\"let action of inlineActions\">\n <span\n [pTooltip]=\"action.disabled ? (action.disabledTooltipKey ? (action.disabledTooltipKey | translate) : action.disabledTooltip) : (action.titleKey ? (action.titleKey | translate) : action.title)\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n >\n <p-button\n id=\"{{ action.id }}\"\n [icon]=\"action.icon ?? ''\"\n type=\"button\"\n class=\"action-button\"\n [label]=\"action.labelKey ? (action.labelKey | translate) : action.label\"\n (onClick)=\"action.actionCallback()\"\n [disabled]=\"action.disabled ? action.disabled : false\"\n [attr.name]=\"action.icon ? 'ocx-page-header-inline-action-icon-button' : 'ocx-page-header-inline-action-button'\"\n [ariaLabel]=\" (action.ariaLabelKey ? (action.ariaLabelKey | translate) : action.ariaLabel) || (action.titleKey ? (action.titleKey | translate) : action.title) || (action.labelKey ? (action.labelKey | translate) : action.label)\"\n ></p-button>\n </span>\n </ng-container>\n </div>\n <ng-content select=\"[toolbarItems]\"></ng-content>\n <ng-container>\n <div *ngIf=\"overflowActions.length !== 0\">\n <button\n id=\"pageHeaderMenuButton\"\n type=\"button\"\n pButton\n icon=\"pi pi-ellipsis-v\"\n pTooltip=\"{{ 'OCX_PAGE_HEADER.MORE_ACTIONS' | translate }}\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n class=\"more-actions-menu-button action-button ml-2\"\n (click)=\"menu.toggle($event)\"\n name=\"ocx-page-header-overflow-action-button\"\n [attr.aria-label]=\"('OCX_PAGE_HEADER.MORE_ACTIONS' | translate)\"\n ></button>\n <p-menu #menu [popup]=\"true\" [model]=\"overflowActions\" appendTo=\"body\"></p-menu>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"additionalToolbarContent\" [ngTemplateOutlet]=\"additionalToolbarContent\"> </ng-container>\n </div>\n </div>\n\n <div class=\"object-panel\" [ngClass]=\"getObjectPanelLayoutClasses()\">\n <ng-container *ngIf=\"objectDetails\">\n <div class=\"object-info\" [ngClass]=\"getObjectInfoLayoutClasses()\" *ngFor=\"let item of objectDetails\">\n <span\n class=\"flex font-medium text-600 object-info-grid-label\"\n name=\"object-detail-label\"\n [pTooltip]=\"item.labelTooltip || ''\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n >{{ item.label | dynamicPipe:item.labelPipe }}</span\n >\n <span *ngIf=\"item.icon || item.value\" class=\"object-info-grid-value\">\n <span\n class=\"flex text-900 align-items-center gap-2 w-max\"\n [ngClass]=\"generateItemStyle(item)\"\n name=\"object-detail-value\"\n >\n <span\n class=\"flex align-items-center gap-2\"\n [pTooltip]=\"item.valueTooltip || item.tooltip || ''\"\n tooltipEvent=\"hover\"\n tooltipPosition=\"top\"\n >\n <i\n *ngIf=\"item.icon\"\n class='{{item.icon + \" \" + (item.iconStyleClass || \"\")}}'\n name=\"object-detail-icon\"\n ></i>\n {{ item.value | dynamicPipe:item.valuePipe:item.valuePipeArgs}}\n </span>\n <p-button\n *ngIf=\"item.actionItemIcon && item.actionItemCallback\"\n [icon]=\"item.actionItemIcon\"\n styleClass=\"p-button-text p-0 w-full\"\n [pTooltip]=\"item.actionItemTooltip || ''\"\n tooltipPosition=\"top\"\n tooltipEvent=\"hover\"\n [ariaLabel]=\"(item.actionItemAriaLabelKey ? (item.actionItemAriaLabelKey | translate) : item.actionItemAriaLabel) || item.actionItemTooltip || ''\"\n (onClick)=\"item.actionItemCallback()\"\n ></p-button>\n </span>\n </span>\n </div>\n </ng-container>\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [":host(.p-button-label){font-weight:400}.onecx-page-header{display:flex;flex-flow:column;border-radius:.25rem;overflow:hidden;background:#fff;-webkit-box-shadow:0 2px 2px 0 rgba(0,0,0,.1);box-shadow:0 2px 2px #0000001a;border:1px solid #cdd0d3}.onecx-page-header .title-bar{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;background-color:#f8f9fa;border-top-right-radius:inherit;border-top-left-radius:inherit}.onecx-page-header .title-bar .figure{width:3rem;height:3rem;margin-right:.5rem;position:relative}.onecx-page-header .title-bar .figure .figure-image img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.onecx-page-header .title-bar .figure .colorblob{background-color:var(--primary-color);position:absolute;inset:0}.onecx-page-header .title-bar .title-wrap{display:flex;flex-flow:row;align-items:center;gap:.25rem}.onecx-page-header .title-bar .title-wrap .header{display:flex;align-items:flex-start;justify-content:center;flex-direction:column}.onecx-page-header .title-bar .title-wrap h1{font-size:1em;font-weight:700;margin:0;padding:0}.onecx-page-header .title-bar .title-wrap h2{font-size:1em;font-weight:400;margin:0;padding:0}.onecx-page-header .title-bar .action-items-wrap{display:flex;height:fit-content;gap:.5rem;align-items:center;justify-content:space-between}.onecx-page-header .object-panel{border-top:1px solid #cdd0d3;padding:1rem}.onecx-page-header .object-panel:empty{display:none!important}.badge-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.scale{transform:scale(2)}.object-info-grid-label{flex:1}.object-info-grid-value{flex:3}.min-w-120{min-width:120px!important}\n"] }]
|
|
202
203
|
}], ctorParameters: () => [{ type: i1.BreadcrumbService }, { type: i2.TranslateService }, { type: i3.AppStateService }, { type: i3.UserService }], propDecorators: { header: [{
|
|
203
204
|
type: Input
|
|
204
205
|
}], loading: [{
|
|
@@ -234,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
234
235
|
type: ContentChild,
|
|
235
236
|
args: ['additionalToolbarContentLeft']
|
|
236
237
|
}] } });
|
|
237
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewEncapsulation,\n} from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { MenuItem, PrimeIcons } from 'primeng/api'\nimport { concat, map, Observable, of } from 'rxjs'\nimport { AppStateService } from '@onecx/angular-integration-interface'\nimport { UserService } from '@onecx/angular-integration-interface'\nimport { BreadcrumbService } from '../../services/breadcrumb.service'\nimport { PrimeIcon } from '../../utils/primeicon.utils'\n\n/**\n * Action definition.\n */\nexport interface Action {\n  id?: string\n  label?: string\n  labelKey?: string\n  icon?: string\n  /**\n   * Permission for this action. If the current user does not have this permission, the action will not be shown.\n   */\n  permission?: string\n  title?: string\n  titleKey?: string\n  ariaLabel?: string\n  ariaLabelKey?: string\n  btnClass?: string\n  actionCallback(): void\n  disabled?: boolean\n  show?: 'always' | 'asOverflow'\n  conditional?: boolean\n  // Note: This currently doesn't work with dynamic values, since a passed in Action is just a copy of the original object.\n  // As a workaround, you can manually update/replace the passed in Action if you wish to update a showCondition\n  showCondition?: boolean\n}\n\nexport interface ObjectDetailItem {\n  label: string\n  value?: string\n  /**\n   * @deprecated Use `valueTooltip` instead\n   */\n  tooltip?: string\n  labelTooltip?: string\n  valueTooltip?: string\n  icon?: PrimeIcon\n  iconStyleClass?: string\n  labelPipe?: Type<any>\n  valuePipe?: Type<any>\n  valuePipeArgs?: string\n  valueCssClass?: string\n  actionItemIcon?: PrimeIcon\n  actionItemCallback?: () => void\n  actionItemTooltip?: string\n  actionItemAriaLabelKey?: string\n  actionItemAriaLabel?: string\n}\n\nexport interface HomeItem {\n  menuItem: MenuItem\n  page?: string\n}\n\nexport type GridColumnOptions = 1 | 2 | 3 | 4 | 6 | 12\n\n@Component({\n  selector: 'ocx-page-header',\n  templateUrl: './page-header.component.html',\n  styleUrls: ['./page-header.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class PageHeaderComponent implements OnInit, OnChanges {\n  @Input()\n  public header: string | undefined\n\n  @Input()\n  loading = false\n\n  @Input()\n  figureBackground = true\n\n  @Input()\n  showFigure = true\n\n  //image fot preview in top-header left side\n  @Input()\n  figureImage: string | undefined\n\n  @Input()\n  disableDefaultActions = false\n\n  @Input()\n  subheader: string | undefined\n\n  _actions: Action[] | undefined\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  @Input()\n  objectDetails: ObjectDetailItem[] | undefined\n\n  @Input()\n  showBreadcrumbs = true\n\n  @Input()\n  manualBreadcrumbs = false\n\n  @Input()\n  enableGridView: undefined | boolean\n\n  @Input()\n  gridLayoutDesktopColumns: undefined | GridColumnOptions\n\n  @Output()\n  save = new EventEmitter()\n\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  overflowActions: MenuItem[] = []\n  inlineActions: Action[] | undefined\n  dd = new Date()\n  breadcrumbs$!: Observable<MenuItem[]>\n\n  home$!: Observable<HomeItem>\n\n  figureImageLoadError = false\n\n  objectPanelGridLayoutClasses = 'grid row-gap-2 m-0'\n  objectPanelColumnLayoutClasses = 'flex flex-row justify-content-between overflow-x-auto'\n\n  objectPanelDefaultLayoutClasses = 'flex flex-column row-gap-2 md:flex-row md:justify-content-between'\n\n  objectInfoGridLayoutClasses = 'col-12 flex gap-4 md:col-6 align-items-center p-0'\n  objectInfoColumnLayoutClasses = 'flex flex-column align-items-center gap-2 min-w-120'\n\n  objectInfoDefaultLayoutClasses = 'flex flex-row md:flex-column md:align-items-center md:gap-2'\n\n  protected breadcrumbs: BreadcrumbService\n\n  constructor(\n    breadcrumbs: BreadcrumbService,\n    private translateService: TranslateService,\n    private appStateService: AppStateService,\n    private userService: UserService\n  ) {\n    this.breadcrumbs = breadcrumbs\n    this.home$ = concat(\n      of({ menuItem: { icon: PrimeIcons.HOME, routerLink: '/' } }),\n      this.appStateService.currentPortal$.pipe(\n        map((portal) => ({\n          menuItem: {\n            icon: PrimeIcons.HOME,\n            routerLink: portal.baseUrl,\n          },\n          page: portal.portalName,\n        }))\n      )\n    )\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['actions']) {\n      this.generateInlineActions()\n      this.generateOverflowActions()\n    }\n  }\n\n  ngOnInit(): void {\n    if (!this.manualBreadcrumbs) {\n      this.breadcrumbs$ = this.breadcrumbs.generatedItemsSource\n    } else {\n      this.breadcrumbs$ = this.breadcrumbs.itemsHandler\n    }\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  onAction(action: string) {\n    switch (action) {\n      case 'save':\n        this.save.emit()\n        break\n      default:\n        break\n    }\n  }\n\n  handleImageError() {\n    this.figureImageLoadError = true\n  }\n\n  public generateItemStyle(item: ObjectDetailItem): string {\n    let style = ''\n    if (item.icon) style = style.concat(style, ' ', 'gap-1 align-items-center')\n    if (item.valueCssClass) style = style.concat(style, ' ', item.valueCssClass)\n    return style\n  }\n\n  public getObjectPanelLayoutClasses() {\n    if (this.enableGridView) {\n      return this.objectPanelGridLayoutClasses\n    }\n    if (this.enableGridView === false) {\n      return this.objectPanelColumnLayoutClasses\n    }\n    return this.objectPanelDefaultLayoutClasses\n  }\n\n  public getObjectInfoLayoutClasses() {\n    if (this.enableGridView) {\n      return `${this.objectInfoGridLayoutClasses} lg:col-${\n        this.gridLayoutDesktopColumns ? 12 / this.gridLayoutDesktopColumns : 4\n      }`\n    }\n    if (this.enableGridView === false) {\n      return this.objectInfoColumnLayoutClasses\n    }\n    return this.objectInfoDefaultLayoutClasses\n  }\n\n  /**\n   * Generates a list of actions that should be rendered in an overflow menu\n   */\n  private generateOverflowActions() {\n    if (this.actions) {\n      const translationKeys: string[] = [\n        ...this.actions.map((a) => a.labelKey || '').filter((a) => !!a),\n        ...this.actions.map((a) => a.titleKey || '').filter((a) => !!a),\n      ]\n      const translations$ = translationKeys.length ? this.translateService.get(translationKeys) : of([])\n      translations$.subscribe((translations) => {\n        const allowedActions: Action[] = []\n        if (this.actions) {\n          this.actions\n            .filter((a) => a.show === 'asOverflow')\n            .filter((a) => {\n              if (a.conditional) {\n                if (a.showCondition) return a\n                return null\n              } else return a\n            })\n            .forEach((action) => {\n              this.checkActionPermission(allowedActions, action)\n            })\n          this.overflowActions = [\n            ...allowedActions.map<MenuItem>((a) => ({\n              label: a.labelKey ? translations[a.labelKey] : a.label,\n              icon: a.icon,\n              tooltipOptions: {\n                tooltipLabel: a.titleKey ? translations[a.titleKey] : a.title,\n                tooltipEvent: 'hover',\n                tooltipPosition: 'top',\n              },\n              command: a.actionCallback,\n              disabled: a.disabled,\n            })),\n          ]\n        }\n      })\n    }\n  }\n\n  /**\n   * Generates a list of actions that should be rendered as inline buttons\n   */\n  private generateInlineActions() {\n    if (this.actions) {\n      // Temp array to hold all inline actions that should be visible to the current user\n      const allowedActions: Action[] = []\n      // Check permissions for all actions that should be rendered 'always'\n      this.actions\n        .filter((a) => a.show === 'always')\n        .filter((a) => {\n          if (a.conditional) {\n            return a.showCondition ? a : null\n          } else return a\n        })\n        .forEach((action) => {\n          this.checkActionPermission(allowedActions, action)\n        })\n      this.inlineActions = [...allowedActions]\n    }\n  }\n  /**\n   * Adds a given action to a given array if the current user is allowed to see it\n   * @param allowedActions Array that the action should be added to if the current user is allowed to see it\n   * @param action Action for which a permission check should be executed\n   */\n  private checkActionPermission(allowedActions: Action[], action: Action) {\n    if (action.permission) {\n      if (this.userService.hasPermission(action.permission)) {\n        // Push action to allowed array if user has sufficient permissions\n        allowedActions.push(action)\n      }\n    } else {\n      // Push action to allowed array if no permission was specified\n      allowedActions.push(action)\n    }\n  }\n}\n","<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n  <ng-container *ngIf=\"showBreadcrumbs\">\n    <p-breadcrumb\n      [model]=\"items\"\n      *ngIf=\"breadcrumbs$ | async  as items\"\n      [home]=\"(home$ | async)?.menuItem ?? {}\"\n      [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n      [attr.manual]=\"manualBreadcrumbs\"\n    ></p-breadcrumb>\n  </ng-container>\n  <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n    <div class=\"title-wrap\">\n      <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n        <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n          <ng-content select=\"[figureImage]\"></ng-content>\n          <img\n            *ngIf=\"figureImage && !figureImageLoadError\"\n            [ocxSrc]=\"figureImage\"\n            alt=\"Figure image\"\n            class=\"w-full\"\n            (error)=\"handleImageError()\"\n          />\n        </div>\n        <div\n          class=\"colorblob flex-1 border-round\"\n          *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n        ></div>\n      </div>\n      <ng-template #skeletonBar>\n        <div class=\"header justify-content-evenly\">\n          <p-skeleton width=\"10rem\"></p-skeleton>\n          <p-skeleton width=\"10rem\"></p-skeleton>\n        </div>\n      </ng-template>\n      <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n        <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n        <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n      </div>\n    </div>\n    <div class=\"action-items-wrap mt-2 md:mt-0\">\n      <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n      </ng-container>\n\n      <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n      <ng-template #skeletonActions>\n        <div class=\"flex\">\n          <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n          <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n        </div>\n      </ng-template>\n      <ng-container *ngIf=\"!loading; else skeletonActions\">\n        <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n          <ng-container *ngFor=\"let action of inlineActions\">\n            <p-button\n              id=\"{{ action.id }}\"\n              [icon]=\"action.icon ?? ''\"\n              type=\"button\"\n              class=\"action-button\"\n              [label]=\"action.labelKey ? (action.labelKey | translate) : action.label\"\n              (onClick)=\"action.actionCallback()\"\n              [pTooltip]=\"(action.titleKey ? (action.titleKey | translate) : action.title)\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n              [disabled]=\"action.disabled ? action.disabled : false\"\n              [attr.name]=\"action.icon ? 'ocx-page-header-inline-action-icon-button' : 'ocx-page-header-inline-action-button'\"\n              [ariaLabel]=\" (action.ariaLabelKey ? (action.ariaLabelKey | translate) : action.ariaLabel) || (action.titleKey ? (action.titleKey | translate) : action.title) || (action.labelKey ? (action.labelKey | translate) : action.label)\"\n            ></p-button>\n          </ng-container>\n        </div>\n        <ng-content select=\"[toolbarItems]\"></ng-content>\n        <ng-container>\n          <div *ngIf=\"overflowActions.length !== 0\">\n            <button\n              id=\"pageHeaderMenuButton\"\n              type=\"button\"\n              pButton\n              icon=\"pi pi-ellipsis-v\"\n              pTooltip=\"{{ 'OCX_PAGE_HEADER.MORE_ACTIONS' | translate }}\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n              class=\"more-actions-menu-button action-button ml-2\"\n              (click)=\"menu.toggle($event)\"\n              name=\"ocx-page-header-overflow-action-button\"\n              [attr.aria-label]=\"('OCX_PAGE_HEADER.MORE_ACTIONS' | translate)\"\n            ></button>\n            <p-menu #menu [popup]=\"true\" [model]=\"overflowActions\" appendTo=\"body\"></p-menu>\n          </div>\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"additionalToolbarContent\" [ngTemplateOutlet]=\"additionalToolbarContent\"> </ng-container>\n    </div>\n  </div>\n\n  <div class=\"object-panel\" [ngClass]=\"getObjectPanelLayoutClasses()\">\n    <ng-container *ngIf=\"objectDetails\">\n      <div class=\"object-info\" [ngClass]=\"getObjectInfoLayoutClasses()\" *ngFor=\"let item of objectDetails\">\n        <span\n          class=\"flex font-medium text-600 object-info-grid-label\"\n          name=\"object-detail-label\"\n          [pTooltip]=\"item.labelTooltip || ''\"\n          tooltipEvent=\"hover\"\n          tooltipPosition=\"top\"\n          >{{ item.label | dynamicPipe:item.labelPipe }}</span\n        >\n        <span *ngIf=\"item.icon || item.value\" class=\"object-info-grid-value\">\n          <span\n            class=\"flex text-900 align-items-center gap-2 w-max\"\n            [ngClass]=\"generateItemStyle(item)\"\n            name=\"object-detail-value\"\n          >\n            <span\n              class=\"flex align-items-center gap-2\"\n              [pTooltip]=\"item.valueTooltip || item.tooltip || ''\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n            >\n              <i\n                *ngIf=\"item.icon\"\n                class='{{item.icon + \" \" + (item.iconStyleClass || \"\")}}'\n                name=\"object-detail-icon\"\n              ></i>\n              {{ item.value | dynamicPipe:item.valuePipe:item.valuePipeArgs}}\n            </span>\n            <p-button\n              *ngIf=\"item.actionItemIcon && item.actionItemCallback\"\n              [icon]=\"item.actionItemIcon\"\n              styleClass=\"p-button-text p-0 w-full\"\n              [pTooltip]=\"item.actionItemTooltip || ''\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n              [ariaLabel]=\"(item.actionItemAriaLabelKey ? (item.actionItemAriaLabelKey | translate) : item.actionItemAriaLabel) || item.actionItemTooltip || ''\"\n              (onClick)=\"item.actionItemCallback()\"\n            ></p-button>\n          </span>\n        </span>\n      </div>\n    </ng-container>\n    <ng-content></ng-content>\n  </div>\n</div>\n"]}
|
|
238
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-header.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.ts","../../../../../../../libs/angular-accelerator/src/lib/components/page-header/page-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewEncapsulation,\n} from '@angular/core'\nimport { TranslateService } from '@ngx-translate/core'\nimport { MenuItem, PrimeIcons } from 'primeng/api'\nimport { concat, map, Observable, of } from 'rxjs'\nimport { AppStateService } from '@onecx/angular-integration-interface'\nimport { UserService } from '@onecx/angular-integration-interface'\nimport { BreadcrumbService } from '../../services/breadcrumb.service'\nimport { PrimeIcon } from '../../utils/primeicon.utils'\n\n/**\n * Action definition.\n */\nexport interface Action {\n  id?: string\n  label?: string\n  labelKey?: string\n  icon?: string\n  /**\n   * Permission for this action. If the current user does not have this permission, the action will not be shown.\n   */\n  permission?: string\n  title?: string\n  titleKey?: string\n  ariaLabel?: string\n  ariaLabelKey?: string\n  btnClass?: string\n  actionCallback(): void\n  disabled?: boolean\n  disabledTooltip?: string\n  disabledTooltipKey?: string\n  show?: 'always' | 'asOverflow'\n  conditional?: boolean\n  // Note: This currently doesn't work with dynamic values, since a passed in Action is just a copy of the original object.\n  // As a workaround, you can manually update/replace the passed in Action if you wish to update a showCondition\n  showCondition?: boolean\n}\n\nexport interface ObjectDetailItem {\n  label: string\n  value?: string\n  /**\n   * @deprecated Use `valueTooltip` instead\n   */\n  tooltip?: string\n  labelTooltip?: string\n  valueTooltip?: string\n  icon?: PrimeIcon\n  iconStyleClass?: string\n  labelPipe?: Type<any>\n  valuePipe?: Type<any>\n  valuePipeArgs?: string\n  valueCssClass?: string\n  actionItemIcon?: PrimeIcon\n  actionItemCallback?: () => void\n  actionItemTooltip?: string\n  actionItemAriaLabelKey?: string\n  actionItemAriaLabel?: string\n}\n\nexport interface HomeItem {\n  menuItem: MenuItem\n  page?: string\n}\n\nexport type GridColumnOptions = 1 | 2 | 3 | 4 | 6 | 12\n\n@Component({\n  selector: 'ocx-page-header',\n  templateUrl: './page-header.component.html',\n  styleUrls: ['./page-header.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class PageHeaderComponent implements OnInit, OnChanges {\n  @Input()\n  public header: string | undefined\n\n  @Input()\n  loading = false\n\n  @Input()\n  figureBackground = true\n\n  @Input()\n  showFigure = true\n\n  //image fot preview in top-header left side\n  @Input()\n  figureImage: string | undefined\n\n  @Input()\n  disableDefaultActions = false\n\n  @Input()\n  subheader: string | undefined\n\n  _actions: Action[] | undefined\n  @Input()\n  get actions() {\n    return this._actions\n  }\n  set actions(value) {\n    this._actions = value\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  @Input()\n  objectDetails: ObjectDetailItem[] | undefined\n\n  @Input()\n  showBreadcrumbs = true\n\n  @Input()\n  manualBreadcrumbs = false\n\n  @Input()\n  enableGridView: undefined | boolean\n\n  @Input()\n  gridLayoutDesktopColumns: undefined | GridColumnOptions\n\n  @Output()\n  save = new EventEmitter()\n\n  @ContentChild('additionalToolbarContent')\n  additionalToolbarContent: TemplateRef<any> | undefined\n\n  @ContentChild('additionalToolbarContentLeft')\n  additionalToolbarContentLeft: TemplateRef<any> | undefined\n\n  overflowActions: MenuItem[] = []\n  inlineActions: Action[] | undefined\n  dd = new Date()\n  breadcrumbs$!: Observable<MenuItem[]>\n\n  home$!: Observable<HomeItem>\n\n  figureImageLoadError = false\n\n  objectPanelGridLayoutClasses = 'grid row-gap-2 m-0'\n  objectPanelColumnLayoutClasses = 'flex flex-row justify-content-between overflow-x-auto'\n\n  objectPanelDefaultLayoutClasses = 'flex flex-column row-gap-2 md:flex-row md:justify-content-between'\n\n  objectInfoGridLayoutClasses = 'col-12 flex gap-4 md:col-6 align-items-center p-0'\n  objectInfoColumnLayoutClasses = 'flex flex-column align-items-center gap-2 min-w-120'\n\n  objectInfoDefaultLayoutClasses = 'flex flex-row md:flex-column md:align-items-center md:gap-2'\n\n  protected breadcrumbs: BreadcrumbService\n\n  constructor(\n    breadcrumbs: BreadcrumbService,\n    private translateService: TranslateService,\n    private appStateService: AppStateService,\n    private userService: UserService\n  ) {\n    this.breadcrumbs = breadcrumbs\n    this.home$ = concat(\n      of({ menuItem: { icon: PrimeIcons.HOME, routerLink: '/' } }),\n      this.appStateService.currentPortal$.pipe(\n        map((portal) => ({\n          menuItem: {\n            icon: PrimeIcons.HOME,\n            routerLink: portal.baseUrl,\n          },\n          page: portal.portalName,\n        }))\n      )\n    )\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['actions']) {\n      this.generateInlineActions()\n      this.generateOverflowActions()\n    }\n  }\n\n  ngOnInit(): void {\n    if (!this.manualBreadcrumbs) {\n      this.breadcrumbs$ = this.breadcrumbs.generatedItemsSource\n    } else {\n      this.breadcrumbs$ = this.breadcrumbs.itemsHandler\n    }\n    this.generateInlineActions()\n    this.generateOverflowActions()\n  }\n\n  onAction(action: string) {\n    switch (action) {\n      case 'save':\n        this.save.emit()\n        break\n      default:\n        break\n    }\n  }\n\n  handleImageError() {\n    this.figureImageLoadError = true\n  }\n\n  public generateItemStyle(item: ObjectDetailItem): string {\n    let style = ''\n    if (item.icon) style = style.concat(style, ' ', 'gap-1 align-items-center')\n    if (item.valueCssClass) style = style.concat(style, ' ', item.valueCssClass)\n    return style\n  }\n\n  public getObjectPanelLayoutClasses() {\n    if (this.enableGridView) {\n      return this.objectPanelGridLayoutClasses\n    }\n    if (this.enableGridView === false) {\n      return this.objectPanelColumnLayoutClasses\n    }\n    return this.objectPanelDefaultLayoutClasses\n  }\n\n  public getObjectInfoLayoutClasses() {\n    if (this.enableGridView) {\n      return `${this.objectInfoGridLayoutClasses} lg:col-${\n        this.gridLayoutDesktopColumns ? 12 / this.gridLayoutDesktopColumns : 4\n      }`\n    }\n    if (this.enableGridView === false) {\n      return this.objectInfoColumnLayoutClasses\n    }\n    return this.objectInfoDefaultLayoutClasses\n  }\n\n  /**\n   * Generates a list of actions that should be rendered in an overflow menu\n   */\n  private generateOverflowActions() {\n    if (this.actions) {\n      const translationKeys: string[] = [\n        ...this.actions.map((a) => a.labelKey || '').filter((a) => !!a),\n        ...this.actions.map((a) => a.titleKey || '').filter((a) => !!a),\n      ]\n      const translations$ = translationKeys.length ? this.translateService.get(translationKeys) : of([])\n      translations$.subscribe((translations) => {\n        const allowedActions: Action[] = []\n        if (this.actions) {\n          this.actions\n            .filter((a) => a.show === 'asOverflow')\n            .filter((a) => {\n              if (a.conditional) {\n                if (a.showCondition) return a\n                return null\n              } else return a\n            })\n            .forEach((action) => {\n              this.checkActionPermission(allowedActions, action)\n            })\n          this.overflowActions = [\n            ...allowedActions.map<MenuItem>((a) => ({\n              id: a.id,\n              label: a.labelKey ? translations[a.labelKey] : a.label,\n              icon: a.icon,\n              tooltipOptions: {\n                tooltipLabel: a.titleKey ? translations[a.titleKey] : a.title,\n                tooltipEvent: 'hover',\n                tooltipPosition: 'top',\n              },\n              command: a.actionCallback,\n              disabled: a.disabled,\n            })),\n          ]\n        }\n      })\n    }\n  }\n\n  /**\n   * Generates a list of actions that should be rendered as inline buttons\n   */\n  private generateInlineActions() {\n    if (this.actions) {\n      // Temp array to hold all inline actions that should be visible to the current user\n      const allowedActions: Action[] = []\n      // Check permissions for all actions that should be rendered 'always'\n      this.actions\n        .filter((a) => a.show === 'always')\n        .filter((a) => {\n          if (a.conditional) {\n            return a.showCondition ? a : null\n          } else return a\n        })\n        .forEach((action) => {\n          this.checkActionPermission(allowedActions, action)\n        })\n      this.inlineActions = [...allowedActions]\n    }\n  }\n  /**\n   * Adds a given action to a given array if the current user is allowed to see it\n   * @param allowedActions Array that the action should be added to if the current user is allowed to see it\n   * @param action Action for which a permission check should be executed\n   */\n  private checkActionPermission(allowedActions: Action[], action: Action) {\n    if (action.permission) {\n      if (this.userService.hasPermission(action.permission)) {\n        // Push action to allowed array if user has sufficient permissions\n        allowedActions.push(action)\n      }\n    } else {\n      // Push action to allowed array if no permission was specified\n      allowedActions.push(action)\n    }\n  }\n}\n","<div class=\"onecx-page-header mb-4\" name=\"ocx-page-header-wrapper\">\n  <ng-container *ngIf=\"showBreadcrumbs\">\n    <p-breadcrumb\n      [model]=\"items\"\n      *ngIf=\"breadcrumbs$ | async  as items\"\n      [home]=\"(home$ | async)?.menuItem ?? {}\"\n      [homeAriaLabel]=\"(home$ | async)?.page ? ('OCX_PAGE_HEADER.HOME_ARIA_LABEL' | translate: { page: (home$ | async)?.page}) : ('OCX_PAGE_HEADER.HOME_DEFAULT_ARIA_LABEL' | translate)\"\n      [attr.manual]=\"manualBreadcrumbs\"\n    ></p-breadcrumb>\n  </ng-container>\n  <div class=\"title-bar flex flex-row md:justify-content-between p-3\">\n    <div class=\"title-wrap\">\n      <div class=\"figure flex h-2rem w-2rem md:h-3rem md:w-3rem\" *ngIf=\"showFigure\">\n        <div #previewImage class=\"figure-image absolute top-0 left-0 right-0 bottom-0\">\n          <ng-content select=\"[figureImage]\"></ng-content>\n          <img\n            *ngIf=\"figureImage && !figureImageLoadError\"\n            [ocxSrc]=\"figureImage\"\n            alt=\"Figure image\"\n            class=\"w-full\"\n            (error)=\"handleImageError()\"\n          />\n        </div>\n        <div\n          class=\"colorblob flex-1 border-round\"\n          *ngIf=\"previewImage.children.length === 0 || figureImageLoadError\"\n        ></div>\n      </div>\n      <ng-template #skeletonBar>\n        <div class=\"header justify-content-evenly\">\n          <p-skeleton width=\"10rem\"></p-skeleton>\n          <p-skeleton width=\"10rem\"></p-skeleton>\n        </div>\n      </ng-template>\n      <div class=\"header\" *ngIf=\"!loading; else skeletonBar\">\n        <h1 id=\"page-header\" *ngIf=\"!!header\">{{ header }}</h1>\n        <h2 id=\"page-subheader\" *ngIf=\"!!subheader\">{{ subheader }}</h2>\n      </div>\n    </div>\n    <div class=\"action-items-wrap mt-2 md:mt-0\">\n      <ng-container *ngIf=\"additionalToolbarContentLeft\" [ngTemplateOutlet]=\"additionalToolbarContentLeft\">\n      </ng-container>\n\n      <ng-container *ngIf=\"!disableDefaultActions\"> </ng-container>\n      <ng-template #skeletonActions>\n        <div class=\"flex\">\n          <p-skeleton width=\"5rem\" height=\"2rem\" styleClass=\"mr-2\"></p-skeleton>\n          <p-skeleton width=\"2rem\" height=\"2rem\" styleClass=\"mb-2\"></p-skeleton>\n        </div>\n      </ng-template>\n      <ng-container *ngIf=\"!loading; else skeletonActions\">\n        <div *ngIf=\"inlineActions && inlineActions.length > 0\" class=\"toolbar flex flex-wrap gap-1 sm:gap-2\">\n          <ng-container *ngFor=\"let action of inlineActions\">\n            <span\n              [pTooltip]=\"action.disabled ? (action.disabledTooltipKey ? (action.disabledTooltipKey | translate) : action.disabledTooltip) : (action.titleKey ? (action.titleKey | translate) : action.title)\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n            >\n              <p-button\n                id=\"{{ action.id }}\"\n                [icon]=\"action.icon ?? ''\"\n                type=\"button\"\n                class=\"action-button\"\n                [label]=\"action.labelKey ? (action.labelKey | translate) : action.label\"\n                (onClick)=\"action.actionCallback()\"\n                [disabled]=\"action.disabled ? action.disabled : false\"\n                [attr.name]=\"action.icon ? 'ocx-page-header-inline-action-icon-button' : 'ocx-page-header-inline-action-button'\"\n                [ariaLabel]=\" (action.ariaLabelKey ? (action.ariaLabelKey | translate) : action.ariaLabel) || (action.titleKey ? (action.titleKey | translate) : action.title) || (action.labelKey ? (action.labelKey | translate) : action.label)\"\n              ></p-button>\n            </span>\n          </ng-container>\n        </div>\n        <ng-content select=\"[toolbarItems]\"></ng-content>\n        <ng-container>\n          <div *ngIf=\"overflowActions.length !== 0\">\n            <button\n              id=\"pageHeaderMenuButton\"\n              type=\"button\"\n              pButton\n              icon=\"pi pi-ellipsis-v\"\n              pTooltip=\"{{ 'OCX_PAGE_HEADER.MORE_ACTIONS' | translate }}\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n              class=\"more-actions-menu-button action-button ml-2\"\n              (click)=\"menu.toggle($event)\"\n              name=\"ocx-page-header-overflow-action-button\"\n              [attr.aria-label]=\"('OCX_PAGE_HEADER.MORE_ACTIONS' | translate)\"\n            ></button>\n            <p-menu #menu [popup]=\"true\" [model]=\"overflowActions\" appendTo=\"body\"></p-menu>\n          </div>\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"additionalToolbarContent\" [ngTemplateOutlet]=\"additionalToolbarContent\"> </ng-container>\n    </div>\n  </div>\n\n  <div class=\"object-panel\" [ngClass]=\"getObjectPanelLayoutClasses()\">\n    <ng-container *ngIf=\"objectDetails\">\n      <div class=\"object-info\" [ngClass]=\"getObjectInfoLayoutClasses()\" *ngFor=\"let item of objectDetails\">\n        <span\n          class=\"flex font-medium text-600 object-info-grid-label\"\n          name=\"object-detail-label\"\n          [pTooltip]=\"item.labelTooltip || ''\"\n          tooltipEvent=\"hover\"\n          tooltipPosition=\"top\"\n          >{{ item.label | dynamicPipe:item.labelPipe }}</span\n        >\n        <span *ngIf=\"item.icon || item.value\" class=\"object-info-grid-value\">\n          <span\n            class=\"flex text-900 align-items-center gap-2 w-max\"\n            [ngClass]=\"generateItemStyle(item)\"\n            name=\"object-detail-value\"\n          >\n            <span\n              class=\"flex align-items-center gap-2\"\n              [pTooltip]=\"item.valueTooltip || item.tooltip || ''\"\n              tooltipEvent=\"hover\"\n              tooltipPosition=\"top\"\n            >\n              <i\n                *ngIf=\"item.icon\"\n                class='{{item.icon + \" \" + (item.iconStyleClass || \"\")}}'\n                name=\"object-detail-icon\"\n              ></i>\n              {{ item.value | dynamicPipe:item.valuePipe:item.valuePipeArgs}}\n            </span>\n            <p-button\n              *ngIf=\"item.actionItemIcon && item.actionItemCallback\"\n              [icon]=\"item.actionItemIcon\"\n              styleClass=\"p-button-text p-0 w-full\"\n              [pTooltip]=\"item.actionItemTooltip || ''\"\n              tooltipPosition=\"top\"\n              tooltipEvent=\"hover\"\n              [ariaLabel]=\"(item.actionItemAriaLabelKey ? (item.actionItemAriaLabelKey | translate) : item.actionItemAriaLabel) || item.actionItemTooltip || ''\"\n              (onClick)=\"item.actionItemCallback()\"\n            ></p-button>\n          </span>\n        </span>\n      </div>\n    </ng-container>\n    <ng-content></ng-content>\n  </div>\n</div>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhZ3JhbS1kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWFjY2VsZXJhdG9yL3NyYy9saWIvbW9kZWwvZGlhZ3JhbS1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBEaWFncmFtRGF0YSA9IHsgbGFiZWw6IHN0cmluZzsgdmFsdWU6IG51bWJlcjsgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nIH1cbiJdfQ==
|