fix(toolbar): refactored toolbar and variable to overlay (#15681)

fix(toolbar): refactored toolbar and variable to overlay
pull/15709/head
Ariel Salem 2019-11-01 06:53:05 -07:00 committed by GitHub
parent 2ccd93d725
commit cba69aba5f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 104 additions and 107 deletions

View File

@ -192,6 +192,27 @@ describe('DataExplorer', () => {
cy.getByTestID('query-builder').should('exist')
})
it('should display the popover when hovering', () => {
cy.getByTestID('selector-list my_meas')
.click()
.then(() => {
cy.getByTestID('selector-list my_field')
.click()
.then(() => {
cy.getByTestID('switch-to-script-editor').click()
cy.getByTestID('flux-editor').should('exist')
cy.getByTestID('toolbar-popover--contents').should('not.exist')
cy.getByTestID('flux-function aggregateWindow').trigger(
'mouseover'
)
cy.getByTestID('toolbar-popover--contents').should('exist')
})
})
})
})
describe('raw script editing', () => {

View File

@ -90,3 +90,7 @@ $box-tooltip--caret-size: 6px;
right: 0;
}
}
.tooltip--link {
padding-bottom: 10px;
}

View File

@ -37,15 +37,23 @@
}
}
.flux-functions-toolbar--function {
position: relative;
}
.flux-functions-toolbar--helper {
color: $g10-wolf;
padding: 15px;
visibility: hidden;
}
.flux-functions-toolbar--function {
position: relative;
&:hover {
.flux-functions-toolbar--helper {
visibility: visible;
}
}
}
.flux-functions-toolbar--heading {
font-weight: 600;
margin-bottom: $ix-marg-a;

View File

@ -21,14 +21,12 @@ const FunctionTooltipContents: FunctionComponent<Props> = ({
func: {desc, args, example, link},
}) => {
return (
<div className="box-tooltip--contents">
<FancyScrollbar autoHeight={true} maxHeight={MAX_HEIGHT} autoHide={false}>
<TooltipDescription description={desc} />
<TooltipArguments argsList={args} />
<TooltipExample example={example} />
<TooltipLink link={link} />
</FancyScrollbar>
</div>
)
}

View File

@ -1,9 +1,14 @@
// Libraries
import React, {PureComponent, createRef} from 'react'
import React, {FC, createRef} from 'react'
// Component
import FunctionTooltipContents from 'src/timeMachine/components/fluxFunctionsToolbar/FunctionTooltipContents'
import BoxTooltip from 'src/shared/components/BoxTooltip'
import {
Popover,
PopoverPosition,
PopoverInteraction,
PopoverType,
} from '@influxdata/clockface'
// Types
import {FluxToolbarFunction} from 'src/types/shared'
@ -14,77 +19,43 @@ interface Props {
testID: string
}
interface State {
isActive: boolean
const defaultProps = {
testID: 'toolbar-function',
}
class ToolbarFunction extends PureComponent<Props, State> {
public static defaultProps = {
testID: 'toolbar-function',
const ToolbarFunction: FC<Props> = ({func, onClickFunction, testID}) => {
const functionRef = createRef<HTMLDivElement>()
const handleClickFunction = () => {
onClickFunction(func)
}
public state: State = {isActive: false}
private functionRef = createRef<HTMLDivElement>()
public render() {
const {func, testID} = this.props
const {isActive} = this.state
return (
<div
className="flux-functions-toolbar--function"
ref={this.functionRef}
onMouseEnter={this.handleHover}
onMouseLeave={this.handleStopHover}
ref={functionRef}
data-testid={testID}
>
{isActive && (
<BoxTooltip triggerRect={this.domRect}>
<FunctionTooltipContents func={func} />
</BoxTooltip>
)}
<Popover
type={PopoverType.Outline}
position={PopoverPosition.ToTheLeft}
triggerRef={functionRef}
showEvent={PopoverInteraction.Hover}
hideEvent={PopoverInteraction.Hover}
distanceFromTrigger={8}
testID="toolbar-popover"
contents={() => <FunctionTooltipContents func={func} />}
/>
<dd
onClick={this.handleClickFunction}
onClick={handleClickFunction}
data-testid={`flux-function ${func.name}`}
>
{func.name} {this.helperText}
{func.name}
&nbsp;
<span className="flux-functions-toolbar--helper">Click to Add</span>
</dd>
</div>
)
}
private get domRect(): DOMRect {
if (!this.functionRef.current) {
return null
}
return this.functionRef.current.getBoundingClientRect() as DOMRect
}
private get helperText(): JSX.Element | null {
if (this.state.isActive) {
return (
<span className="flux-functions-toolbar--helper">Click to Add</span>
)
}
return null
}
private handleHover = () => {
this.setState({isActive: true})
}
private handleStopHover = () => {
this.setState({isActive: false})
}
private handleClickFunction = () => {
const {func, onClickFunction} = this.props
onClickFunction(func)
}
}
ToolbarFunction.defaultProps = defaultProps
export default ToolbarFunction

View File

@ -5,7 +5,7 @@ interface Props {
}
const TooltipLink: SFC<Props> = ({link}) => (
<p>
<p className="tooltip--link">
Still have questions? Check out the{' '}
<a target="_blank" href={link}>
Flux Docs

View File

@ -1,9 +1,14 @@
// Libraries
import React, {FunctionComponent, useRef, useState} from 'react'
import React, {FC, useRef} from 'react'
// Components
import VariableTooltipContents from 'src/timeMachine/components/variableToolbar/VariableTooltipContents'
import BoxTooltip from 'src/shared/components/BoxTooltip'
import {
Popover,
PopoverPosition,
PopoverInteraction,
PopoverType,
} from '@influxdata/clockface'
// Types
import {IVariable as Variable} from '@influxdata/influx'
@ -14,32 +19,22 @@ interface Props {
onClickVariable: (variableName: string) => void
}
const VariableItem: FunctionComponent<Props> = ({
variable,
onClickVariable,
}) => {
const VariableItem: FC<Props> = ({variable, onClickVariable}) => {
const trigger = useRef<HTMLDivElement>(null)
const [tooltipVisible, setTooltipVisible] = useState(false)
let triggerRect: DOMRect = null
if (trigger.current) {
triggerRect = trigger.current.getBoundingClientRect() as DOMRect
}
return (
<div
className="variables-toolbar--item"
onMouseEnter={() => setTooltipVisible(true)}
onMouseLeave={() => setTooltipVisible(false)}
ref={trigger}
>
<div className="variables-toolbar--item" ref={trigger}>
<VariableLabel name={variable.name} onClickVariable={onClickVariable} />
{tooltipVisible && (
<BoxTooltip triggerRect={triggerRect}>
<VariableTooltipContents variableID={variable.id} />
</BoxTooltip>
)}
<Popover
type={PopoverType.Outline}
position={PopoverPosition.ToTheLeft}
triggerRef={trigger}
showEvent={PopoverInteraction.Hover}
hideEvent={PopoverInteraction.Hover}
distanceFromTrigger={8}
testID="toolbar-popover"
contents={() => <VariableTooltipContents variableID={variable.id} />}
/>
</div>
)
}

View File

@ -81,7 +81,7 @@ const VariableTooltipContents: FunctionComponent<Props> = ({
}
return (
<div className="box-tooltip--contents" onMouseEnter={handleMouseEnter}>
<div onMouseEnter={handleMouseEnter}>
<Form.Element label="Value">
<SelectDropdown
buttonIcon={icon}