2.0.1 • Published 5 years ago
@kaprisa57/react-popover v2.0.1
Popover React Component
Install
npm install --save @kaprisa57/react-popoveryarn add @kaprisa57/react-popoverAdvantages
- Fully and easily customizable. It has a bunch of props, including animation, className, arrow visibility, etc.
 - Uses styled-components for styling.
 - Able to change dimensions depending on available space (if maxHeight and maxWidth not specified).
 - Able to choose better placement if there is no room (if guessBetterPosition = true, default false).
 - Able to follow trigger (if considerTriggerMotion = true, default false for better performance).
 - Able to detect trigger width and height and use them for content (useTriggerWidth, useTriggerHeight).
 - Considers window resizing.
 - Closes on scroll event of scroll container (if closeOnScroll = true, default true).
 - Supports 12 different placements.
 - Able to close on remote click, enter and escape buttons press.
 - Able to open on hover, click, focus and contextMenu events.
 - Supports external visibility control (if isOpenControlled = true).
 - Renders content into body or provided container.
 - Supports children and content functions and provides them with some useful props.
 - Accepts custom offset from default position.
 - Accepts custom mouse enter/leave delay if trigger is "hover".
 - Accepts custom trigger container display and tag.
 - Accepts arrowSize, arrowOffset and arrowPlacement for arrow customization.
 - Lazy initialization. Popover initializes on first trigger event.
 
See props in Docs
Basic Example
import React from 'react'
import Popover from '@kaprisa57/react-popover'
function Example() {
  return <Popover content="Hi!">
    <button>Open</button>
  </Popover>
}Consider Trigger Motion
Popover can follow trigger if considerTriggerMotion = true.
See example here
Custom styles. Live Example
Note: if you use styled-components of different version use && for styles priority
import React from 'react'
import Popover from '@kaprisa57/react-popover'
import styled from 'styled-components'
const CustomPopover = styled(Popover)`
  background-color: aquamarine;
  border-radius: 30px;
  border: 2px solid black;
  box-shadow: none;
  &:before { // arrow
    border-left-color: black;
    border-bottom-color: black;
    box-shadow: none;
  }
`
// if you use lower version of styled-components
const CustomPopover2 = styled(Popover)`
  && {
    background-color: aquamarine;
    border-radius: 30px;
    border: 2px solid black;
    box-shadow: none;
    &:before { // arrow
    border-left-color: black;
    border-bottom-color: black;
    box-shadow: none;
    }
 }
`
export function styledPopover(props) {
  return (
      <CustomPopover {...props} content="Hi!">
        <button>Open</button>
      </CustomPopover>
  );
}Also you can use className
Custom Animation
You can configure custom animation by defining framer-motion props. In this example used simple opacity animation, i.e. you won't see any jumping or movement. Live Example.
import React from 'react'
import Popover from '@kaprisa57/react-popover'
const animation = {
  initial: {
      opacity: 0,
  },
   
 animate: {
  opacity: 1,
 },
   
   exit: {
     opacity: 0,
     transition: { duration: 0.1 },
   },
 }
function PopoverWithCustomAnimation() {
  return <Popover
      content="Hi!"
      trigger="click"
      // Popover won't move during opening
      animationTranslateDistance={0}
      // custom animation
      animation={animation}
     >
       <button>Click to Open</button>
     </Popover>
}See more details in storybook
License
MIT © kaprisa57@gmail.com
2.0.1
5 years ago
2.0.0
5 years ago
1.2.0
5 years ago
1.1.1
5 years ago
1.0.2
5 years ago
1.1.0
5 years ago
1.0.1
5 years ago
1.0.0
5 years ago
0.0.10
5 years ago
0.0.11
5 years ago
0.0.12
5 years ago
0.0.13
5 years ago
0.0.14
5 years ago
0.0.9
5 years ago
0.0.8
5 years ago
0.0.7
5 years ago
0.0.6
5 years ago
0.0.5
5 years ago
0.0.4
5 years ago
0.0.3
5 years ago
0.0.2
5 years ago
0.0.1
5 years ago