Nextjs Themes
Nextjs Themes 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 nextjs-themes/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, Vite, and Remix
Please consider starring this repository and sharing it with your friends.
Getting Started
Installation
$ pnpm add nextjs-themes
or
$ npm install nextjs-themes
or
$ yarn add nextjs-themes
Want Lite Version?
$ pnpm add nextjs-themes-lite
or
$ npm install nextjs-themes-lite
or
$ yarn add nextjs-themes-lite
You need r18gs
as a peer-dependency
Import Styles
You can import styles globally or within specific components.
@import "nextjs-themes/dist";
import "nextjs-themes/dist/index.css";
For selective imports:
@import "nextjs-themes/dist/client";
@import "nextjs-themes/dist/server/bars/bars1";
Usage
Using loaders is straightforward.
import { Bars1 } from "nextjs-themes/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.
<LoaderContainer />
...
import { useLoader } from "nextjs-themes/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.
Please consider enrolling in our courses or sponsoring our work.
with 💖 by Mayank Kumar Chaudhari