Cache buster library (<1kb) for React that helps in busting cache by checking changes for a unique release ID and calling window.location.reload when a change is detected in release ID.
You can install @piplup/cache-buster using:
npm install @piplup/cache-buster
// or
yarn add @piplup/cache-buster
// or
pnpm add @piplup/cache-buster
-
Integration with your build process:
Include a script in your package.json to generate a release ID before building your application:
{
"scripts": {
"build": "piplup-cache-buster --publicDir=public && react-scripts build"
}
}
Alternatively, if you are using vite
to build your react application. You can use @piplup/vite-plugin-cache-buster
and update your vite configuration file (usually vite.config.js
or vite.config.ts
) to the following:
import { vitePluginCacheBuster } from '@piplup/vite-plugin-cache-buster';
export default {
// Other Vite config options...
plugins: [vitePluginCacheBuster() /*...other plugins */],
};
- Integrate CacheBuster into your application:
import { CacheBuster } from '@piplup/cache-buster';
function App() {
return (
<>
<CacheBuster
loading={null} // Optional: Add a loading component to display loading.
verbose={false} // Optional: If true, logs will be visible.
storageKey="RELEASE" // Optional: local storage key for storing the unique release ID.
enabled={process.env.NODE_ENV === 'production'}
/>
<YourApp />
</>
);
}
export default App;
enabled
(optional): Boolean indicating whether the cache busting functionality should be enabled. Default istrue
.loading
(optional): React node to be displayed while checking for updates. Default isnull
.verbose
(optional): Boolean indicating whether verbose logging should be enabled. Default isfalse
.storageKey
(optional): local storage key for storing the unique release ID. Default isRELEASE
children
(optional): The child components to render within the cache buster.
CacheBuster
fetches a release ID from the public folder using a predefined file name. It then compares this ID with the one stored in the browser's local storage. If a new release is detected, it reloads the page. Otherwise, it proceeds to render the child components.
Contributions are welcome! Feel free to submit issues or pull requests.
This project is licensed under the MIT License - see the LICENSE file for details.