mirror of https://github.com/apache/superset.git
fix: show TIME COLUMN options in dashboard (#11210)
* fix: show TIME COLUMN options in dashboard * add unit test
This commit is contained in:
parent
4f4367edf3
commit
88af85ac53
|
@ -17,9 +17,10 @@
|
|||
* under the License.
|
||||
*/
|
||||
import React from 'react';
|
||||
import { shallow } from 'enzyme';
|
||||
import { shallow, mount } from 'enzyme';
|
||||
|
||||
import FilterBox from 'src/visualizations/FilterBox/FilterBox';
|
||||
import SelectControl from 'src/explore/components/controls/SelectControl';
|
||||
|
||||
describe('FilterBox', () => {
|
||||
it('should only add defined non-predefined options to filtersChoices', () => {
|
||||
|
@ -58,4 +59,30 @@ describe('FilterBox', () => {
|
|||
inst.setState({ selectedValues: { name: 'James' } });
|
||||
expect(inst.props.filtersChoices.name.length).toEqual(3);
|
||||
});
|
||||
|
||||
it('should support granularity_sqla options', () => {
|
||||
const wrapper = mount(
|
||||
<FilterBox
|
||||
chartId={1001}
|
||||
datasource={{
|
||||
id: 1,
|
||||
columns: [],
|
||||
databases: {},
|
||||
granularity_sqla: [
|
||||
['created_on', 'created_on'],
|
||||
['changed_on', 'changed_on'],
|
||||
],
|
||||
}}
|
||||
showSqlaTimeColumn
|
||||
instantFiltering
|
||||
/>,
|
||||
);
|
||||
|
||||
expect(wrapper.find(SelectControl).props().choices).toEqual(
|
||||
expect.arrayContaining([
|
||||
['created_on', 'created_on'],
|
||||
['changed_on', 'changed_on'],
|
||||
]),
|
||||
);
|
||||
});
|
||||
});
|
||||
|
|
|
@ -316,12 +316,12 @@ export const controls = {
|
|||
mapStateToProps: state => {
|
||||
const props = {};
|
||||
if (state.datasource) {
|
||||
props.options = state.datasource.columns.filter(c => c.is_dttm);
|
||||
props.choices = state.datasource.granularity_sqla;
|
||||
props.default = null;
|
||||
if (state.datasource.main_dttm_col) {
|
||||
props.default = state.datasource.main_dttm_col;
|
||||
} else if (props.options && props.options.length > 0) {
|
||||
props.default = props.options[0].column_name;
|
||||
} else if (props.choices && props.choices.length > 0) {
|
||||
props.default = props.choices[0].column_name;
|
||||
}
|
||||
}
|
||||
return props;
|
||||
|
|
|
@ -406,7 +406,7 @@ class FilterBox extends React.Component {
|
|||
}
|
||||
|
||||
renderFilters() {
|
||||
const { filtersFields, chartId } = this.props;
|
||||
const { filtersFields = [], chartId } = this.props;
|
||||
return filtersFields.map(filterConfig => {
|
||||
const { label, key } = filterConfig;
|
||||
return (
|
||||
|
|
Loading…
Reference in New Issue