react-redux-typescript-guide
                                
                                 react-redux-typescript-guide copied to clipboard
                                
                                    react-redux-typescript-guide copied to clipboard
                            
                            
                            
                        Add a section about Types global namespace
We would need a new section explaining how I designed cross-cutting Types global project namespace to be easily reused across the project as a module encapsulating all the types in the application.
I leveraged the inversion of control principle, so instead of defining all the types in one place (in Types module, it's the responsibility of modules (which are owners of that particular type annotations) to extend the Types namespace.
The main benefits are:
- simplicity to extend
- easy maintenance - for instance when you remove some application module you also delete the extension point because it's colocated with the module
- nicely and cleanly imported in type consumers
import Types from 'Types';
// reducer(state: Types.RootState , action: Types.RootAction) => ...
// mapDispatchToProps(dispatch: Dispatch<Types.RootAction>)
// Epic<Types.RootAction, Types.RootState, Types.Services>
@issuehuntfest has funded $20.00 to this issue. See it on IssueHunt
@issuehunt has funded $20.00 to this issue.
- Submit pull request via IssueHunt to receive this reward.
- Want to contribute? Chip in to this issue via IssueHunt.
- Checkout the IssueHunt Issue Explorer to see more funded issues.
- Need help from developers? Add your repository on IssueHunt to raise funds.