Skip to content
Snippets Groups Projects
Commit 0adad8c2 authored by Daniel Cothran's avatar Daniel Cothran
Browse files

Issue #3482290 by zerbash, andileco, nikathone: Secondary axis overwrites first

parent 9bbbfecf
No related branches found
No related tags found
3 merge requests!113fixed the issue,!112Resolve #3482290,!75Resolve #3391197 "Enable support for"
Pipeline #333201 passed with warnings
...@@ -78,7 +78,7 @@ class Chartjs extends ChartBase { ...@@ -78,7 +78,7 @@ class Chartjs extends ChartBase {
'center' => $this->t('Center'), 'center' => $this->t('Center'),
'end' => $this->t('End'), 'end' => $this->t('End'),
], ],
'#default_value' => $xaxis_configuration['horizontal_axis_title_align'] ?? '', '#default_value' => $xaxis_configuration['horizontal_axis_title_align'] ?? 'center',
]; ];
$form['yaxis'] = [ $form['yaxis'] = [
'#title' => $this->t('Y-Axis Settings'), '#title' => $this->t('Y-Axis Settings'),
...@@ -93,7 +93,7 @@ class Chartjs extends ChartBase { ...@@ -93,7 +93,7 @@ class Chartjs extends ChartBase {
'center' => $this->t('Center'), 'center' => $this->t('Center'),
'end' => $this->t('End'), 'end' => $this->t('End'),
], ],
'#default_value' => $this->configuration['yaxis']['vertical_axis_title_align'] ?? '', '#default_value' => $this->configuration['yaxis']['vertical_axis_title_align'] ?? 'center',
]; ];
return $form; return $form;
...@@ -177,13 +177,12 @@ class Chartjs extends ChartBase { ...@@ -177,13 +177,12 @@ class Chartjs extends ChartBase {
* Setting defaults based on what Views uses. However, API users may * Setting defaults based on what Views uses. However, API users may
* have different keys for their X and Y axes. * have different keys for their X and Y axes.
*/ */
$x_axis_key = 'xaxis'; $axes_info = [];
$y_axis_key = 'yaxis';
foreach ($children as $child) { foreach ($children as $child) {
$type = $element[$child]['#type']; $type = $element[$child]['#type'];
if ($type === 'chart_xaxis') { if ($type === 'chart_xaxis') {
$x_axis_key = $child; $x_axis_key = $child;
$xaxis_configuration = $this->configuration[$x_axis_key] ?? []; $xaxis_configuration = $this->configuration['xaxis'] ?? [];
if (!in_array($chart_type, $this->getPieStyleTypes())) { if (!in_array($chart_type, $this->getPieStyleTypes())) {
if ($chart_type !== 'radar') { if ($chart_type !== 'radar') {
$chart_definition['options']['scales']['x'] = [ $chart_definition['options']['scales']['x'] = [
...@@ -201,24 +200,21 @@ class Chartjs extends ChartBase { ...@@ -201,24 +200,21 @@ class Chartjs extends ChartBase {
} }
} }
} }
$axes_info['x'] = [
'element' => $element[$x_axis_key] ?? [],
'config' => $this->configuration['xaxis'] ?? [],
];
} }
if ($type === 'chart_yaxis') { elseif ($type === 'chart_yaxis') {
$y_axis_key = $child; $target_axes = array_column($chart_definition['data']['datasets'],'yAxisID');
$y_axis_key = in_array($child, $target_axes) ? $child : 'y';
$axes_info[$y_axis_key] = [
'element' => $element[$child] ?? [],
'config' => $this->configuration['yaxis'] ?? [],
];
} }
} }
// Build array of axes info.
$axes_info = [
'x' => [
'element' => $element[$x_axis_key] ?? [],
'config' => $this->configuration[$x_axis_key] ?? [],
],
'y' => [
'element' => $element[$y_axis_key] ?? [],
'config' => $this->configuration[$y_axis_key] ?? [],
],
];
// Build axes options in chart_definition. // Build axes options in chart_definition.
if (!in_array($chart_type, $this->getPieStyleTypes())) { if (!in_array($chart_type, $this->getPieStyleTypes())) {
if (!empty($element['#stacking']) && $element['#stacking'] == 1) { if (!empty($element['#stacking']) && $element['#stacking'] == 1) {
...@@ -236,25 +232,28 @@ class Chartjs extends ChartBase { ...@@ -236,25 +232,28 @@ class Chartjs extends ChartBase {
'minRotation' => $axes_info['x']['element']['#labels_rotation'] ?? 0, 'minRotation' => $axes_info['x']['element']['#labels_rotation'] ?? 0,
], ],
]; ];
$chart_definition['options']['scales']['y'] = [
'ticks' => [
'beginAtZero' => NULL,
'maxRotation' => $axes_info['y']['element']['#labels_rotation'] ?? 0,
'minRotation' => $axes_info['y']['element']['#labels_rotation'] ?? 0,
],
'maxTicksLimit' => 11,
'precision' => NULL,
'stepSize' => NULL,
'suggestedMax' => NULL,
'suggestedMin' => NULL,
'stacked' => $stacking,
];
// Set configured values for each axis. // Set configured values for each axis.
foreach ($axes_info as $axis_id => $axis_info) { foreach ($axes_info as $axis_id => $axis_info) {
$axis_element = $axis_info['element']; $axis_element = $axis_info['element'];
$axis_config = $axis_info['config']; $axis_config = $axis_info['config'];
if ($axis_element['#type'] == 'chart_yaxis') {
$chart_definition['options']['scales'][$axis_id] = [
'ticks' => [
'beginAtZero' => NULL,
'maxRotation' => $axes_info[$axis_id]['element']['#labels_rotation'] ?? 0,
'minRotation' => $axes_info[$axis_id]['element']['#labels_rotation'] ?? 0,
],
'maxTicksLimit' => 11,
'precision' => NULL,
'stepSize' => NULL,
'suggestedMax' => NULL,
'suggestedMin' => NULL,
'stacked' => $stacking,
];
}
// Set the axis type. // Set the axis type.
if (!empty($axis_element['#axis_type'])) { if (!empty($axis_element['#axis_type'])) {
$chart_definition['options']['scales'][$axis_id]['type'] = $axis_element['#axis_type']; $chart_definition['options']['scales'][$axis_id]['type'] = $axis_element['#axis_type'];
...@@ -421,7 +420,7 @@ class Chartjs extends ChartBase { ...@@ -421,7 +420,7 @@ class Chartjs extends ChartBase {
foreach (Element::children($element) as $key) { foreach (Element::children($element) as $key) {
if ($element[$key]['#type'] === 'chart_data') { if ($element[$key]['#type'] === 'chart_data') {
$series_data = []; $series_data = [];
$dataset = new \stdClass(); $dataset = [];
// Populate the data. // Populate the data.
foreach ($element[$key]['#data'] as $data_index => $data) { foreach ($element[$key]['#data'] as $data_index => $data) {
if (isset($series_data[$data_index])) { if (isset($series_data[$data_index])) {
...@@ -457,34 +456,34 @@ class Chartjs extends ChartBase { ...@@ -457,34 +456,34 @@ class Chartjs extends ChartBase {
} }
} }
if (!empty($element[$key]['#target_axis'])) { if (!empty($element[$key]['#target_axis'])) {
$dataset->yAxisID = $element[$key]['#target_axis']; $dataset['yAxisID'] = $element[$key]['#target_axis'];
} }
$dataset->label = $element[$key]['#title']; $dataset['label'] = $element[$key]['#title'];
$dataset->data = $series_data; $dataset['data'] = $series_data;
// Set the background and border color. // Set the background and border color.
if (!empty($element[$key]['#color'])) { if (!empty($element[$key]['#color'])) {
if (!in_array($chart_type, $this->getPieStyleTypes())) { if (!in_array($chart_type, $this->getPieStyleTypes())) {
$dataset->borderColor = $element[$key]['#color']; $dataset['borderColor'] = $element[$key]['#color'];
} }
$dataset->backgroundColor = $element[$key]['#color']; $dataset['backgroundColor'] = $element[$key]['#color'];
} }
if (in_array($chart_type, $this->getPieStyleTypes()) && !empty($element['#colors'])) { if (in_array($chart_type, $this->getPieStyleTypes()) && !empty($element['#colors'])) {
$dataset->backgroundColor = $element['#colors']; $dataset['backgroundColor'] = $element['#colors'];
} }
$series_type = isset($element[$key]['#chart_type']) ? $this->populateChartType($element[$key]) : $chart_type; $series_type = isset($element[$key]['#chart_type']) ? $this->populateChartType($element[$key]) : $chart_type;
$dataset->type = $series_type; $dataset['type'] = $series_type;
if (!empty($element[$key]['#chart_type']) && $element[$key]['#chart_type'] === 'area') { if (!empty($element[$key]['#chart_type']) && $element[$key]['#chart_type'] === 'area') {
$dataset->fill = 'origin'; $dataset['fill'] = 'origin';
$dataset->backgroundColor = $this->getTranslucentColor($element[$key]['#color']); $dataset['backgroundColor'] = $this->getTranslucentColor($element[$key]['#color']);
} }
elseif ($element['#chart_type'] === 'area') { elseif ($element['#chart_type'] === 'area') {
$dataset->fill = 'origin'; $dataset['fill'] = 'origin';
$dataset->backgroundColor = $this->getTranslucentColor($element[$key]['#color']); $dataset['backgroundColor'] = $this->getTranslucentColor($element[$key]['#color']);
} }
else { else {
$dataset->fill = FALSE; $dataset['fill'] = FALSE;
} }
// Merge in dataset raw options. // Merge in dataset raw options.
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment