1. @idui/react-popover
React Popover Component
@idui/react-popover
Package: @idui/react-popover
Created by: id-ui
Last modified: Thu, 12 May 2022 04:55:41 GMT
Version: 3.1.0
License: MIT
Downloads: 3,934
Repository: https://github.com/id-ui/react-popover

Install

npm install @idui/react-popover
yarn add @idui/react-popover

Popover React Component

NPM
Size
JavaScript Style Guide
Coverage Status
LICENSE

Install

 npm install --save @idui/react-popover
 yarn add @idui/react-popover

Advantages

  • Fully and easily customizable. It has a bunch of props, including animation, className, arrow visibility, etc.
  • 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 change placement when content dimensions changed (if considerContentResizing = 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), otherwise changes position. Use scrollHandlerMinDistance prop to specify min scrolled distance to call scroll handler.
  • 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 isOpen specified).
  • 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 '@idui/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 '@idui/react-popover'
import styled from 'styled-components'

const CustomPopover = styled(Popover).attrs({
  arrowColor: 'black',
})`
  background-color: aquamarine;
  border-radius: 30px;
  border: 2px solid black;
  box-shadow: none;
  .idui-popover__arrow { // arrow
    box-shadow: none;
  }
`

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 '@idui/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 © [email protected]

Dependencies

RELATED POST

10 Must-Know Windows Shortcuts That Will Save You Time

10 Must-Know Windows Shortcuts That Will Save You Time

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Navigating AWS Networking: Essential Hacks for Smooth Operation

Navigating AWS Networking: Essential Hacks for Smooth Operation

Achieving Stunning Visuals with Unity's Global Illumination

Achieving Stunning Visuals with Unity's Global Illumination

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code