@nkavtaradze/use-undo-hook
TypeScript icon, indicating that this package has built-in type declarations

1.0.10 • Public • Published

Installation

Yarn

yarn add @nkavtaradze/use-undo-hook

NPM

npm install @nkavtaradze/use-undo-hook --save

Usage

import useUndo from'@nkavtaradze/use-undo-hook';
import { useState } from 'react';
function App() {

    const [count, setCount] = useState(0);
    const {
        element, 
        undo,
        redo,
        undos,
        redos,
        undoable,
        redoable,
    } = useUndo({
        value: count,
        setValue: setCount,
    })

    return (
        <div
            style={{
                textAlign: 'center',
            }}
        >
            <div>{count}</div>
            <div>
                <button
                    disabled={!undoable}
                    onClick={undo}
                >Undo</button>
                <button 
                    onClick={() => setCount(count + 1)
                }>Add</button>
                <button
                    disabled={!redoable}
                    onClick={redo}
                >Redo</button>
            </div>
        </div>
    );
}

export default App;

It will automatically bind ctr + z and ctr + y (cmd + z, cmd + shift + z for macos ) shorcuts to document element.

If you want to bind it on different DOM element you mast pass element variable to ref attribute like this:

import useUndo from'@nkavtaradze/use-undo-hook';
import { useState } from 'react';


function App() {

    const [count, setCount] = useState(0);
    const {
        element, 
        undo,
        redo,
        undos,
        redos,
        undoable,
        redoable,
    } = useUndo({
        value: count,
        setValue: setCount,
    })

    return (
        <div
            style={{
                textAlign: 'center',
            }}
        >
            <div ref={element} tabIndex="0">
                Bind listeners here
            </div>
            <div>{count}</div>
            <div>
                <button
                    disabled={!undoable}
                    onClick={undo}
                >Undo</button>
                <button 
                    onClick={() => setCount(count + 1)}
                >Add</button>
                <button
                    disabled={!redoable}
                    onClick={redo}
                >Redo</button>
            </div>
        </div>
    );
}

export default App;

Package Sidebar

Install

npm i @nkavtaradze/use-undo-hook

Weekly Downloads

1

Version

1.0.10

License

ISC

Unpacked Size

8.45 kB

Total Files

10

Last publish

Collaborators

  • nkavtaradze