/** * 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 React from 'react'; import PropTypes from 'prop-types'; import { Col, Collapse, Row, Well } from 'react-bootstrap'; import { t, styled } from '@superset-ui/core'; import { ColumnOption, MetricOption } from '@superset-ui/chart-controls'; import { Dropdown, Menu } from 'src/common/components'; import Tooltip from 'src/common/components/Tooltip'; import Icon from 'src/components/Icon'; import ChangeDatasourceModal from 'src/datasource/ChangeDatasourceModal'; import DatasourceModal from 'src/datasource/DatasourceModal'; import Label from 'src/components/Label'; import ControlHeader from '../ControlHeader'; const propTypes = { actions: PropTypes.object.isRequired, onChange: PropTypes.func, value: PropTypes.string, datasource: PropTypes.object.isRequired, isEditable: PropTypes.bool, onDatasourceSave: PropTypes.func, }; const defaultProps = { onChange: () => {}, onDatasourceSave: null, value: null, isEditable: true, }; const Styles = styled.div` .ant-dropdown-trigger { margin-left: ${({ theme }) => theme.gridUnit}px; box-shadow: none; &:active { box-shadow: none; } } .btn-group .open .dropdown-toggle { box-shadow: none; &.button-default { background: none; } } i.angle { color: ${({ theme }) => theme.colors.primary.base}; } svg.datasource-modal-trigger { color: ${({ theme }) => theme.colors.primary.base}; vertical-align: middle; cursor: pointer; } `; /** * used in column details. */ const ColumnsCol = styled(Col)` overflow: auto; /* for very very long columns names */ white-space: nowrap; /* make sure tooltip trigger is on the same line as the metric */ .and-more { padding-left: 38px; } `; const CHANGE_DATASET = 'change_dataset'; const EXPLORE_IN_SQL_LAB = 'explore_in_sql_lab'; const EDIT_DATASET = 'edit_dataset'; class DatasourceControl extends React.PureComponent { constructor(props) { super(props); this.state = { showEditDatasourceModal: false, showChangeDatasourceModal: false, }; this.onDatasourceSave = this.onDatasourceSave.bind(this); this.toggleChangeDatasourceModal = this.toggleChangeDatasourceModal.bind( this, ); this.toggleEditDatasourceModal = this.toggleEditDatasourceModal.bind(this); this.toggleShowDatasource = this.toggleShowDatasource.bind(this); this.renderDatasource = this.renderDatasource.bind(this); this.handleMenuItemClick = this.handleMenuItemClick.bind(this); } onDatasourceSave(datasource) { this.props.actions.setDatasource(datasource); if (this.props.onDatasourceSave) { this.props.onDatasourceSave(datasource); } } toggleShowDatasource() { this.setState(({ showDatasource }) => ({ showDatasource: !showDatasource, })); } toggleChangeDatasourceModal() { this.setState(({ showChangeDatasourceModal }) => ({ showChangeDatasourceModal: !showChangeDatasourceModal, })); } toggleEditDatasourceModal() { this.setState(({ showEditDatasourceModal }) => ({ showEditDatasourceModal: !showEditDatasourceModal, })); } handleMenuItemClick({ key }) { if (key === CHANGE_DATASET) { this.toggleChangeDatasourceModal(); } if (key === EDIT_DATASET) { this.toggleEditDatasourceModal(); } } renderDatasource() { const { datasource } = this.props; const { showDatasource } = this.state; const maxNumColumns = 50; return (
{` ${datasource.database.name} `}
{showDatasource && ( Columns {datasource.columns.slice(0, maxNumColumns).map(col => (
))} {datasource.columns.length > maxNumColumns && (
...
)}
Metrics {datasource.metrics.slice(0, maxNumColumns).map(m => (
))} {datasource.columns.length > maxNumColumns && (
...
)}
)}
); } render() { const { showChangeDatasourceModal, showEditDatasourceModal, showDatasource, } = this.state; const { datasource, onChange, value } = this.props; const datasourceMenu = ( {this.props.isEditable && ( {t('Edit Dataset')} )} {t('Change Dataset')} {t('View in SQL Lab')} ); return (
{this.renderDatasource()} {showEditDatasourceModal && ( )} {showChangeDatasourceModal && ( )}
); } } DatasourceControl.propTypes = propTypes; DatasourceControl.defaultProps = defaultProps; export default DatasourceControl;