Merge pull request #5282 from tsiegleauq/dynamic-bar-chart-aspect-ratio

Define chart height
This commit is contained in:
Emanuel Schütze 2020-03-26 17:58:48 +01:00 committed by GitHub
commit 04c625b3d5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 18 additions and 27 deletions

View File

@ -1,4 +1,4 @@
<div class="charts-wrapper" [ngClass]="[hasPadding ? 'has-padding' : '']"> <div class="charts-wrapper" [style.height]="calcBarChartHeight()">
<canvas <canvas
class="chart-js-canvas" class="chart-js-canvas"
*ngIf="chartData && chartData.length" *ngIf="chartData && chartData.length"

View File

@ -1,9 +1,6 @@
.charts-wrapper { .charts-wrapper {
position: relative; position: relative;
display: block; display: block;
height: 100%;
margin: auto; margin: auto;
&.has-padding {
padding: 16px;
}
} }

View File

@ -55,12 +55,6 @@ export class ChartsComponent extends BaseViewComponent {
@Input() @Input()
public labels: Label[]; public labels: Label[];
/**
* Determine, if the chart has some padding at the borders.
*/
@Input()
public hasPadding = true;
/** /**
* Show a legend * Show a legend
*/ */
@ -89,7 +83,8 @@ export class ChartsComponent extends BaseViewComponent {
public get chartOptions(): ChartOptions { public get chartOptions(): ChartOptions {
if (this.isCircle) { if (this.isCircle) {
return { return {
aspectRatio: 1, responsive: true,
maintainAspectRatio: false,
tooltips: { tooltips: {
enabled: false enabled: false
}, },
@ -99,7 +94,8 @@ export class ChartsComponent extends BaseViewComponent {
}; };
} else { } else {
return { return {
aspectRatio: 3, responsive: true,
maintainAspectRatio: false,
tooltips: { tooltips: {
enabled: false enabled: false
}, },
@ -145,6 +141,16 @@ export class ChartsComponent extends BaseViewComponent {
super(title, translate, matSnackbar); super(title, translate, matSnackbar);
} }
public calcBarChartHeight(): string | undefined {
if (!this.isCircle) {
const baseHeight = 120;
const perLabel = 60;
return `${baseHeight + perLabel * this.labels.length}px`;
} else {
return undefined;
}
}
private progressInputData(inputChartData: ChartData): void { private progressInputData(inputChartData: ChartData): void {
if (this.isCircle) { if (this.isCircle) {
this.chartData = inputChartData.flatMap(chartDate => chartDate.data); this.chartData = inputChartData.flatMap(chartDate => chartDate.data);

View File

@ -34,6 +34,6 @@
<!-- Chart --> <!-- Chart -->
<div class="doughnut-chart" *ngIf="showChart"> <div class="doughnut-chart" *ngIf="showChart">
<os-charts type="doughnut" [data]="chartData | async" [hasPadding]="false"></os-charts> <os-charts type="doughnut" [data]="chartData | async"></os-charts>
</div> </div>
</div> </div>

View File

@ -25,7 +25,5 @@
.doughnut-chart { .doughnut-chart {
display: block; display: block;
margin-top: auto;
margin-bottom: auto;
} }
} }

View File

@ -39,7 +39,6 @@
*ngIf="chartDataSubject.value" *ngIf="chartDataSubject.value"
[labels]="candidatesLabels" [labels]="candidatesLabels"
[data]="chartDataSubject | async" [data]="chartDataSubject | async"
[hasPadding]="false"
></os-charts> ></os-charts>
</div> </div>

View File

@ -1,11 +1,6 @@
.assignment-result-wrapper { .assignment-result-wrapper {
.chart-wrapper { .chart-wrapper {
margin-top: 2em; margin-top: 2em;
.pie-chart {
margin-left: auto;
margin-right: auto;
width: 50%;
}
} }
.named-result-table { .named-result-table {

View File

@ -64,7 +64,6 @@
routerLink="/assignments/polls/{{ poll.id }}" routerLink="/assignments/polls/{{ poll.id }}"
[labels]="candidatesLabels" [labels]="candidatesLabels"
[data]="chartDataSubject | async" [data]="chartDataSubject | async"
[hasPadding]="false"
></os-charts> ></os-charts>
</div> </div>

View File

@ -103,8 +103,6 @@ export class AssignmentPollService extends PollService {
} }
public generateTableData(poll: ViewAssignmentPoll | PollData): PollTableData[] { public generateTableData(poll: ViewAssignmentPoll | PollData): PollTableData[] {
console.log('poll: ', poll);
const tableData: PollTableData[] = poll.options const tableData: PollTableData[] = poll.options
.sort((a, b) => { .sort((a, b) => {
if (this.sortByVote) { if (this.sortByVote) {

View File

@ -87,8 +87,7 @@
</div> </div>
</div> </div>
<div class="doughnut-chart" [routerLink]="pollLink"> <div class="doughnut-chart" [routerLink]="pollLink">
<os-charts *ngIf="showChart" type="doughnut" [data]="chartDataSubject | async" [hasPadding]="false"> <os-charts *ngIf="showChart" type="doughnut" [data]="chartDataSubject | async"></os-charts>
</os-charts>
</div> </div>
</div> </div>