2020-11-02 16:32:37 +01:00
|
|
|
export class ApexOptionsBuilder {
|
|
|
|
options = {
|
|
|
|
series: [],
|
2020-11-03 10:43:45 +01:00
|
|
|
legend: {
|
|
|
|
show: false,
|
|
|
|
position: "top",
|
|
|
|
horizontalAlign: "right",
|
|
|
|
showForSingleSeries: true,
|
|
|
|
showForNullSeries: true,
|
|
|
|
showForZeroSeries: true,
|
|
|
|
},
|
|
|
|
chart: {
|
|
|
|
toolbar: {
|
|
|
|
show: false,
|
|
|
|
},
|
|
|
|
},
|
2020-11-02 16:32:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
setOption(path, value) {
|
|
|
|
if (value == null || value === "") {
|
|
|
|
return this
|
|
|
|
}
|
|
|
|
let tmp = this.options
|
|
|
|
for (let i = 0; i < path.length - 1; i++) {
|
|
|
|
const step = path[i]
|
|
|
|
if (!tmp[step]) {
|
|
|
|
tmp[step] = {}
|
|
|
|
}
|
|
|
|
tmp = tmp[step]
|
|
|
|
}
|
|
|
|
tmp[path[path.length - 1]] = value
|
|
|
|
return this
|
|
|
|
}
|
|
|
|
|
|
|
|
getOptions() {
|
|
|
|
return this.options
|
|
|
|
}
|
|
|
|
|
|
|
|
type(type) {
|
|
|
|
return this.setOption(["chart", "type"], type)
|
|
|
|
}
|
|
|
|
|
2020-11-03 10:43:45 +01:00
|
|
|
title(title) {
|
|
|
|
return this.setOption(["title", "text"], title)
|
|
|
|
}
|
|
|
|
|
2020-11-02 16:32:37 +01:00
|
|
|
color(color) {
|
2020-11-03 10:43:45 +01:00
|
|
|
return this.setOption(["colors"], [color])
|
2020-11-02 16:32:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
width(width) {
|
|
|
|
return this.setOption(["chart", "width"], width || undefined)
|
|
|
|
}
|
|
|
|
|
|
|
|
height(height) {
|
|
|
|
return this.setOption(["chart", "height"], height || undefined)
|
|
|
|
}
|
|
|
|
|
|
|
|
xLabel(label) {
|
|
|
|
return this.setOption(["xaxis", "title", "text"], label)
|
|
|
|
}
|
|
|
|
|
|
|
|
yLabel(label) {
|
|
|
|
return this.setOption(["yaxis", "title", "text"], label)
|
|
|
|
}
|
|
|
|
|
|
|
|
categories(categories) {
|
|
|
|
return this.setOption(["xaxis", "categories"], categories)
|
|
|
|
}
|
|
|
|
|
|
|
|
series(series) {
|
|
|
|
return this.setOption(["series"], series)
|
|
|
|
}
|
|
|
|
|
|
|
|
horizontal(horizontal) {
|
|
|
|
return this.setOption(["plotOptions", "bar", "horizontal"], horizontal)
|
|
|
|
}
|
|
|
|
|
|
|
|
dataLabels(dataLabels) {
|
|
|
|
return this.setOption(["dataLabels", "enabled"], dataLabels)
|
|
|
|
}
|
|
|
|
|
|
|
|
animate(animate) {
|
|
|
|
return this.setOption(["chart", "animations", "enabled"], animate)
|
|
|
|
}
|
2020-11-03 10:43:45 +01:00
|
|
|
|
|
|
|
curve(curve) {
|
|
|
|
return this.setOption(["stroke", "curve"], curve)
|
|
|
|
}
|
|
|
|
|
|
|
|
gradient(gradient) {
|
|
|
|
const fill = {
|
|
|
|
type: "gradient",
|
|
|
|
gradient: {
|
|
|
|
shadeIntensity: 1,
|
|
|
|
opacityFrom: 0.7,
|
|
|
|
opacityTo: 0.9,
|
|
|
|
stops: [0, 90, 100],
|
|
|
|
},
|
|
|
|
}
|
|
|
|
return this.setOption(["fill"], gradient ? fill : undefined)
|
|
|
|
}
|
|
|
|
|
|
|
|
legend(legend) {
|
|
|
|
return this.setOption(["legend", "show"], legend)
|
|
|
|
}
|
2020-11-02 16:32:37 +01:00
|
|
|
}
|