2020-04-14 11:28:33 +02:00
|
|
|
import { Component, Inject, OnInit } from '@angular/core';
|
|
|
|
import { Chart } from 'chart.js';
|
|
|
|
import { DOCUMENT } from '@angular/common';
|
2020-04-19 14:22:10 +02:00
|
|
|
import { mockGraphConfig } from '../mocks/mock-graph';
|
2020-04-14 11:28:33 +02:00
|
|
|
import { ConfigService } from '../services/config.service';
|
2020-04-19 14:22:10 +02:00
|
|
|
import { mockPoll3 } from '../mocks/mock-poll3';
|
2019-10-23 10:45:30 +02:00
|
|
|
|
|
|
|
@Component({
|
2020-04-14 11:28:33 +02:00
|
|
|
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 {
|
2020-04-19 14:22:10 +02:00
|
|
|
isColorblind = false;
|
2020-01-30 11:19:17 +01:00
|
|
|
pollConfigRetrieved: any = mockPoll3;
|
2020-01-16 16:25:40 +01:00
|
|
|
graphicConfig: any = mockGraphConfig;
|
2020-04-14 11:28:33 +02:00
|
|
|
preferred: any = 'rien';
|
2019-11-19 10:55:56 +01:00
|
|
|
yesList: number[] = [];
|
|
|
|
maybeList: number[] = [];
|
|
|
|
noList: number[] = [];
|
2020-04-19 14:22:10 +02:00
|
|
|
nbPoll = 0;
|
2019-11-19 10:55:56 +01:00
|
|
|
dateList: string[] = [];
|
2019-11-19 14:53:53 +01:00
|
|
|
|
2020-04-14 11:28:33 +02:00
|
|
|
constructor(@Inject(DOCUMENT) private document: any, private config: ConfigService) {}
|
2019-10-23 15:39:16 +02:00
|
|
|
|
2020-04-19 14:22:10 +02:00
|
|
|
ngOnInit(): void {
|
2020-01-16 16:25:40 +01:00
|
|
|
this.formatDataAnswers(this.graphicConfig);
|
2019-11-13 18:18:42 +01:00
|
|
|
this.isColorblind = false;
|
2020-04-14 11:28:33 +02:00
|
|
|
this.pollConfigRetrieved = new Chart(this.document.getElementById('graph'), {
|
|
|
|
type: 'horizontalBar',
|
2019-11-13 18:18:42 +01:00
|
|
|
data: {
|
2020-04-14 11:28:33 +02:00
|
|
|
labels: this.pollConfigRetrieved.choices.map((choice) => choice.name),
|
2019-11-19 10:55:56 +01:00
|
|
|
datasets: [
|
|
|
|
{
|
2020-04-14 11:28:33 +02:00
|
|
|
type: 'horizontalBar',
|
|
|
|
stack: 'Yes',
|
|
|
|
backgroundColor: '#429a00',
|
|
|
|
data: this.yesList,
|
2019-11-19 10:55:56 +01:00
|
|
|
},
|
|
|
|
{
|
2020-04-14 11:28:33 +02:00
|
|
|
type: 'horizontalBar',
|
|
|
|
stack: 'Yes',
|
|
|
|
backgroundColor: '#f5a623',
|
|
|
|
data: this.maybeList,
|
2019-11-19 10:55:56 +01:00
|
|
|
},
|
|
|
|
{
|
2020-04-14 11:28:33 +02:00
|
|
|
type: 'horizontalBar',
|
|
|
|
stack: 'No',
|
|
|
|
backgroundColor: '#cd0000',
|
|
|
|
data: this.noList,
|
|
|
|
},
|
|
|
|
],
|
2019-11-13 18:18:42 +01:00
|
|
|
},
|
2020-04-19 14:22:10 +02:00
|
|
|
options: this.getSettedGraphOptions(),
|
2019-11-19 10:55:56 +01:00
|
|
|
});
|
|
|
|
}
|
2019-11-13 18:18:42 +01:00
|
|
|
|
2020-04-19 14:22:10 +02:00
|
|
|
public toggleColorblind(): void {
|
2019-11-13 18:18:42 +01:00
|
|
|
this.isColorblind = !this.isColorblind;
|
|
|
|
}
|
|
|
|
|
2020-04-19 14:22:10 +02:00
|
|
|
public formatDataAnswers(poll): void {
|
2020-01-16 16:25:40 +01:00
|
|
|
// if (poll && poll.pollType === "date") {
|
|
|
|
this.initPollCounter();
|
2020-04-14 11:28:33 +02:00
|
|
|
poll.answers.forEach((response) => {
|
2020-01-16 16:25:40 +01:00
|
|
|
switch (response.text) {
|
2020-04-14 11:28:33 +02:00
|
|
|
case 'yes':
|
2020-01-16 16:25:40 +01:00
|
|
|
this.yesList[this.nbPoll - 1]++;
|
|
|
|
break;
|
2020-04-14 11:28:33 +02:00
|
|
|
case 'maybe':
|
2020-01-16 16:25:40 +01:00
|
|
|
this.maybeList[this.nbPoll - 1]++;
|
|
|
|
break;
|
2020-04-14 11:28:33 +02:00
|
|
|
case 'no':
|
2020-01-16 16:25:40 +01:00
|
|
|
this.noList[this.nbPoll - 1]++;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
// }
|
2019-11-13 18:18:42 +01:00
|
|
|
}
|
|
|
|
|
2020-04-19 14:22:10 +02:00
|
|
|
public initPollCounter(): void {
|
2019-11-19 10:55:56 +01:00
|
|
|
this.nbPoll++;
|
2020-04-14 11:28:33 +02:00
|
|
|
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;
|
|
|
|
}
|
2020-04-19 14:22:10 +02:00
|
|
|
|
|
|
|
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
|
|
|
}
|