Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use in a monorepo with hooks packages wrapping the store #28

Open
tyom opened this issue Aug 27, 2024 · 5 comments
Open

Use in a monorepo with hooks packages wrapping the store #28

tyom opened this issue Aug 27, 2024 · 5 comments

Comments

@tyom
Copy link

tyom commented Aug 27, 2024

I have encountered an issue in a monorepo setup. I created a package with nanostore that has some logic including subscriptions to the atoms. I created another package which wraps the store into custom React hooks that I would like to export as an API to access the store data. However, the consumer app loses the atom subscriptions when used via custom hooks. But it works when the custom hook is created in the consumer app.

Please see this minimal reproducible example repo.

  • Clone, run pnpm install and pnpm start;
  • Go to the app in the browser and open the console;
  • Observe how the two hooks affect the subscription.

The first button increments the count within React component but does nothing for the subscription outside. The second button updates the count in both React component and the subscription outside of React (browser console).

I assumed that the issue lies somewhere around the multiple version of the store being used but no matter what I tried with peer dependencies doesn't help.

@nanostores nanostores deleted a comment Aug 27, 2024
@nanostores nanostores deleted a comment Aug 27, 2024
@ai
Copy link
Member

ai commented Aug 27, 2024

Hi. I will try to look during the week.

@ai
Copy link
Member

ai commented Aug 27, 2024

Yes, seems like it is not a Nano Store issue but pnpm (in a way).

Since we have a multiple packages with the store, we will have 2 different stores. It is hard to image what we can do with that on Nano Stores side.

I suggest export createStore from store’s package and create all stores inside the app.

@tyom
Copy link
Author

tyom commented Aug 28, 2024

Thanks for looking into this, Andrey.

To avoid changing the store package, as it could be used directly for non-React app I think the hooks package could instead export an initialisation function that would accept the store as argument and enclose it for hooks.

What do you think of this approach?

@tyom
Copy link
Author

tyom commented Aug 28, 2024

I ended up exporting a binding function from the React hooks package that would then be bound with the store in the app.

import { store } from '@monorepo/my-store';
import { bindStore } from '@monorepo/my-react-hooks';

export const { useCounter } = bindStore(store);

@marcomuser
Copy link

I think it should be possible as well to scope the atom to the react app via a react context. See (note: the article describes this pattern for zustand but it should work the same way for nanostores): https://tkdodo.eu/blog/zustand-and-react-context

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants