Idea
The primary idea is to have everything set up for quick start with components, modules and other stuff which many templates can't offer.
Core
The core of this template is build around next dependencies:
Documentation
One of the main differences between this and any other template is that it offers a documentation to each of its component, helper, module, etc.
Structure
It offers more than just a simple template project it offers a guidance towards project, module, component creation.
From the component to publishing an app, it covers each aspect of development.
Performance
From the beginning it includes Hermes on both platforms, proguard is enabled, consoles are being removed and many other enhancements are used to provide the best performance.
Native-look-alike focus
By using React Native Navigation and providing SF Symbols usage on iOS and Material Icons on Android this template strives to make apps look as native ones as possible.
Native colors usage are also welcomed in this template and bring many useful helpers.
Components
Set of created common components like buttons, text inputs, radio buttons, date and image pickers, permissions, toasts and more.
Different helpers to help in your day-to-day cases.
Hooks which are found useful throughout the development process.
Localization
Localization is provided by react-native-localization helps to keep all the strings in one place and maintain correct usage when adding new languages.
Tests
Jest is used to test functions, methods and show test coverage of your project.
End-to-End coverage provided by Detox will make it easier to test each scenario on emulators or real devices.
Storybook can help to see what each component is capable of and show its properties and different edge cases. Or even contain whole screens.
So it brings best of both TDD (Test Driven Development) and CDD (Component Driven Development).
Code quality
ESLint with strict set of rules and plugins provided by eslint-config-strong.
Additionally there are Prettier and TSConfig rules which will make it hard to create messy code.
To prevent commits with errors Husky together with lint-staged won't allow them to pass.
Environments
React Native Config bring you the ability, for example, to have different environments which will make it easier to work with different API endpoints and test your application.
If you think that this template lacks something or would like to add something, feel free to do so by creating issues or participate in discussions.
There are still many things which I'd like to add, check the roadmap and issues to see where it's heading.
This and many more other things you can find in repository's documentation.
I hope you will find it useful and you will use it in your next project! 🎉🏆🎉
Top comments (0)