react-fluxible
v6.0.8
Published
Connector for react-js and fluxible-js.
Downloads
1,442
Maintainers
Readme
react-fluxible
Connector for react-js and fluxible-js which allows you to access the store inside your components and rerender your component when the store changes.
Change logs
From v6, the changelogs on the project will be kept in CHANGELOG, which follows keepachangelog.
Demo
https://user-images.githubusercontent.com/21032419/139817756-c5bf348e-7941-4000-9205-a165ee3ddccc.mp4
Install
yarn add react-fluxible fluxible-js
Rendering performance impact
react-fluxible does NOT rely on a wrapper on top of your app.
Unlike react-redux
, react-fluxible
does NOT rely on a global provider on top of your app. This makes it more performant and independent. You simply have to choose between hooks or HOCs.
react-fluxible does selective update
Due to the architecture of fluxible-js, when you update the store, react-fluxible
does NOT rerender all components connected to the store. It only rerenders components that are using the store key that was updated.
This means that if you have 100 components connected to the global store, and you updated a store key called authUser
, and you only have 5 components connected to the store that are using authUser
, then only those 5 components will be rerendered and given the updated values.
react-fluxible does not do anything about the store
It does not set, reset or update the store, it only does the following:
- Connect to the store.
- Wait for updates on the store keys that you are using, i.e.,
authUser
. - Rerender your component with the new values when that/those store key/s was/were updated.
- Disconnect to the store when your component unmounts, this is necessary for cleanup.
Usage
Initialize store
Refer to fluxible-js docs for more information on initialization.
Create a reusable hook for your store
You need to tell react-fluxible
to what store to connect to via createFluxibleHook
, and then it returns a hook that can connect to that store.
globalStore.ts
import { createStore } from 'fluxible-js';
import { createFluxibleHook } from 'react-fluxible';
const initialStore = {
token: null,
isLoggedIn: false
};
const globalStore = createStore({
initialStore
});
const useGlobalStore = createFluxibleHook(globalStore);
// to connect a component to the store
function MyComponent () {
const { token, isLoggedIn } = useGlobalStore((store) => {
return {
token: store.token,
isLoggedIn: store.isLoggedIn
};
})
// do something with the `token` and `isLoggedIn`
return <p>Hello world</p>;
}
createFluxibleHook
accepts a store instance as argument and returns a react hook that you can use in your components, the react hook accepts a function that function should return an object that is the store states that you want to watch in that component. In the example above, the component will watch token
and isLoggedIn
, every time the token
or isLoggedIn
changes, this component will be rerendered with the new values of the token
and isLoggedIn
.
Example with state persistence using react-native-async-storage
import { createStore, AsyncStorage as TAsyncStorage } from 'fluxible-js';
import { createFluxibleHook } from 'react-fluxible';
import AsyncStorage from '@react-native-async-storage/async-storage';
const initialStore = {
token: null,
isLoggedIn: false,
initComplete: false
};
const globalStore = createStore(
{
initialStore,
persist: {
stringify: true,
asyncStorage: AsyncStorage as TAsyncStorage<typeof initialStore>,
restore: (savedStore) => {
return {
token: savedStore.token
};
}
}
},
() => {
globalStore.updateStore({ initComplete: true });
}
);
const useGlobalStore = createFluxibleHook(globalStore);
// to connect a component to the store
function MyComponent () {
const { token, isLoggedIn, initComplete } = useGlobalStore((store) => {
return {
token: store.token,
isLoggedIn: store.isLoggedIn,
initComplete: store.initComplete
};
})
// do something with the `token` and `isLoggedIn`
if (!initComplete) return <p>Initializing store...</p>
return <p>Hello world</p>;
}
Example with state persistence using window.localStorage
import { createStore, SyncStorage } from 'fluxible-js';
import { createFluxibleHook } from 'react-fluxible';
const initialStore = {
token: null,
isLoggedIn: false
};
const globalStore = createStore({
initialStore,
persist: {
stringify: true,
asyncStorage: window.localStorage as SyncStorage,
restore: (savedStore) => {
return {
token: savedStore.token
};
}
}
});
const useGlobalStore = createFluxibleHook(globalStore);
// to connect a component to the store
function MyComponent () {
const { token, isLoggedIn } = useGlobalStore((store) => {
return {
token: store.token,
isLoggedIn: store.isLoggedIn
};
})
// do something with the `token` and `isLoggedIn`
return <p>Hello world</p>;
}
Migrating from v5 to v6
Create a new file called globalStore.ts
import { createStore } from 'fluxible-js';
import { createFluxibleHook } from 'react-fluxible';
const initialStore = {
// your store here
};
export const globalStore = createStore({
initialStore
});
export const useGlobalStore = createFluxibleHook(globalStore);
Instead of importing updateStore
and the likes directly from fluxible-js
, you will need to import { globalStore } from 'globalStore';
and use the methods from globalStore
.
Instead of importing useFluxibleStore
directly from react-fluxible
, you will need to import { useGlobalStore } from 'globalStore';
.