forked from DonJayamanne/pythonVSCode
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathflyout.tsx
More file actions
61 lines (53 loc) · 1.9 KB
/
Copy pathflyout.tsx
File metadata and controls
61 lines (53 loc) · 1.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
'use strict';
import './flyout.css';
import * as React from 'react';
interface IFlyoutProps {
buttonClassName: string;
flyoutContainerName: string;
buttonContent: JSX.Element;
buttonTooltip?: string;
disabled?: boolean;
hidden?: boolean;
}
interface IFlyoutState {
visible: boolean;
}
export class Flyout extends React.Component<IFlyoutProps, IFlyoutState> {
constructor(props: IFlyoutProps) {
super(props);
this.state = { visible: false };
}
public render() {
const innerFilter = this.props.disabled ? 'flyout-inner-disabled-filter' : '';
const ariaDisabled = this.props.disabled ? 'true' : 'false';
const buttonClassName = this.props.buttonClassName;
const flyoutClassName = this.state.visible
? `flyout-children-visible ${this.props.flyoutContainerName}`
: `flyout-children-hidden ${this.props.flyoutContainerName}`;
return (
<div className="flyout-container" onMouseLeave={this.mouseLeave}>
<button
role="button"
aria-pressed="false"
disabled={this.props.disabled}
aria-disabled={ariaDisabled}
title={this.props.buttonTooltip}
aria-label={this.props.buttonTooltip}
onMouseEnter={this.mouseEnter}
className={buttonClassName}
>
<span className={innerFilter}>{this.props.buttonContent}</span>
</button>
<div className={flyoutClassName}>{this.props.children}</div>
</div>
);
}
private mouseEnter = () => {
this.setState({ visible: true });
};
private mouseLeave = () => {
this.setState({ visible: false });
};
}