framadate-responsive/src/app/poll-graphic/poll-graphic.component.ts

113 lines
3.7 KiB
TypeScript
Raw Normal View History

import { Component, Inject, OnInit } from '@angular/core';
import { Chart } from 'chart.js';
import { DOCUMENT } from '@angular/common';
import { mockGraphConfig } from '../mocks/mock-graph';
import { ConfigService } from '../services/config.service';
import { mockPoll3 } from '../mocks/mock-poll3';
2019-10-23 10:45:30 +02:00
@Component({
selector: 'framadate-poll-graphic',
templateUrl: './poll-graphic.component.html',
styleUrls: ['./poll-graphic.component.scss'],
2019-10-23 10:45:30 +02:00
})
export class PollGraphicComponent implements OnInit {
isColorblind = false;
2020-01-30 11:19:17 +01:00
pollConfigRetrieved: any = mockPoll3;
graphicConfig: any = mockGraphConfig;
preferred: any = 'rien';
2019-11-19 10:55:56 +01:00
yesList: number[] = [];
maybeList: number[] = [];
noList: number[] = [];
nbPoll = 0;
2019-11-19 10:55:56 +01:00
dateList: string[] = [];
2019-11-19 14:53:53 +01:00
constructor(@Inject(DOCUMENT) private document: any, private config: ConfigService) {}
2019-10-23 15:39:16 +02:00
ngOnInit(): void {
this.formatDataAnswers(this.graphicConfig);
this.isColorblind = false;
this.pollConfigRetrieved = new Chart(this.document.getElementById('graph'), {
type: 'horizontalBar',
data: {
labels: this.pollConfigRetrieved.choices.map((choice) => choice.name),
2019-11-19 10:55:56 +01:00
datasets: [
{
type: 'horizontalBar',
stack: 'Yes',
backgroundColor: '#429a00',
data: this.yesList,
2019-11-19 10:55:56 +01:00
},
{
type: 'horizontalBar',
stack: 'Yes',
backgroundColor: '#f5a623',
data: this.maybeList,
2019-11-19 10:55:56 +01:00
},
{
type: 'horizontalBar',
stack: 'No',
backgroundColor: '#cd0000',
data: this.noList,
},
],
},
options: this.getSettedGraphOptions(),
2019-11-19 10:55:56 +01:00
});
}
public toggleColorblind(): void {
this.isColorblind = !this.isColorblind;
}
public formatDataAnswers(poll): void {
// if (poll && poll.pollType === "date") {
this.initPollCounter();
poll.answers.forEach((response) => {
switch (response.text) {
case 'yes':
this.yesList[this.nbPoll - 1]++;
break;
case 'maybe':
this.maybeList[this.nbPoll - 1]++;
break;
case 'no':
this.noList[this.nbPoll - 1]++;
break;
}
});
// }
}
public initPollCounter(): void {
2019-11-19 10:55:56 +01:00
this.nbPoll++;
this.dateList[this.nbPoll - 1] = 'jeudi';
2019-11-19 10:55:56 +01:00
this.maybeList[this.nbPoll - 1] = 0;
this.yesList[this.nbPoll - 1] = 0;
this.noList[this.nbPoll - 1] = 0;
}
private getSettedGraphOptions(): any {
// TODO: create interfaces, or find another way to work. "any" return type should be removed.
return {
legend: { display: false },
scales: {
xAxes: [
{
gridLines: { drawBorder: false, display: false },
display: false,
stacked: true,
ticks: { beginAtZero: true, maxRotation: 0, minRotation: 0 },
},
],
yAxes: [
{
gridLines: { drawBorder: true, display: false },
display: true,
stacked: true,
},
],
},
};
}
2019-10-23 10:45:30 +02:00
}