From 93d05938ea180979c29edb1029cf195b07e7457b Mon Sep 17 00:00:00 2001 From: Alison Date: Fri, 18 Aug 2017 15:43:16 -0400 Subject: [PATCH] change pie chart colors (re #240) --- .../visualizations/chart/chart-editor.html | 66 ++++++++++++++----- client/app/visualizations/chart/index.js | 58 ++++++++++++---- client/app/visualizations/chart/plotly.js | 8 ++- 3 files changed, 100 insertions(+), 32 deletions(-) diff --git a/client/app/visualizations/chart/chart-editor.html b/client/app/visualizations/chart/chart-editor.html index f29f35ac5f..e9f86a3aac 100644 --- a/client/app/visualizations/chart/chart-editor.html +++ b/client/app/visualizations/chart/chart-editor.html @@ -9,9 +9,14 @@
  • Y Axis
  • -
  • +
  • Series
  • +
  • + Colors +
  • @@ -32,7 +37,6 @@
    -
    @@ -138,18 +142,18 @@
    -
    - -
    +
    + + +
    -
    - +
    + +
    @@ -216,7 +220,7 @@

    {{$index == 0 ? 'Left' : 'Right'}} Y Axis

    -
    +
    @@ -229,7 +233,8 @@

    {{$index == 0 ? 'Left' : 'Right'}} Y Axis

    + ng-bind="options.seriesOptions[name].zIndex + 1"> + @@ -269,3 +274,34 @@

    {{$index == 0 ? 'Left' : 'Right'}} Y Axis

    zIndex
    + +
    + + + + + + + + + + + + + +
    zIndexLabelColor
    + + {{name}} + + + + + + + + + + +
    +
    diff --git a/client/app/visualizations/chart/index.js b/client/app/visualizations/chart/index.js index b67c8cd61d..94fd2f4930 100644 --- a/client/app/visualizations/chart/index.js +++ b/client/app/visualizations/chart/index.js @@ -120,19 +120,48 @@ function ChartEditor(ColorPalette, clientConfig) { } function refreshSeries() { - const seriesNames = pluck(scope.queryResult.getChartData(scope.options.columnMapping), 'name'); - const existing = keys(scope.options.seriesOptions); - each(difference(seriesNames, existing), (name) => { - scope.options.seriesOptions[name] = { - type: scope.options.globalSeriesType, - yAxis: 0, - }; - scope.form.seriesList.push(name); - }); - each(difference(existing, seriesNames), (name) => { - scope.form.seriesList = without(scope.form.seriesList, name); - delete scope.options.seriesOptions[name]; - }); + // for pie charts only get color list (x row) instead of series list (y column) + if (scope.options.globalSeriesType === 'pie') { + const seriesData = scope.queryResult.getData(); + scope.form.colorsList = []; + const xColumnName = scope.form.xAxisColumn; + seriesData.forEach((rowOfData) => { + scope.form.colorsList.push(rowOfData[xColumnName]); + }); + + const colorNames = scope.form.colorsList; + let existing = []; + if (scope.options.colorOptions === undefined) { + existing = colorNames; + } else { + existing = keys(scope.options.colorOptions); + } + each(difference(colorNames, existing), (name) => { + scope.options.colorOptions[name] = { + type: scope.options.globalSeriesType, + yAxis: 0, + }; + scope.form.colorsList.push(name); + }); + each(difference(existing, colorNames), (name) => { + scope.form.colorsList = without(scope.form.colorsList, name); + delete scope.options.colorOptions[name]; + }); + } else { + const seriesNames = pluck(scope.queryResult.getChartData(scope.options.columnMapping), 'name'); + const existing = keys(scope.options.seriesOptions); + each(difference(seriesNames, existing), (name) => { + scope.options.seriesOptions[name] = { + type: scope.options.globalSeriesType, + yAxis: 0, + }; + scope.form.seriesList.push(name); + }); + each(difference(existing, seriesNames), (name) => { + scope.form.seriesList = without(scope.form.seriesList, name); + delete scope.options.seriesOptions[name]; + }); + } } function setColumnRole(role, column) { @@ -164,6 +193,8 @@ function ChartEditor(ColorPalette, clientConfig) { yAxisColumns: [], seriesList: sortBy(keys(scope.options.seriesOptions), name => scope.options.seriesOptions[name].zIndex), + colorsList: sortBy(keys(scope.options.colorOptions), name => + scope.options.colorOptions[name].zIndex), }; scope.$watchCollection('form.seriesList', (value) => { @@ -173,7 +204,6 @@ function ChartEditor(ColorPalette, clientConfig) { }); }); - scope.$watchCollection('form.yAxisColumns', (value, old) => { each(old, unsetColumn); each(value, partial(setColumnRole, 'y')); diff --git a/client/app/visualizations/chart/plotly.js b/client/app/visualizations/chart/plotly.js index a411a35e9f..5552bec2a9 100644 --- a/client/app/visualizations/chart/plotly.js +++ b/client/app/visualizations/chart/plotly.js @@ -262,7 +262,7 @@ const PlotlyChart = () => { labels: [], type: 'pie', hole: 0.4, - marker: { colors: ColorPaletteArray }, + marker: { colors: ColorPaletteArray.slice() }, text: series.name, textposition: 'inside', name: series.name, @@ -272,9 +272,11 @@ const PlotlyChart = () => { }, }; - series.data.forEach((row) => { + each(series.data, (row, rowIdx) => { plotlySeries.values.push(row.y); - plotlySeries.labels.push(hasX ? row.x : `Slice ${index}`); + plotlySeries.labels.push(hasX ? row.x : `Slice ${index}`); + const rowOpts = scope.options.seriesOptions[hasX ? row.x : `Slice ${index}`]; + plotlySeries.marker.colors[rowIdx] = rowOpts ? rowOpts.color : getColor(rowIdx); }); scope.data.push(plotlySeries);