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 🙏

© 2026 – Pkg Stats / Ryan Hefner

react-pageflip-rtl

v0.1.1

Published

React.js wrapper for StPageFlip with RTL (right-to-left) support – for creating realistic page turning effects in both LTR and RTL languages

Readme

npm npm GitHub license

react-pageflip-rtl

A fork of react-pageflip with native RTL (right-to-left) support.

This library adds first-class RTL page-flipping to the excellent react-pageflip / StPageFlip ecosystem. It is a drop-in replacement — all original props, events, and methods still work exactly the same. Just add rtl={true} and you're done.

RTL Mode (Arabic, Hebrew, etc.)

RTL Demo

LTR Mode (English, etc.)

LTR Demo


What's Different from the Original?

| Feature | react-pageflip | react-pageflip-rtl | | --- | --- | --- | | RTL page order | ❌ Not supported | ✅ rtl prop | | Page index remapping | ❌ | ✅ Events report correct RTL page numbers | | Interaction direction | Left → Right only | Configurable: Left → Right or Right → Left | | Drop-in compatible | — | ✅ Same API, same props |


How RTL Works

When you pass rtl={true}:

  1. Pages are reversed internally so the first page appears on the right (as expected in RTL languages like Arabic and Hebrew).
  2. Click/swipe directions are flipped — click the left side to go forward, the right side to go back.
  3. Event page indices are remappedonFlip, onInit, and onUpdate all report the correct logical page number from your original page array.
  4. startPage is adjusted — if you set startPage={0}, it correctly opens to the first logical page (rightmost in the book).

Installation

npm install react-pageflip-rtl

RTL Usage Example

import HTMLFlipBook from 'react-pageflip-rtl';

function MyArabicBook() {
    return (
        <HTMLFlipBook width={300} height={500} rtl={true} showCover={true}>
            <div className="page">الصفحة الأولى</div>
            <div className="page">الصفحة الثانية</div>
            <div className="page">الصفحة الثالثة</div>
            <div className="page">الصفحة الرابعة</div>
        </HTMLFlipBook>
    );
}

To use in LTR mode (default behavior, same as the original library):

<HTMLFlipBook width={300} height={500} rtl={false}>
    {/* pages */}
</HTMLFlipBook>

Running the Demo

The demo showcases both RTL and LTR modes with real PDF files. Toggle the checkbox to switch between an Arabic (RTL) PDF and an English (LTR) PDF.

# 1. Clone the repo
git clone https://github.com/NezarAli/react-pageflip-rtl.git
cd react-pageflip-rtl

# 2. Install dependencies
npm install

# 3. Start the demo dev server
npm run demo

# 4. Open http://localhost:5173 in your browser
  • RTL checked → loads rtl.pdf, pages flip right-to-left
  • RTL unchecked → loads ltr.pdf, pages flip left-to-right

Original Documentation

Everything below is from the original react-pageflip library. All props, events, and methods are fully supported in this fork.


GitHub license npm npm

Version 2.0.0

This version fixed some bugs and is completely written with react hooks. !!! Method access api changed !!!

React.js wrapper for StPageFlip

Simple React.js wrapper for StPageFlip library, for creating realistic and beautiful page turning effect

Features of StPageFlip

  • Works with simple images on canvas and complex HTML blocks
  • Has simple API and flexible configuration
  • Compatible with mobile devices
  • Supports landscape and portrait screen mode
  • Supports soft and hard page types (only in HTML mode)
  • No dependencies

Live Demo with source code: https://nodlik.github.io/react-pageflip/

Docs and examples to StPageFlip: https://nodlik.github.io/StPageFlip/

Docs (generated by TypeDoc): https://nodlik.github.io/StPageFlip/docs/index.html

Installation

You can install the latest version using npm:

npm install react-pageflip

Basic Usage

import HTMLFlipBook from 'react-pageflip';

function MyBook(props) {
    return (
        <HTMLFlipBook width={300} height={500}>
            <div className="demoPage">Page 1</div>
            <div className="demoPage">Page 2</div>
            <div className="demoPage">Page 3</div>
            <div className="demoPage">Page 4</div>
        </HTMLFlipBook>
    );
}

Advanced Usage

You can define pages as a component, but in this case you should use React.forwardRef method. Like this:

const Page = React.forwardRef((props, ref) => {
    return (
        <div className="demoPage" ref={ref}>
            /* ref required */
            <h1>Page Header</h1>
            <p>{props.children}</p>
            <p>Page number: {props.number}</p>
        </div>
    );
});

function MyBook(props) {
    return (
        <HTMLFlipBook width={300} height={500}>
            <Page number="1">Page text</Page>
            <Page number="2">Page text</Page>
            <Page number="3">Page text</Page>
            <Page number="4">Page text</Page>
        </HTMLFlipBook>
    );
}

Props

To set configuration use these props:

  • width: number - required
  • height: number - required
  • size: ("fixed", "stretch") - default: "fixed" Whether the book will be stretched under the parent element or not
  • minWidth, maxWidth, minHeight, maxHeight: number You must set threshold values ​​with size: "stretch"
  • drawShadow: bool - default: true Draw shadows or not when page flipping
  • flippingTime: number (milliseconds) - default: 1000 Flipping animation time
  • usePortrait: bool - default: true Enable switching to portrait mode
  • startZIndex: number - default: 0 Initial value to z-index
  • autoSize: bool - default: true If this value is true, the parent element will be equal to the size of the book
  • maxShadowOpacity: number [0..1] - default: 1 Shadow intensity (1: max intensity, 0: hidden shadows)
  • showCover: boolean - default: false If this value is true, the first and the last pages will be marked as hard and will be shown in single page mode
  • mobileScrollSupport: boolean - default: true disable content scrolling when touching a book on mobile devices
  • swipeDistance: number - default: 30 (px) minimum distance to detect swipe
  • clickEventForward: boolean - default: true forwarding click events to the page children html elements (only for a and button tags)
  • useMouseEvents: boolean - default: true using mouse and touch events to page flipping
  • renderOnlyPageLengthChange: boolean - default: false (NEW on 2.0.0) if this flag is active, the book will be updated and re-rendered ONLY if the number of pages has changed
  • rtl: boolean - default: false (NEW in react-pageflip-rtl) If this value is true, the book will be displayed in right-to-left mode. Pages are reversed internally, interaction directions are flipped, and event indices are remapped to report correct logical page numbers.

Events

You can use the following events:

...
function DemoBook() {
    const onFlip = useCallback((e) => {
        console.log('Current page: ' + e.data);
    }, []);

    return (
        <HTMLFlipBook
            /* props */
            onFlip={onFlip}
        >
        /* ... pages */
        </HTMLFlipBook>
    )
}

Available events:

  • onFlip: number - triggered by page turning
  • onChangeOrientation: ("portrait", "landscape") - triggered when page orientation changes
  • onChangeState: ("user_fold", "fold_corner", "flipping", "read") - triggered when the state of the book changes
  • onInit: ({page: number, mode: 'portrait', 'landscape'}) - triggered when the book is init and the start page is loaded. Listen (on) this event before using the "loadFrom..." methods
  • onUpdate: ({page: number, mode: 'portrait', 'landscape'}) - triggered when the book pages are updated (using the "updateFrom..." methods)

Event object has two fields: data: number | string and object: PageFlip

Methods

To use methods, you need to get a PageFlip object. This can be done using React ref and pageFlip(): PageFlip method For example - flipping to the next page:

  function DemoBook() {
        const book = useRef();

        return (
            <>
                <button onClick={() =>
                    book.current.pageFlip().flipNext()}>Next page</button>

                <HTMLFlipBook
                    ...
                    ref={book}
                    ...
                >
                    /* ... pages */
                </HTMLFlipBook>
            </>
        )
  }

Available methods:

| Method name | Parameters | Return type | Description | | --------------------- | -------------------------------------------- | ------------------------- | -------------------------------------------------------------- | | getPageCount | | number | Get number of all pages | | getCurrentPageIndex | | number | Get the current page number (starts at 0) | | getOrientation | | 'portrait', 'landscape' | Get the current orientation: portrait or landscape | | getBoundsRect | | PageRect | Get current book sizes and position | | turnToPage | pageNum: number | void | Turn to the specified page number (without animation) | | turnToNextPage | | void | Turn to the next page (without animation) | | turnToPrevPage | | void | Turn to the previous page (without animation) | | flipNext | corner: ['top', 'bottom'] | void | Turn to the next page (with animation) | | flipPrev | corner: ['top', 'bottom'] | void | Turn to the previous page (with animation) | | flip | pageNum: number, corner: ['top', 'bottom'] | void | Turn to the specified page (with animation) | | loadFromImages | images: ['path-to-image1.jpg', ...] | void | Load page from images | | loadFromHtml | items: NodeListOf, HTMLElement[] | void | Load page from html elements | | updateFromHtml | items: NodeListOf, HTMLElement[] | void | Update page from html elements | | updateFromImages | images: ['path-to-image1.jpg', ...] | void | Update page from images | | destroy | | void | Destructor. Removes Parent HTML Element and all event handlers |

Contacts

Oleg,

[email protected]

https://github.com/Nodlik/react-pageflip

Buy me a coffee