/** * 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 } from '@superset-ui/core'; import { ColumnOption, MetricOption } from '@superset-ui/chart-controls'; import Label from 'src/components/Label'; import ControlHeader from '../ControlHeader'; import DatasourceModal from '../../../datasource/DatasourceModal'; import ChangeDatasourceModal from '../../../datasource/ChangeDatasourceModal'; import TooltipWrapper from '../../../components/TooltipWrapper'; 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, }; class DatasourceControl extends React.PureComponent { constructor(props) { super(props); this.state = { showEditDatasourceModal: false, showChangeDatasourceModal: false, menuExpanded: 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.datasource; return (