Simple MobX React Lite with Context
# yarn
yarn add mobx mobx-react-lite mobx-react-lite-context
# npm
npm install mobx mobx-react-lite mobx-react-lite-context --save
More example via codesandbox.io
// index.tsx
import React from 'react'
import ReactDOM from 'react-dom'
import Page from './page'
import Store from './store'
const App = () => {
return (
<Store.Provider>
<Page />
</Store.Provider>
);
};
ReactDOM.render(<App />, document.getElementById("root"));
// page.tsx
import React from 'react'
import Store, { IStore } from './store'
export default () => {
const { counter }: IStore = useStore<IStore>()
return (
<Store.Consumer>
<button onClick={() => counter.add()}>Increment {counter.value}</button>
</Store.Consumer>
)
}
// store.ts
import { createContext } from "mobx-react-lite-context";
import Counter, { IStore as ICounterStore } from "./counter";
export interface IStore {
counter: ICounterStore;
}
export default createContext<IStore>({
counter: new Counter()
});
// counter.ts
import { observable, action } from 'mobx'
interface IStore {
value: number;
add(): void;
}
export default class Store implements IStore {
@observable value = 0;
@action add() {
this.value++;
}
}
Send me ETH to this address 0xab1c4e446900ad20bf5fae1be67f87d54dacd2f0
👤 Ribhararnus Pracutian <oknoorap@gmail.com>
Contributions, issues and feature requests are welcome!
Feel free to check issues page.
Give a ⭐️ if this project helped you!
MIT © oknoorap