Best Practices for Structuring a Large ReScript Codebase?

Hello everyone,

I’m currently working on a fairly large-scale project using ReScript, and I’m looking for advice on best practices for structuring a growing codebase. As the project expands, I want to ensure maintainability, readability, and performance while keeping the developer experience smooth.

Here are a few specific areas where I’d love input:

  1. Module Organization – How do you typically structure modules and folders in a large ReScript project? Do you follow a feature-based approach, a domain-driven structure, or something else?
  2. Code Splitting & Reusability – What are your strategies for breaking down large files and making components reusable across different parts of the app?
  3. Interop with JavaScript – If your project integrates with existing JavaScript codebases, how do you manage the boundaries between ReScript and JS efficiently?
  4. State Management – For complex applications, what’s the preferred state management approach in ReScript? Are people mostly using React with ReScript or other patterns like reducers or global state libraries?
  5. Testing – What tools and methodologies do you find most effective for testing ReScript code, especially when dealing with side effects?

Any insights, examples, or open-source repositories that showcase well-structured ReScript projects would be greatly appreciated. Thanks in advance!

I also checked this: https://discuss.royaleapi.com/t/how-to-optimize-decks-for-mid-ladder-progression/msbi

Looking forward to your thoughts.