Skip to content

Latest commit

 

History

History
129 lines (106 loc) · 3.47 KB

README.md

File metadata and controls

129 lines (106 loc) · 3.47 KB

react-simple-store

react-simple-store is a lightweight and easy-to-use implementation of global state management for React/React-Native applications, utilizing custom hooks. It offers a simple and efficient solution for sharing state across components while optimizing rendering processes.

Motivation

In exploring custom hooks in React, I encountered two common approaches:

  1. custom hooks using useState(). The limitation of this custom is that it is hard to share value/state across components.
  2. custom hooks using useContext().This custom hook can solve the limitation of useState() However too many contexts can lead to excessive rendering.

With react-simple-store, I aimed to create a custom hook-based state management solution that addresses these limitations, allowing for:

  1. Seamless sharing of values across components.
  2. Optimized rendering to prevent unnecessary re-renders using selector & direct access

How to Install

You can install React Simple Store via npm or yarn:

# Using npm
npm install @rzulfikri/react-simple-store

# Using yarn
yarn add @rzulfikri/react-simple-store

How to Use

Here's an example of how to use React Simple Store:

import React, { useCallback } from 'react';
import { createStore, useStore } from '@rzulfikri/react-simple-store';
import apiServices from './apiServices'; // Import your API services

// Create a custom store
const customStore = createStore((set, get) => {
  return {
    user: undefined,
    getData: async () => {
      const { data } = await apiServices.getUserDetail('RZulfikri');
      set({ user: data });
    }
  };
});

// Create a custom hook for using the store
const useCustomStore = (selector) => useStore(customStore, selector);

// Define custom selectors
const customSelectors = {
  user: store => store.user,
  userName: state => state?.user?.name
};

// Component A
const ComponentA = () => {
  const value = useCustomStore(customSelectors.userName);
  return (
    <div>
      <p>{value}</p>
    </div>
  );
};

// Component B
const ComponentB = () => {
  const value = useCustomStore(customSelectors.user);
  return (
    <div>
      <p>{value?.name}</p>
    </div>
  );
};

// Container Component
const Container = () => {
  return (
    <div>
      <ComponentA />
      <ComponentB />
    </div>
  );
};

// App Component
const App = () => {
  const onClick = useCallback(() => {
    // A direct access/manipulation to a store function
    customStore.get().getData();
  }, []);

  return (
    <div>
      <Container />
      <button onClick={onClick}>
        getData
      </button>
    </div>
  );
};

export default App;

Optimization

Direct Access

Direct Access provides access to the store using set and get, without React/Hook. You can get/set value and call functions from the store anywhere in your project.

const user = customStore.get().user;
const getUser = customStore.get().getData();
const setUser = customStore.set({ user: undefined });

Selectors

Selectors allow for selecting specific values, optimizing rendering:

const customSelectors = {
  user: store => store.user,
  userName: state => state?.user?.name
};

// This hook returns the user object
const value = useCustomStore();

// This hook returns the value of user.name
const value = useCustomStore(customSelectors.userName);

Contribution

Contributions are welcome! If you find any issues or have suggestions for improvements, please feel free to open an issue or submit a pull request.