From c79ee568849761d9c5793ce88f5b7aba8d9e7ac9 Mon Sep 17 00:00:00 2001 From: smileydev <47900232+prosdev0107@users.noreply.github.com> Date: Thu, 10 Mar 2022 06:59:07 -0500 Subject: [PATCH] =?UTF-8?q?fix(plugin-chart-echarts):=20make=20to=20allow?= =?UTF-8?q?=20the=20custome=20of=20x=20&=20y=20axis=20title=20margin=20i?= =?UTF-8?q?=E2=80=A6=20(#18947)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix(chartviz): make to allow the custome of x & y axis title margin in chart * fix(chartviz): add eslint radix error in chart.js * fix(chartviz): change the transformProps in chart plugin & creat helper. * fix(chartviz): lint fix & chart.js back * fix(plugin-chart-echarts): make to allow the custom margin of X & y axis in BoxPlot & Mixedtimeseries charts * fix(plugin-chart-echarts): make to change changeNumber to changeInteger * fix(plugin-chart-echarts): make to add license & change file name --- .../src/BoxPlot/transformProps.ts | 9 ++++---- .../src/MixedTimeseries/transformProps.ts | 9 ++++---- .../src/Timeseries/transformProps.ts | 10 +++++---- .../src/utils/convertInteger.ts | 22 +++++++++++++++++++ 4 files changed, 38 insertions(+), 12 deletions(-) create mode 100644 superset-frontend/plugins/plugin-chart-echarts/src/utils/convertInteger.ts diff --git a/superset-frontend/plugins/plugin-chart-echarts/src/BoxPlot/transformProps.ts b/superset-frontend/plugins/plugin-chart-echarts/src/BoxPlot/transformProps.ts index 929d63b987118..8e89914b4d8a8 100644 --- a/superset-frontend/plugins/plugin-chart-echarts/src/BoxPlot/transformProps.ts +++ b/superset-frontend/plugins/plugin-chart-echarts/src/BoxPlot/transformProps.ts @@ -36,6 +36,7 @@ import { getColtypesMapping, sanitizeHtml, } from '../utils/series'; +import { convertInteger } from '../utils/convertInteger'; import { defaultGrid, defaultTooltip, defaultYAxis } from '../defaults'; import { getPadding } from '../Timeseries/transformers'; import { OpacityEnum } from '../constants'; @@ -240,8 +241,8 @@ export default function transformProps( null, addXAxisTitleOffset, yAxisTitlePosition, - yAxisTitleMargin, - xAxisTitleMargin, + convertInteger(yAxisTitleMargin), + convertInteger(xAxisTitleMargin), ); const echartOptions: EChartsCoreOption = { grid: { @@ -253,7 +254,7 @@ export default function transformProps( data: transformedData.map(row => row.name), axisLabel, name: xAxisTitle, - nameGap: xAxisTitleMargin, + nameGap: convertInteger(xAxisTitleMargin), nameLocation: 'middle', }, yAxis: { @@ -261,7 +262,7 @@ export default function transformProps( type: 'value', axisLabel: { formatter: numberFormatter }, name: yAxisTitle, - nameGap: yAxisTitleMargin, + nameGap: convertInteger(yAxisTitleMargin), nameLocation: yAxisTitlePosition === 'Left' ? 'middle' : 'end', }, tooltip: { diff --git a/superset-frontend/plugins/plugin-chart-echarts/src/MixedTimeseries/transformProps.ts b/superset-frontend/plugins/plugin-chart-echarts/src/MixedTimeseries/transformProps.ts index 9ac3ff28c2df9..c3d6e979a96a4 100644 --- a/superset-frontend/plugins/plugin-chart-echarts/src/MixedTimeseries/transformProps.ts +++ b/superset-frontend/plugins/plugin-chart-echarts/src/MixedTimeseries/transformProps.ts @@ -50,6 +50,7 @@ import { formatForecastTooltipSeries, rebaseForecastDatum, } from '../utils/forecast'; +import { convertInteger } from '../utils/convertInteger'; import { defaultGrid, defaultTooltip, defaultYAxis } from '../defaults'; import { getPadding, @@ -251,8 +252,8 @@ export default function transformProps( null, addXAxisTitleOffset, yAxisTitlePosition, - yAxisTitleMargin, - xAxisTitleMargin, + convertInteger(yAxisTitleMargin), + convertInteger(xAxisTitleMargin), ); const labelMap = rawSeriesA.reduce((acc, datum) => { const label = datum.name as string; @@ -282,7 +283,7 @@ export default function transformProps( xAxis: { type: 'time', name: xAxisTitle, - nameGap: xAxisTitleMargin, + nameGap: convertInteger(xAxisTitleMargin), nameLocation: 'middle', axisLabel: { formatter: xAxisFormatter, @@ -300,7 +301,7 @@ export default function transformProps( axisLabel: { formatter }, scale: truncateYAxis, name: yAxisTitle, - nameGap: yAxisTitleMargin, + nameGap: convertInteger(yAxisTitleMargin), nameLocation: yAxisTitlePosition === 'Left' ? 'middle' : 'end', alignTicks, }, diff --git a/superset-frontend/plugins/plugin-chart-echarts/src/Timeseries/transformProps.ts b/superset-frontend/plugins/plugin-chart-echarts/src/Timeseries/transformProps.ts index e7848c4e4f602..b3a3d58c39958 100644 --- a/superset-frontend/plugins/plugin-chart-echarts/src/Timeseries/transformProps.ts +++ b/superset-frontend/plugins/plugin-chart-echarts/src/Timeseries/transformProps.ts @@ -55,6 +55,7 @@ import { formatForecastTooltipSeries, rebaseForecastDatum, } from '../utils/forecast'; +import { convertInteger } from '../utils/convertInteger'; import { defaultGrid, defaultTooltip, defaultYAxis } from '../defaults'; import { getPadding, @@ -125,6 +126,7 @@ export default function transformProps( yAxisTitleMargin, yAxisTitlePosition, }: EchartsTimeseriesFormData = { ...DEFAULT_FORM_DATA, ...formData }; + const colorScale = CategoricalColorNamespace.getScale(colorScheme as string); const rebasedData = rebaseForecastDatum(data, verboseMap); const xAxisCol = verboseMap[xAxisOrig] || xAxisOrig || DTTM_ALIAS; @@ -282,8 +284,8 @@ export default function transformProps( legendMargin, addXAxisLabelOffset, yAxisTitlePosition, - yAxisTitleMargin, - xAxisTitleMargin, + convertInteger(yAxisTitleMargin), + convertInteger(xAxisTitleMargin), ); const legendData = rawSeries @@ -304,7 +306,7 @@ export default function transformProps( xAxis: { type: xAxisType, name: xAxisTitle, - nameGap: xAxisTitleMargin, + nameGap: convertInteger(xAxisTitleMargin), nameLocation: 'middle', axisLabel: { hideOverlap: true, @@ -322,7 +324,7 @@ export default function transformProps( axisLabel: { formatter }, scale: truncateYAxis, name: yAxisTitle, - nameGap: yAxisTitleMargin, + nameGap: convertInteger(yAxisTitleMargin), nameLocation: yAxisTitlePosition === 'Left' ? 'middle' : 'end', }, tooltip: { diff --git a/superset-frontend/plugins/plugin-chart-echarts/src/utils/convertInteger.ts b/superset-frontend/plugins/plugin-chart-echarts/src/utils/convertInteger.ts new file mode 100644 index 0000000000000..16aa607ac594b --- /dev/null +++ b/superset-frontend/plugins/plugin-chart-echarts/src/utils/convertInteger.ts @@ -0,0 +1,22 @@ +/** + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ +export const convertInteger = (value: string | number) => { + if (typeof value !== 'number') return parseInt(value, 10) || 0; + return value; +};