Skip to content

Latest commit

 

History

History
88 lines (60 loc) · 2.68 KB

README.md

File metadata and controls

88 lines (60 loc) · 2.68 KB

@piplup/cache-buster

npm

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.

Installation

You can install @piplup/cache-buster using:

npm install @piplup/cache-buster

// or

yarn add @piplup/cache-buster

// or

pnpm add @piplup/cache-buster

Usage

  1. 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 */],
};
  1. 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;

Props

  • enabled (optional): Boolean indicating whether the cache busting functionality should be enabled. Default is true.
  • loading (optional): React node to be displayed while checking for updates. Default is null.
  • verbose (optional): Boolean indicating whether verbose logging should be enabled. Default is false.
  • storageKey (optional): local storage key for storing the unique release ID. Default is RELEASE
  • children (optional): The child components to render within the cache buster.

How It Works

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.

Contributing

Contributions are welcome! Feel free to submit issues or pull requests.

License

This project is licensed under the MIT License - see the LICENSE file for details.