MOPCON App for Android build by react-native 0.59.8
this project develop with react-native, so before getting start, we should install below command and tool.
- nodejs recommend v10 LTS version
- jdk8
- android-studio recommend v3.4.1
before getting start, please set env variable to develop machine
export MOPCON_API_URL="https://mopconXXXXXXXX.com/"
export keystore_password="xxx"
export keystore_alias="xxx"
export keystore_alias_password="xxx"
export MOPCON_DES_KEY="xxx"
the security files was encrypted into secrets.tar.enc
use follow command to decrypt it.
sh appcenter-post-clone.sh
If you need to add files into secrets.tar.enc
, you can follow below command
# compress multiple files into single tar file.
tar -czvf secrets.tar aaa.json bbb.json
# use environment key to encrypt tar file.
openssl des-cbc -e -k $MOPCON_DES_KEY -in secrets.tar -out secrets.tar.enc
after extract necessary files. use follow command to install dependencies.
npm i && react-native link
after setting all tool and commands, now we can start develop. To run the code on android simulator, we should create android AVD and open it. After open AVD we can use follow command to install app to simulator.
npm run android
Generate release mode APK for React-Native project to publish on PlayStore
npm run build:prd
.
├── android # android folder
├── appcenter-post-clone.sh # App-Center CI/CD config
├── .travis.yml # travis CI/CD config
├── app.json
├── assets
│ └── fonts # necessary fonts
├── BoothMission.json # mission game json, it should be extracted from secrets.tar.enc
├── index.js # react native enter point
├── ios # ios folder
├── package.json
├── package-lock.json
├── Quiz.json # mission game json, it should be extracted from secrets.tar.enc
├── README.md
├── secrets.tar.enc # encryped secrets files
└── src
├── api # all api services defined in here.
├── components # common react components
├── containers # main app pages
├── images
├── locales # i18n json
├── store # react context
├── theme # theme constant
└── utils
the coding style in below link, all the developer should follow it.
https://github.com/letmeknowhow/react-native-coding-style
We use the simplified git-flow to improve team development speed. Unlike the standard git-flow, we don't have a release branch.
When a feature branch is finished, you must submit a Pull Request to develop branch.
Don't forget assign your partner to review it.
The App Version use Semantic Versioning concept.
The Semantic Versioning concept is simple: all versions have 3 digits: x.y.z.
- the first digit is the major version
- the second digit is the minor version
- the third digit is the patch version
When you make a new release, you don’t just up a number as you please, but you have rules:
- up the major version when you make incompatible API changes
- up the minor version when you add functionality in a backward-compatible manner
- up the patch version when you make backward-compatible bug fixes
npm version [major|minor|patch] --no-git-tag-version