diff options
author | fragosti <francesco.agosti93@gmail.com> | 2018-08-28 09:29:35 +0800 |
---|---|---|
committer | fragosti <francesco.agosti93@gmail.com> | 2018-08-28 09:29:35 +0800 |
commit | 5785ec0713c39466b3a6a171f5f0a2d38207b44b (patch) | |
tree | 95c7bbb4ae8b4f627a0465cec86f77d5eb349484 /packages/website/ts/components/ui | |
parent | 91a9014a50cca8e0d42634666fe409839aeae8cf (diff) | |
download | dexon-sol-tools-5785ec0713c39466b3a6a171f5f0a2d38207b44b.tar dexon-sol-tools-5785ec0713c39466b3a6a171f5f0a2d38207b44b.tar.gz dexon-sol-tools-5785ec0713c39466b3a6a171f5f0a2d38207b44b.tar.bz2 dexon-sol-tools-5785ec0713c39466b3a6a171f5f0a2d38207b44b.tar.lz dexon-sol-tools-5785ec0713c39466b3a6a171f5f0a2d38207b44b.tar.xz dexon-sol-tools-5785ec0713c39466b3a6a171f5f0a2d38207b44b.tar.zst dexon-sol-tools-5785ec0713c39466b3a6a171f5f0a2d38207b44b.zip |
Have new Popover component working in React 16
Diffstat (limited to 'packages/website/ts/components/ui')
-rw-r--r-- | packages/website/ts/components/ui/container.tsx | 8 | ||||
-rw-r--r-- | packages/website/ts/components/ui/drop_down.tsx | 43 | ||||
-rw-r--r-- | packages/website/ts/components/ui/overlay.tsx | 2 | ||||
-rw-r--r-- | packages/website/ts/components/ui/popover.tsx | 59 |
4 files changed, 84 insertions, 28 deletions
diff --git a/packages/website/ts/components/ui/container.tsx b/packages/website/ts/components/ui/container.tsx index f2ae68b70..cf3ec41f2 100644 --- a/packages/website/ts/components/ui/container.tsx +++ b/packages/website/ts/components/ui/container.tsx @@ -26,10 +26,10 @@ export interface ContainerProps { className?: string; position?: 'absolute' | 'fixed' | 'relative' | 'unset'; display?: 'inline-block' | 'block' | 'inline-flex' | 'inline'; - top?: string; - left?: string; - right?: string; - bottom?: string; + top?: StringOrNum; + left?: StringOrNum; + right?: StringOrNum; + bottom?: StringOrNum; zIndex?: number; Tag?: ContainerTag; cursor?: string; diff --git a/packages/website/ts/components/ui/drop_down.tsx b/packages/website/ts/components/ui/drop_down.tsx index 752c92e02..638b29f88 100644 --- a/packages/website/ts/components/ui/drop_down.tsx +++ b/packages/website/ts/components/ui/drop_down.tsx @@ -1,6 +1,6 @@ -import Popover from 'material-ui/Popover'; import * as React from 'react'; -import { MaterialUIPosition } from 'ts/types'; +import { Placement } from 'react-popper'; +import { Popover } from 'ts/components/ui/popover'; const CHECK_CLOSE_POPOVER_INTERVAL_MS = 300; const DEFAULT_STYLE = { @@ -15,8 +15,7 @@ export enum DropdownMouseEvent { export interface DropDownProps { activeNode: React.ReactNode; popoverContent: React.ReactNode; - anchorOrigin: MaterialUIPosition; - targetOrigin: MaterialUIPosition; + placement?: Placement; style?: React.CSSProperties; zDepth?: number; activateEvent?: DropdownMouseEvent; @@ -33,8 +32,8 @@ export class DropDown extends React.Component<DropDownProps, DropDownState> { public static defaultProps: Partial<DropDownProps> = { style: DEFAULT_STYLE, zDepth: 1, - activateEvent: DropdownMouseEvent.Hover, - closeEvent: DropdownMouseEvent.Hover, + activateEvent: DropdownMouseEvent.Click, + closeEvent: DropdownMouseEvent.Click, }; private _popoverCloseCheckIntervalId: number; public static getDerivedStateFromProps(props: DropDownProps, state: DropDownState): Partial<DropDownState> { @@ -70,24 +69,22 @@ export class DropDown extends React.Component<DropDownProps, DropDownState> { onMouseLeave={this._onHoverOff.bind(this)} > <div onClick={this._onActiveNodeClick.bind(this)}>{this.props.activeNode}</div> - <Popover - open={this.state.isDropDownOpen} - anchorEl={this.state.anchorEl} - anchorOrigin={this.props.anchorOrigin} - targetOrigin={this.props.targetOrigin} - onRequestClose={this._closePopover.bind(this)} - useLayerForClickAway={this.props.closeEvent === DropdownMouseEvent.Click} - animated={false} - zDepth={this.props.zDepth} - > - <div - onMouseEnter={this._onHover.bind(this)} - onMouseLeave={this._onHoverOff.bind(this)} - onClick={this._closePopover.bind(this)} + {this.state.isDropDownOpen && + <Popover + anchorEl={this.state.anchorEl} + placement={this.props.placement} + onRequestClose={this._closePopover.bind(this)} + zIndex={this.props.zDepth} > - {this.props.popoverContent} - </div> - </Popover> + <div + onMouseEnter={this._onHover.bind(this)} + onMouseLeave={this._onHoverOff.bind(this)} + onClick={this._closePopover.bind(this)} + > + {this.props.popoverContent} + </div> + </Popover> + } </div> ); } diff --git a/packages/website/ts/components/ui/overlay.tsx b/packages/website/ts/components/ui/overlay.tsx index fc7507475..cb68aeca1 100644 --- a/packages/website/ts/components/ui/overlay.tsx +++ b/packages/website/ts/components/ui/overlay.tsx @@ -29,4 +29,4 @@ Overlay.defaultProps = { onClick: _.noop.bind(_), }; -Overlay.displayName = 'Overlay'; +Overlay.displayName = 'Overlay';
\ No newline at end of file diff --git a/packages/website/ts/components/ui/popover.tsx b/packages/website/ts/components/ui/popover.tsx new file mode 100644 index 000000000..66c0ac663 --- /dev/null +++ b/packages/website/ts/components/ui/popover.tsx @@ -0,0 +1,59 @@ +import * as _ from 'lodash'; +import * as React from 'react'; +import * as ReactDOM from 'react-dom'; +import { Placement, Popper, PopperChildrenProps } from 'react-popper'; + +import { colors } from '@0xproject/react-shared'; +import { Container } from 'ts/components/ui/container'; +import { Overlay } from 'ts/components/ui/overlay'; +import { styled } from 'ts/style/theme'; + +export interface PopoverProps { + anchorEl: HTMLInputElement; + placement?: Placement; + onRequestClose?: () => void; + zIndex?: number; +} + +const PopoverContainer = styled.div` + background-color: ${colors.white}; + max-height: 679px; + overflow-y: auto; + border-radius: 2px; +`; + +const defaultPlacement: Placement = 'bottom'; + +export class Popover extends React.Component<PopoverProps> { + public static defaultProps = { + placement: defaultPlacement, + }; + + public render(): React.ReactNode { + const { anchorEl, placement, zIndex, onRequestClose } = this.props; + const overlayStyleOverrides = { + zIndex, + backgroundColor: 'transparent', + }; + return ( + <div> + <Overlay onClick={onRequestClose} style={overlayStyleOverrides}/> + <Popper referenceElement={anchorEl} placement="bottom" eventsEnabled={true}> + {this._renderPopperChildren.bind(this)} + </Popper> + </div> + ); + } + private _renderPopperChildren(props: PopperChildrenProps): React.ReactNode { + const popperContainerStyleOverrids = { + zIndex: _.isUndefined(this.props.zIndex) ? undefined : this.props.zIndex + 1, + }; + return ( + <div ref={props.ref} style={{...props.style, ...popperContainerStyleOverrids}}> + <PopoverContainer> + {this.props.children} + </PopoverContainer> + </div> + ); + } +} |