https://github.com/jollyjerr/react-autosave
A lightweight solution for auto saving controlled form values
https://github.com/jollyjerr/react-autosave
autosave forms react
Last synced: 10 months ago
JSON representation
A lightweight solution for auto saving controlled form values
- Host: GitHub
- URL: https://github.com/jollyjerr/react-autosave
- Owner: jollyjerr
- License: mit
- Created: 2020-11-05T00:37:52.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2025-03-09T04:33:55.000Z (over 1 year ago)
- Last Synced: 2025-08-09T14:18:29.404Z (11 months ago)
- Topics: autosave, forms, react
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/react-autosave
- Size: 49.9 MB
- Stars: 71
- Watchers: 2
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
# react-autosave
[](https://github.com/jollyjerr/react-autosave/actions/workflows/ci.yml)
[](https://codecov.io/gh/jollyjerr/react-autosave)


> Auto save controlled form values as they are updated.
react-autosave is a lightweight solution for auto saving controlled form values.
It handles many edge cases and guarantees a good user experience.
## Examples
```tsx
import React from 'react';
import axios from 'axios';
import { Autosave, useAutosave } from 'react-autosave';
const updateBlog = (data) => axios.post('myapi/blog/123', { text: data });
// Via hook
const EditBlogFormWithHook = () => {
const [blogText, setBlogText] = React.useState('hello world');
useAutosave({ data: blogText, onSave: updateBlog });
return (
setBlogText(e.target.value)}
/>
);
};
// Via component
const EditBlogForm = () => {
const [blogText, setBlogText] = React.useState('hello world');
return (
setBlogText(e.target.value)}
/>
);
};
```
## Installation
```sh
yarn add react-autosave
# or with npm...
npm i react-autosave
```
## Features
1. Written in typescript.
2. Lightweight and simple.
3. No dependencies.
## API
| Prop | Type | Description |
| ------------------------ | :------------------: | -----------------------------------------------------------------: |
| data | TData | The controlled form value to be auto saved |
| onSave | (data: TData) => any | The callback function to save your data |
| interval (optional) | number | The number of milliseconds between save attempts. Defaults to 2000 |
| saveOnUnmount (optional) | boolean | Defaults to true. Set to false to prevent saving on unmount |
### Contributing
Issues and PRs are more than welcome. Please clone the repo and setup your environment with:
```sh
pnpm
```
The test suite can be run with `pnpm test`
Buid the library with `pnpm build`
A demo page can be viewed with `pnpm build && pnpm dev`