/** * 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, { ReactNode, useCallback, useState } from 'react'; import { ControlType } from '@superset-ui/chart-controls'; import { JsonValue, QueryFormData } from '@superset-ui/core'; import ErrorBoundary from 'src/components/ErrorBoundary'; import { ExploreActions } from 'src/explore/actions/exploreActions'; import controlMap from './controls'; import './Control.less'; export type ControlProps = { // the actual action dispatcher (via bindActionCreators) has identical // signature to the original action factory. actions: Partial & Pick; type: ControlType; label?: ReactNode; name: string; description?: ReactNode; tooltipOnClick?: () => ReactNode; places?: number; rightNode?: ReactNode; formData?: QueryFormData | null; value?: JsonValue; validationErrors?: any[]; hidden?: boolean; renderTrigger?: boolean; }; export default function Control(props: ControlProps) { const { actions: { setControlValue }, name, type, hidden, } = props; const [hovered, setHovered] = useState(false); const onChange = useCallback( (value: any, errors: any[]) => setControlValue(name, value, errors), [name, setControlValue], ); if (!type) return null; const ControlComponent = typeof type === 'string' ? controlMap[type] : type; if (!ControlComponent) { return <>Unknown controlType: {type}; } return (
setHovered(true)} onMouseLeave={() => setHovered(false)} >
); }