/** * 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 { ListGroup, ListGroupItem } from 'react-bootstrap'; import { connect } from 'react-redux'; import { t, withTheme } from '@superset-ui/core'; import { InfoTooltipWithTrigger } from '@superset-ui/chart-controls'; import Popover from 'src/components/Popover'; import AsyncEsmComponent from 'src/components/AsyncEsmComponent'; import { getChartKey } from 'src/explore/exploreUtils'; import { runAnnotationQuery } from 'src/chart/chartAction'; const AnnotationLayer = AsyncEsmComponent( () => import('./AnnotationLayer'), // size of overlay inner content () =>
, ); const propTypes = { colorScheme: PropTypes.string.isRequired, annotationError: PropTypes.object, annotationQuery: PropTypes.object, vizType: PropTypes.string, validationErrors: PropTypes.array, name: PropTypes.string.isRequired, actions: PropTypes.object, value: PropTypes.arrayOf(PropTypes.object), onChange: PropTypes.func, refreshAnnotationData: PropTypes.func, }; const defaultProps = { vizType: '', value: [], annotationError: {}, annotationQuery: {}, onChange: () => {}, }; class AnnotationLayerControl extends React.PureComponent { constructor(props) { super(props); this.state = { popoverVisible: {}, addedAnnotationIndex: null }; this.addAnnotationLayer = this.addAnnotationLayer.bind(this); this.removeAnnotationLayer = this.removeAnnotationLayer.bind(this); this.handleVisibleChange = this.handleVisibleChange.bind(this); } componentDidMount() { // preload the AnotationLayer component and dependent libraries i.e. mathjs AnnotationLayer.preload(); } UNSAFE_componentWillReceiveProps(nextProps) { const { name, annotationError, validationErrors, value } = nextProps; if (Object.keys(annotationError).length && !validationErrors.length) { this.props.actions.setControlValue( name, value, Object.keys(annotationError), ); } if (!Object.keys(annotationError).length && validationErrors.length) { this.props.actions.setControlValue(name, value, []); } } addAnnotationLayer(originalAnnotation, newAnnotation) { let annotations = this.props.value; if (annotations.includes(originalAnnotation)) { annotations = annotations.map(anno => anno === originalAnnotation ? newAnnotation : anno, ); } else { annotations = [...annotations, newAnnotation]; this.setState({ addedAnnotationIndex: annotations.length - 1 }); } this.props.refreshAnnotationData(newAnnotation); this.props.onChange(annotations); } handleVisibleChange(visible, popoverKey) { this.setState(prevState => ({ popoverVisible: { ...prevState.popoverVisible, [popoverKey]: visible }, })); } removeAnnotationLayer(annotation) { const annotations = this.props.value.filter(anno => anno !== annotation); this.props.onChange(annotations); } renderPopover(popoverKey, annotation, error) { const id = annotation?.name || '_new'; return (