react-overlay-pack
TypeScript icon, indicating that this package has built-in type declarations

3.1.1 • Public • Published

react-overlay-pack

Reusable components to build Tooltip, Popover and Dialog.

Travis Codecov Status npm package npm downloads

Dependency Status devDependency Status peerDependency Status

prettier license

Installation

$ yarn add react-overlay-pack

Demo

Usage

ClickOutside

import { ClickOutside } from 'react-overlay-pack';
 
<ClickOutside onClick={e => console.log(e)}>
  <div>content</div>
</ClickOutside>;
type Props = {
  children: React.Node,
  onClick: (e: any) => void,
};

DomAlign

import { DomAlign } from 'react-overlay-pack';
 
<div ref={this.target}>
  Target node
</div>
 
<DomAlign
  config={{ points: ['bl', 'tc'], offset: [5, 0] }}
  target={this.target}
  resize
>
  <div>
    Align node
  </div>
</DomAlign>
type Props = {
  children: React.Element<any>,
  config: Object,
  target: React.ElementRef<any>,
  resize?: boolean,
};

Overlay

import { Overlay } from 'react-overlay-pack';
 
<span ref={this.target} onClick={() => this.setState({ show: true })}>
  Target node
</span>;
 
<Overlay
  show={this.state.show}
  target={this.target}
  onOutsideClick={() => this.setState({ show: false })}
  resize
  alignConfig={{ points: ['tr', 'br'], targetOffset: [0, 8] }}
  transitionConfig={{
    style: { transform: 'translateY(-8px)' }, // From
    animation: { translateY: 0 }, // To
  }}
>
  <div key="div">This is overlay content.</div>
</Overlay>;
type Props = {
  show: boolean,
  children: any,
  onOutsideClick?: (e: any) => void,
  target?: React.ElementRef<any>,
  alignConfig: Object,
  transitionConfig?: Object,
  resize?: boolean,
};

Dialog

import { Dialog } from 'react-overlay-pack';
 
<Dialog
  show={this.state.show}
  onOutsideClick={() => this.setState({ show: false })}
>
  <div key="div">This is content.</div>
</Dialog>;
type Props = {
  show: boolean,
  children: React.Node,
  onOutsideClick: Function,
  backdropTransition?: Object,
  containerTransition?: Object,
};

Portal

Transition

Inspiration

Development

Requirements

  • node >= 11.6.0
  • yarn >= 1.12.3
  • react >= 16
$ yarn install --pure-lockfile
$ yarn start

Test

$ yarn run format
$ yarn run eslint
$ yarn run flow
$ yarn run test:watch
$ yarn run build

Publish

$ npm version patch
$ npm run changelog
git commit & push

CONTRIBUTING

  • ⇄ Pull requests and ★ Stars are always welcome.
  • For bugs and feature requests, please create an issue.
  • Pull requests must be accompanied by passing automated tests.

CHANGELOG

LICENSE

MIT: http://michaelhsu.mit-license.org

Package Sidebar

Install

npm i react-overlay-pack

Weekly Downloads

43

Version

3.1.1

License

MIT

Unpacked Size

76.8 kB

Total Files

56

Last publish

Collaborators

  • evenchange4