- Clone the repository
git clone https://github.com/FlemingVincent/Circles.git
- Navigate to the project directory
cd Circles
- Install dependencies
yarn install
- Start the development server
yarn start
This project has been configured with the following tools:
ESLint
ESLint is a linting tool for JavaScript that enforces coding best practices.
Prettier
Prettier is a code formatter that enforces a consistent code style. Within this project it has been configured to run with ESLint.
TypeScript
TypeScript is a superset of JavaScript that adds static typing to the language. It is used to improve code quality and developer productivity.
Absolute Imports
Absolute imports allow you to import modules using the project root as the base path. This makes it easier to import modules without having to worry about relative paths.
tsconfig.json
{
"extends": "expo/tsconfig.base",
"compilerOptions": {
"strict": true,
"baseUrl": ".",
"paths": {
"@/*": ["src/*"]
}
}
}
app.json
{
"expo": {
"experiments": {
"tsconfigPaths": true
}
}
}
Most of the code lives in the src
directory. The src
directory contains the following subdirectories:
src
|
+-- assets # assets folder can contain all the static files such as images, fonts, etc.
|
+-- components # shared components used across the entire application
|
+-- config # all the global configuration, env variables etc. get exported from here and used in the app
|
+-- lib # re-exporting different libraries preconfigured for the application
|
+-- providers # all of the application providers
|
+-- routes # routes configuration
|
+-- screens # application screens
|
+-- stores # global state stores
|
+-- types # base types used across the application
TailwindCSS
TailwindCSS is a utility-first CSS framework that allows you to build custom designs without having to write custom CSS. With the help of tailwind-react-native-classnames you can utilize the same beloved Tailwind CSS utility classes you are familiar with from web development, seamlessly in your React Native applications.
Component State (useState)
This is the state the only a component needs, and it is not meant to be shared anywhere else. But you can pass it as prop to children components if needed. Most of the time, you want to start from here and lift the state up if needed elsewhere. For this type of state, you will usually need:
Zustand
Zustand is a small, fast and scalable state management library that provides a minimal API to build scalable React applications. It is used to manage global state in the application.
React Hook Form
React Hook Form is a library that allows you to easily create forms in React. It is used to create performant, flexible, and extensible forms with easy-to-use validation.
Zod
Zod is a TypeScript-first schema declaration and validation library. It is used in conjunction with React Hook Form to validate form data.
GitHub Actions
GitHub Actions is a CI/CD tool that allows you to automate your software development workflows. This project has been configured to automatically build and deploy the application to Expo whenever a new commit is pushed to the main
or development
branch.
EAS
Expo Application Services (EAS) is a set of tools that allow you to build, deploy, and manage your Expo applications. This project has been configured to automatically build and deploy the application to Expo whenever a new commit is pushed to the main
or development
branch.
Assuming you've already completed the setup, to start contributing please follow these steps:
-
Create a new branch: Before making any changes, create a new branch with a descriptive name. Follow this convention to choose an appropriate prefix for your branch name:
hotfix
: For quickly fixing critical issues, usually with a temporary solution.bugfix
: For fixing a bug.feature
: For adding, removing, or modifying a feature.test
: For experimenting with something which is not an issue.wip
: For a work in progress.
Example:
feature/update-readme
-
Make Changes: Implement the desired changes in your branch.
-
Test Changes: Before proceeding, ensure that your changes work as expected.
-
Push Branch and Open a Pull Request: Once you're confident in your changes, push your branch to the repository and open a pull request from your branch into the development branch.
-
Merge Pull Request: After review and approval, your pull request will be merged into the development branch.
Note: Please ensure that you base your branch off the development branch, not the main branch.