Package Exports
- react18-loaders-lite
- react18-loaders-lite/client
- react18-loaders-lite/client/loader-container
- react18-loaders-lite/css
- react18-loaders-lite/dist
- react18-loaders-lite/dist/client
- react18-loaders-lite/dist/client/loader-container
- react18-loaders-lite/dist/hooks
- react18-loaders-lite/dist/index.css
- react18-loaders-lite/dist/server
- react18-loaders-lite/dist/server/bars
- react18-loaders-lite/dist/server/common
- react18-loaders-lite/dist/server/dots
- react18-loaders-lite/hooks
- react18-loaders-lite/index.css
- react18-loaders-lite/server
- react18-loaders-lite/server/bars
- react18-loaders-lite/server/common
- react18-loaders-lite/server/dots
- react18-loaders-lite/styles
Readme
React18 Loaders 
React18 Loaders is a comprehensive library designed to unlock the full potential of React 18 server components. It provides customizable loading animation components and a fullscreen loader container, seamlessly integrating with React and Next.js.
✅ Fully Treeshakable (import from react18-loaders-lite/client/loader-container)
✅ Fully TypeScript Supported
✅ Leverages the power of React 18 Server components
✅ Compatible with all React 18 build systems/tools/frameworks
✅ Documented with Typedoc (Docs)
✅ Examples for Next.js, and Vite
Star this repository and share it with your friends.
Getting Started
Installation
pnpm add react18-loaders-liteor
npm install react18-loaders-liteor
yarn add react18-loaders-liteImport Styles
You can import styles globally or within specific components.
/* globals.css */
@import "react18-loaders-lite/dist";// layout.tsx
import "react18-loaders-lite/dist/index.css";For selective imports:
/* globals.css */
@import "react18-loaders-lite/dist/client"; /** required if you are using LoaderContainer */
@import "react18-loaders-lite/dist/server/bars/bars1";Usage
Using loaders is straightforward.
import { Bars1 } from "react18-loaders-lite/dist/server/bars/bars1";
export default function MyComponent() {
  return someCondition ? <Bars1 /> : <>Something else...</>;
}For detailed API and options, refer to the API documentation.
Using LoaderContainer
LoaderContainer is a fullscreen component. You can add this component directly in your layout and then use useLoader hook to toggle its visibility.
// layout.tsx
<LoaderContainer />
     ...// some other page or component
import { useLoader } from "react18-loaders-lite/dist/hooks";
export default MyComponent() {
    const { setLoading } = useLoader();
    useCallback(()=>{
        setLoading(true);
        ...do some work
        setLoading(false);
    }, [])
    ...
}License
This library is licensed under the MPL-2.0 open-source license.
This package also serves as an example demonstrating how to build and publish a
React.jslibrary compatible with React Server Components.
Please enroll in our courses or sponsor our work.
with 💖 by Mayank Kumar Chaudhari