2020-01-15 11:40:39 +01:00
|
|
|
import {Component, Inject, OnInit} from "@angular/core";
|
2019-11-19 14:53:53 +01:00
|
|
|
import {Chart} from "chart.js";
|
2020-01-15 11:40:39 +01:00
|
|
|
import {DOCUMENT} from '@angular/common';
|
2020-01-16 10:33:05 +01:00
|
|
|
import {mockGraphConfig} from "../config/mock-graph";
|
2019-10-23 10:45:30 +02:00
|
|
|
|
|
|
|
@Component({
|
2019-11-13 18:18:42 +01: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 {
|
2019-11-19 14:53:53 +01:00
|
|
|
isColorblind: boolean = false;
|
2019-11-13 18:18:42 +01:00
|
|
|
pollData: any;
|
2020-01-16 10:20:15 +01:00
|
|
|
preferred: any = "rien";
|
2019-11-19 10:55:56 +01:00
|
|
|
yesList: number[] = [];
|
|
|
|
maybeList: number[] = [];
|
|
|
|
noList: number[] = [];
|
|
|
|
nbPoll: number = 0;
|
|
|
|
dateList: string[] = [];
|
2019-11-19 14:53:53 +01:00
|
|
|
|
2020-01-15 11:40:39 +01:00
|
|
|
constructor(@Inject(DOCUMENT) private document: any,) {
|
2019-11-19 14:53:53 +01:00
|
|
|
}
|
2019-10-23 15:39:16 +02:00
|
|
|
|
2019-11-13 18:18:42 +01:00
|
|
|
ngOnInit() {
|
2020-01-16 10:33:05 +01:00
|
|
|
var toto = mockGraphConfig;
|
2019-10-23 15:39:16 +02:00
|
|
|
|
2019-11-19 10:55:56 +01:00
|
|
|
this.formatDataAnswers(toto);
|
2019-10-23 10:45:30 +02:00
|
|
|
|
2019-11-13 18:18:42 +01:00
|
|
|
this.isColorblind = false;
|
2020-01-15 11:40:39 +01:00
|
|
|
this.pollData = new Chart(this.document.getElementById("graph"), {
|
2019-11-19 10:55:56 +01:00
|
|
|
type: "horizontalBar",
|
2019-11-13 18:18:42 +01:00
|
|
|
data: {
|
2019-11-19 10:55:56 +01:00
|
|
|
labels: ["jeudi"],
|
|
|
|
datasets: [
|
|
|
|
{
|
|
|
|
type: "horizontalBar",
|
|
|
|
stack: "Yes",
|
|
|
|
backgroundColor: "#429a00",
|
|
|
|
data: this.yesList
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: "horizontalBar",
|
|
|
|
stack: "Yes",
|
|
|
|
backgroundColor: "#f5a623",
|
|
|
|
data: this.maybeList
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: "horizontalBar",
|
|
|
|
stack: "No",
|
|
|
|
backgroundColor: "#cd0000",
|
|
|
|
data: this.noList
|
|
|
|
}
|
|
|
|
]
|
2019-11-13 18:18:42 +01:00
|
|
|
},
|
|
|
|
options: {
|
2019-11-19 14:53:53 +01:00
|
|
|
legend: {display: false},
|
2019-11-19 10:55:56 +01:00
|
|
|
scales: {
|
|
|
|
xAxes: [
|
|
|
|
{
|
2019-11-19 14:53:53 +01:00
|
|
|
gridLines: {drawBorder: false, display: false},
|
2019-11-19 10:55:56 +01:00
|
|
|
display: false,
|
|
|
|
stacked: true,
|
|
|
|
ticks: {
|
|
|
|
beginAtZero: true,
|
|
|
|
maxRotation: 0,
|
|
|
|
minRotation: 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
],
|
|
|
|
yAxes: [
|
|
|
|
{
|
2019-11-19 14:53:53 +01:00
|
|
|
gridLines: {drawBorder: true, display: false},
|
2019-11-19 10:55:56 +01:00
|
|
|
display: true,
|
|
|
|
stacked: true
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
2019-11-13 18:18:42 +01:00
|
|
|
}
|
2019-11-19 10:55:56 +01:00
|
|
|
});
|
|
|
|
}
|
2019-11-13 18:18:42 +01:00
|
|
|
|
2019-11-19 14:53:53 +01:00
|
|
|
toggleColorblind() {
|
2019-11-13 18:18:42 +01:00
|
|
|
this.isColorblind = !this.isColorblind;
|
|
|
|
}
|
|
|
|
|
2019-11-19 10:55:56 +01:00
|
|
|
formatDataAnswers(poll) {
|
|
|
|
if (poll && poll.pollType === "special dates") {
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2019-11-13 18:18:42 +01:00
|
|
|
}
|
|
|
|
|
2019-11-19 10:55:56 +01:00
|
|
|
initPollCounter() {
|
|
|
|
this.nbPoll++;
|
2019-11-19 14:53:53 +01: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;
|
|
|
|
}
|
2019-10-23 10:45:30 +02:00
|
|
|
}
|