npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

theme-class-provider

v1.0.1

Published

React library providing a ThemeProvider based on a list of class provided.

Downloads

3

Readme

theme-class-provider

A react library that simplifies theming in your applications. It offers a ThemeClassProvider component and a convenient hook (useThemeClass) to access and manage the theme throughout your app.

Brief Overview

Installation

You can install theme-class-provider using npm or yarn:

npm install theme-class-provider
# or
yarn add theme-class-provider

Usage

To integrate theme-class-provider into your React application, follow these steps:

1. Installation

First, install the theme-class-provider package via npm or yarn:

npm install theme-class-provider

or

yarn add theme-class-provider

2. Usage

Wrap your root component with the ThemeClassProvider component provided by the library. This component manages the theme context for your application:

import React from "react";
import ReactDOM from "react-dom";
import { ThemeClassProvider } from "theme-class-provider";
import App from "./App";

const themeClasses = ["red", "green", "blue"];

ReactDOM.render(
    <ThemeClassProvider themeClasses={themeClasses}>
        <App />
    </ThemeClassProvider>,
    document.getElementById("root")
);

In the above example, themeClasses is an array of class names representing different themes. You can customize this array based on your application's requirements.

3. Accessing Theme Context

To access the theme context within your components, utilize the useThemeClass hook provided by the library:

import React from "react";
import { useThemeClass } from "theme-class-provider";

const MyComponent = () => {
    const { getCurrentTheme, toggleTheme } = useThemeClass();

    const currentTheme = getCurrentTheme();

    return (
        <div className={currentTheme}>
            <button onClick={toggleTheme}>Toggle Theme</button>
            <p>Current Theme: {currentTheme}</p>
        </div>
    );
};

export default MyComponent;

4. Setting Up Light and Dark Themes

To define your light and dark theme styles, create corresponding CSS classes:

/* index.css */

.light {
    color-scheme: light;
    /* Light theme styles */
}

.dark {
    color-scheme: dark;
    /* Dark theme styles */
}

/* Additional body styles */

5. Wrapping Your App Component

Finally, wrap your App component with ThemeClassProvider:

import { ThemeClassProvider } from "theme-class-provider";

// Function to set the default theme based on user preferences
const setDefaultTheme = () => {
    return window.matchMedia("(prefers-color-scheme: dark)").matches
        ? "dark"
        : "light";
};

ReactDOM.render(
    <React.StrictMode>
        {/** configure the persistance behaviour as the application demands */}
        <ThemeClassProvider
            defaultTheme={setDefaultTheme()}
            themeClasses={["light", "dark"]}
            persist={{ clearOnUnload: true }}
        >
            <App />
        </ThemeClassProvider>
    </React.StrictMode>,
    document.getElementById("root")
);

Persistence Configuration and Theme Class Context Functions

Persistence Configuration

The ThemeClassProvider component allows you to configure persistence options for managing theme data. Here are the available configuration options:

  • key: The key used for storing theme data.
  • disabled: Indicates whether persistence is disabled.
  • clearOnUnload: Clear the persisted data when the component unmounts.

By default, the library uses localstorage to persist the data.

Theme Class Context Functions

The useThemeClass hook provides access to various functions for managing the theme class context. Here's an overview of these functions:

  • toggleTheme(): void: Toggles the theme class.
  • setCurrentTheme(theme_class: string): void: Sets the current theme class.
  • getCurrentTheme(): string: Retrieves the name of the current theme class.
  • setThemeClasses(classes: string[]): void: Sets the theme classes to the provided array.
  • getThemeClasses(): string[]: Retrieves the list of theme classes.
  • clearPersistedThemeData(): void: Clears the persisted theme data.
  • setDefault(theme_class: string): void: Sets the default theme class.

Release

For detailed release notes, please see CHANGELOG.md.

Contributing

Contributions are welcome! If you have any ideas, suggestions, or bug fixes, please open an issue or submit a pull request on GitHub.

License

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