mirror of
https://github.com/apache/superset.git
synced 2026-05-08 01:15:46 +00:00
90 lines
2.2 KiB
TypeScript
90 lines
2.2 KiB
TypeScript
/**
|
|
* 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.
|
|
*/
|
|
import { rgb } from 'd3-color';
|
|
import { ChartProps, getValueFormatter } from '@superset-ui/core';
|
|
|
|
export default function transformProps(chartProps: ChartProps) {
|
|
const {
|
|
width,
|
|
height,
|
|
formData,
|
|
queriesData,
|
|
hooks,
|
|
inContextMenu,
|
|
filterState,
|
|
emitCrossFilters,
|
|
datasource,
|
|
} = chartProps;
|
|
const { onContextMenu, setDataMask } = hooks;
|
|
const {
|
|
countryFieldtype,
|
|
entity,
|
|
maxBubbleSize,
|
|
showBubbles,
|
|
linearColorScheme,
|
|
colorPicker,
|
|
colorBy,
|
|
colorScheme,
|
|
sliceId,
|
|
metric,
|
|
yAxisFormat,
|
|
currencyFormat,
|
|
} = formData;
|
|
const { r, g, b } = colorPicker;
|
|
const {
|
|
currencyFormats = {},
|
|
columnFormats = {},
|
|
currencyCodeColumn,
|
|
} = datasource;
|
|
const { data, detected_currency: detectedCurrency } = queriesData[0];
|
|
|
|
const formatter = getValueFormatter(
|
|
metric,
|
|
currencyFormats,
|
|
columnFormats,
|
|
yAxisFormat,
|
|
currencyFormat,
|
|
undefined, // key - not needed for single-metric charts
|
|
data,
|
|
currencyCodeColumn,
|
|
detectedCurrency,
|
|
);
|
|
|
|
return {
|
|
countryFieldtype,
|
|
entity,
|
|
data,
|
|
width,
|
|
height,
|
|
maxBubbleSize: parseInt(maxBubbleSize, 10),
|
|
showBubbles,
|
|
linearColorScheme,
|
|
color: rgb(r, g, b).hex(),
|
|
colorBy,
|
|
colorScheme,
|
|
sliceId,
|
|
onContextMenu,
|
|
setDataMask,
|
|
inContextMenu,
|
|
filterState,
|
|
emitCrossFilters,
|
|
formatter,
|
|
};
|
|
}
|