Fix multilayer geoviz and color picker error (#5767)

* Fix multilayer goeviz and color picker error

* fix lint

* remove props.data and improve merging list

* nit
This commit is contained in:
Junda Yang 2018-08-29 15:37:39 -07:00 committed by Beto Dealmeida
parent 00f2771f23
commit 5437efa590
5 changed files with 28 additions and 20 deletions

View File

@ -30,11 +30,11 @@ function getCategories(fd, data) {
const propTypes = {
slice: PropTypes.object.isRequired,
data: PropTypes.array.isRequired,
mapboxApiKey: PropTypes.string.isRequired,
setControlValue: PropTypes.func.isRequired,
viewport: PropTypes.object.isRequired,
getLayer: PropTypes.func.isRequired,
payload: PropTypes.object.isRequired,
};
export default class CategoricalDeckGLContainer extends React.PureComponent {
@ -50,9 +50,9 @@ export default class CategoricalDeckGLContainer extends React.PureComponent {
const fd = nextProps.slice.formData;
const timeGrain = fd.time_grain_sqla || fd.granularity || 'PT1M';
const timestamps = nextProps.data.map(f => f.__timestamp);
const timestamps = nextProps.payload.data.features.map(f => f.__timestamp);
const { start, end, step, values, disabled } = getPlaySliderParams(timestamps, timeGrain);
const categories = getCategories(fd, nextProps.data);
const categories = getCategories(fd, nextProps.payload.data.features);
return { start, end, step, values, disabled, categories };
}
@ -79,8 +79,9 @@ export default class CategoricalDeckGLContainer extends React.PureComponent {
});
}
getLayers(values) {
const fd = this.props.slice.formData;
let data = [...this.props.data];
const { getLayer, payload, slice } = this.props;
const fd = slice.formData;
let data = [...payload.data.features];
// Add colors from categories or fixed color
data = this.addColor(data, fd);
@ -103,7 +104,8 @@ export default class CategoricalDeckGLContainer extends React.PureComponent {
data = data.filter(d => this.state.categories[d.cat_color].enabled);
}
return [this.props.getLayer(fd, data, this.props.slice)];
payload.data.features = data;
return [getLayer(fd, payload, slice)];
}
toggleCategory(category) {
const categoryState = this.state.categories[category];

View File

@ -18,7 +18,8 @@ function getPoints(data) {
return points;
}
function getLayer(fd, data, slice) {
function getLayer(fd, payload, slice) {
const data = payload.data.features;
const sc = fd.color_picker;
const tc = fd.target_color_picker;
return new ArcLayer({
@ -40,17 +41,17 @@ function deckArc(slice, payload, setControlValue) {
};
if (fd.autozoom) {
viewport = common.fitViewport(viewport, getPoints(payload.data.arcs));
viewport = common.fitViewport(viewport, getPoints(payload.data.features));
}
ReactDOM.render(
<CategoricalDeckGLContainer
slice={slice}
data={payload.data.arcs}
mapboxApiKey={payload.data.mapboxApiKey}
setControlValue={setControlValue}
viewport={viewport}
getLayer={getLayer}
payload={payload}
/>,
document.getElementById(slice.containerId),
);

View File

@ -14,13 +14,18 @@ function getPoints(data) {
return data.map(d => d.position);
}
function getLayer(fd, data, slice) {
const dataWithRadius = data.map((d) => {
function getLayer(fd, payload, slice) {
const dataWithRadius = payload.data.features.map((d) => {
let radius = unitToRadius(fd.point_unit, d.radius) || 10;
if (fd.multiplier) {
radius *= fd.multiplier;
}
return { ...d, radius };
if (d.color) {
return { ...d, radius };
}
const c = fd.color_picker || { r: 0, g: 0, b: 0, a: 1 };
const color = [c.r, c.g, c.b, c.a * 255];
return { ...d, radius, color };
});
return new ScatterplotLayer({
@ -49,11 +54,11 @@ function deckScatter(slice, payload, setControlValue) {
ReactDOM.render(
<CategoricalDeckGLContainer
slice={slice}
data={payload.data.features}
mapboxApiKey={payload.data.mapboxApiKey}
setControlValue={setControlValue}
viewport={viewport}
getLayer={getLayer}
payload={payload}
/>,
document.getElementById(slice.containerId),
);

View File

@ -33,10 +33,11 @@ function deckMulti(slice, payload, setControlValue) {
// Filters applied to multi_deck are passed down to underlying charts
// note that dashboard contextual information (filter_immune_slices and such) aren't
// taken into consideration here
let filters = subslice.form_data.filters.concat(fd.filters);
if (fd.extra_filters) {
filters = filters.concat(fd.extra_filters);
}
const filters = [
...(subslice.form_data.filters || []),
...(fd.filters || []),
...(fd.extra_filters || []),
];
const subsliceCopy = {
...subslice,
form_data: {

View File

@ -2166,7 +2166,7 @@ class BaseDeckGLViz(BaseViz):
fd = self.form_data
# add NULL filters
if fd.get('filter_nulls'):
if fd.get('filter_nulls', True):
self.add_null_filters()
d = super(BaseDeckGLViz, self).query_obj()
@ -2432,10 +2432,9 @@ class DeckArc(BaseDeckGLViz):
def get_data(self, df):
d = super(DeckArc, self).get_data(df)
arcs = d['features']
return {
'arcs': arcs,
'features': d['features'],
'mapboxApiKey': config.get('MAPBOX_API_KEY'),
}