mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 11:02:46 +08:00
REFACTOR: poll-pie-chart widget (#8415)
This commit mostly get rid of the later() call and encapsulate all pie chart display logic inside discourse-poll-pie-canvas widget instead of sharing it between discourse-poll-pie-chart and discourse-poll-pie-canvas
This commit is contained in:
parent
2673cad142
commit
0807751390
|
@ -118,7 +118,7 @@ export default class Widget {
|
|||
this.appEvents = register.lookup("service:app-events");
|
||||
this.keyValueStore = register.lookup("key-value-store:main");
|
||||
|
||||
this.init();
|
||||
this.init(this.attrs);
|
||||
|
||||
// Helps debug widgets
|
||||
if (Discourse.Environment === "development" || ENV.environment === "test") {
|
||||
|
|
|
@ -10,7 +10,6 @@ import round from "discourse/lib/round";
|
|||
import { relativeAge } from "discourse/lib/formatter";
|
||||
import loadScript from "discourse/lib/load-script";
|
||||
import { getColors } from "../lib/chart-colors";
|
||||
import { later } from "@ember/runloop";
|
||||
import { classify } from "@ember/string";
|
||||
import { PIE_CHART_TYPE } from "../controllers/poll-ui-builder";
|
||||
|
||||
|
@ -542,6 +541,18 @@ function clearPieChart(id) {
|
|||
createWidget("discourse-poll-pie-canvas", {
|
||||
tagName: "canvas.poll-results-canvas",
|
||||
|
||||
init(attrs) {
|
||||
loadScript("/javascripts/Chart.min.js").then(() => {
|
||||
const data = attrs.poll.options.mapBy("votes");
|
||||
const labels = attrs.poll.options.mapBy("html");
|
||||
const config = pieChartConfig(data, labels);
|
||||
|
||||
const el = document.getElementById(`poll-results-chart-${attrs.id}`);
|
||||
// eslint-disable-next-line
|
||||
new Chart(el.getContext("2d"), config);
|
||||
});
|
||||
},
|
||||
|
||||
buildAttributes(attrs) {
|
||||
return {
|
||||
id: `poll-results-chart-${attrs.id}`
|
||||
|
@ -555,7 +566,7 @@ createWidget("discourse-poll-pie-chart", {
|
|||
const contents = [];
|
||||
|
||||
if (!attrs.showResults) {
|
||||
clearPieChart(this.attrs.id);
|
||||
clearPieChart(attrs.id);
|
||||
return contents;
|
||||
}
|
||||
|
||||
|
@ -563,7 +574,7 @@ createWidget("discourse-poll-pie-chart", {
|
|||
let chart;
|
||||
if (attrs.groupResults && attrs.groupableUserFields.length > 0) {
|
||||
chart = this.attach("discourse-poll-grouped-pies", attrs);
|
||||
clearPieChart(this.attrs.id);
|
||||
clearPieChart(attrs.id);
|
||||
} else {
|
||||
if (attrs.groupableUserFields.length) {
|
||||
btn = this.attach("button", {
|
||||
|
@ -574,18 +585,7 @@ createWidget("discourse-poll-pie-chart", {
|
|||
action: "toggleGroupedPieCharts"
|
||||
});
|
||||
}
|
||||
const data = attrs.poll.options.mapBy("votes");
|
||||
const labels = attrs.poll.options.mapBy("html");
|
||||
loadScript("/javascripts/Chart.min.js").then(() => {
|
||||
later(() => {
|
||||
const el = document.querySelector(
|
||||
`#poll-results-chart-${this.attrs.id}`
|
||||
);
|
||||
const config = pieChartConfig(data, labels);
|
||||
// eslint-disable-next-line
|
||||
new Chart(el.getContext("2d"), config);
|
||||
});
|
||||
});
|
||||
|
||||
chart = this.attach("discourse-poll-pie-canvas", attrs);
|
||||
}
|
||||
contents.push(btn);
|
||||
|
|
Loading…
Reference in New Issue
Block a user