/** * 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, DropdownButton, MenuItem, OverlayTrigger, Row, Tooltip, Well, } from 'react-bootstrap'; import { t, styled } from '@superset-ui/core'; import { ColumnOption, MetricOption } from '@superset-ui/chart-controls'; import TooltipWrapper from 'src/components/TooltipWrapper'; 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'; import './DatasourceControl.less'; 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` #datasource_menu { 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; } } `; /** * 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; } `; 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); } 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, })); } 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; return (
{t('Expand/collapse dataset configuration')} } > } className="" bsSize="sm" id="datasource_menu" > {t('Change Dataset')} {datasource.type === 'table' && ( {t('Explore in SQL Lab')} )} {this.props.isEditable && ( {t('Edit Dataset')} )}
{this.renderDatasource()} {showEditDatasourceModal && ( )} {showChangeDatasourceModal && ( )}
); } } DatasourceControl.propTypes = propTypes; DatasourceControl.defaultProps = defaultProps; export default DatasourceControl;