npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

react-stickup

v1.12.1

Published

React components to stick elements at the top of the page while scrolling

Downloads

4,934

Readme

React Stickup

React components to stick elements at the top of the page while scrolling.

Build Status

Features

  • Sticky component like position: sticky with options for elements bigger than the viewport
  • StickyScrollUp component that is only visible when scrolling up (like the Chrome Browser url bar on Android)
  • Support for modern browsers (including IE11)
  • Build with performance in mind: Blazing fast, even on low end devices
  • Typescript

See the example to see how the library will work in production.

Installation

npm install --save react-stickup

Requirements

  • react version 16.3 or higher

Static Types

  • Support for Typescript is included within this library, no need to install additional packages
  • Flow is not supported (feel free to create a PR)

Client Support

This library aims to support the following clients

  • Chrome/ Chrome Android (latest)
  • Firefox (latest)
  • Edge (latest)
  • Safari/ Safari iOS (latest)
  • NodeJS (latest)
  • Internet Explorer 11 (with @babel/polyfill)

Please fill an issue in case your client is not supported or you see an issue in one of the above.

Usage

StickyProvider

This component is required as a parent for Sticky and StickyScrollUp component to work. It will take care of registration of event handlers and provides a communication channel between components. The main implementation is based on react-viewport-utils.

Sticky

Acts like position: sticky css property. By default the component will be sticky when the top offset is reached and will stay that way. In case it should only stick within a certain container it can get assigned as a reference.

Important: To work properly the Sticky component must have a StickyProvider as a parent within its tree.

Example

import * as React from 'react';
import { Sticky } from 'react-stickup';

const container = React.createRef();

render(
  <StickyProvider>
    <div ref={container}>
      <Sticky container={container}>
        <Header>My Header</Header>
      </Sticky>
      <div style={{ height: '5000px' }}>
        Lots of content
      </div>
    </div>
    <Sticky>
      <Header>My Header</Header>
    </Sticky>
  </StickyProvider>,
  document.querySelector('main')
);

Properties

children?: React.ReactNode | ((options: { isSticky: boolean, isDockedToBottom: boolean, isNearToViewport: boolean, appliedOverflowScroll: 'end' | 'flow' }) => React.ReactNode)

The child node that is rendered within the sticky container. When rendered as a function it will add further information the the function which can be used e.g. to update stylings.

container?: React.RefObject<any>

The reference to the container to stick into. If this is not set, the component will be sticky regardless how far the user scrolls down.

defaultOffsetTop?: number

A top offset to create a padding between the browser window and the sticky component when sticky.

overflowScroll?: 'end' | 'flow'

Defines how the sticky element should react in case its bigger than the viewport. Different options are available:

  • end: The default value will keep the component sticky as long as it reaches the bottom of its container and only then will scroll down.
  • flow: The element scrolls with the flow of the scroll direction, therefore the content is easier to access.

disabled?: boolean

Allows to disable all sticky behavior. Use this in case you need to temporary disable the sticky behavior but you don't want to unmount it for performance reasons.

disableHardwareAcceleration?: boolean

By default css styles for hardware acceleration (will-change if supported, otherwise falls back to transform) are activated. This allows to turn it off.

disableResizing?: boolean

The components will resize when the width of the window changes to adjust its height and width. This allows to turn the resizing off.

stickyProps?: {}

All properties within this object are spread directly into the sticky element within the component. This e.g. allows to add css styles by className or style.

style?: React.CSSProperties

Will be merged with generated styles of the placeholder element. It also allows to override generated styles.

className?: string

The class name is passed directly to the placeholder element.

StickyScrollUp

Only Sticky to the top of the page in case it the page is scrolled up. When scrolled down, the content will just scroll out. Sticky next to the StickyScrollUp will stick to the bottom of it and will therefore not overlap.

Important: To work properly the StickyScrollUp component must have a StickyProvider as a parent within its tree. All Sticky components must be wrapped by the same instance of the StickyProvideras the StickyScrollUp component to not overlap.

Example

import * as React from 'react';
import { Sticky, StickyScrollUp, StickyProvider } from 'react-stickup';

const container = React.createRef();

render(
  <StickyProvider>
    <StickyScrollUp>
      My Stick up container
    </StickyScrollUp>
    <div ref={container}>
      <Sticky container={container}>
        <Header>My Header</Header>
      </Sticky>
      <div style={{ height: '5000px' }}>
        Lots of content
      </div>
    </div>
  </StickyProvider>,
  document.querySelector('main')
);

Properties

children?: React.ReactNode | ((options: { isSticky: boolean, isNearToViewport: boolean }) => React.ReactNode)

The child node that is rendered within the sticky container. When rendered as a function it will add further information the the function which can be used e.g. to update stylings.

disabled?: boolean

Allows to disable all sticky behavior. Use this in case you need to temporary disable the sticky behavior but you don't want to unmount it for performance reasons.

disableHardwareAcceleration?: boolean

By default css styles for hardware acceleration (will-change if supported, otherwise falls back to transform) are activated. This allows to turn it off.

disableResizing?: boolean

The components will resize when the width of the window changes to adjust its height and width. This allows to turn the resizing off.

stickyProps?: {}

All properties within this object are spread directly into the sticky element within the component. This e.g. allows to add css styles by className or style.

style?: React.CSSProperties

Will be merged with generated styles of the placeholder element. It also allows to override generated styles.

className?: string

The class name is passed directly to the placeholder element.

defaultOffsetTop?: number

DEPRECATED: If not set, the start position is now calculated by default as it was already the case for the Sticky component. As there is no use case for this property anymore it will be removed in the future.

When not initialized as the first element within the page (directly at the top) this allows to set an offset by hand from where the component will be sticky.

Contributing

Contributions are highly appreciated! The easiest is to fill an issue in case there is one before providing a PR so we can discuss the issue and a possible solution up front.

At the moment there is not a test suite because its tricky to test the sticky behavior automated. I consider creating some e2e tests with Cypress in the future. In case you are interested in helping on that, please let me know!

For now, please make sure to add a test case for all features in the examples.

To start the example with the recent library changes just run npm start on the command.

License

Licensed under the MIT License.