BigNeon React Native Repo
This is the react native Big Neon Mobile App repository, part of the Big Neon ticketing system.
Big Neon is a multi-tiered micro-services architecture for selling and managing tickets. The software system is made up of multiple components. As such, the code is split across multiple repositories. To get an overall picture of how everything fits together have a look at the docs repository
- If you don't use the
asdf
version manager, set it up: https://github.com/asdf-vm/asdf - Run
./bin/setup
from the project directory. - Run
./bin/start
to start the app on your dev machine.
This will be a React Native app for iOS and Android.
To use the RN Standalone Debugger with an iPhone simulator, first install it with:
brew update && brew cask install react-native-debugger
Then, make sure You disable Remote Debugging on any running simulators. (Cmd+D -> Disable Remote JS Debugging
)
Then run npm run debug
After the standalone debugger loads up, you can then re-enable Remote JS Debugging, which should then open in the standalone app, and not in a browser window.
React Native (https://facebook.github.io/react-native/)
Unstated (https://github.com/jamiebuilds/unstated)
React Navigation (https://reactnavigation.org/)
For deployment details, look in bin/deploy
. This script is used to deploy builds to the appropriate stores.
There are staging and production deploy scripts, based on using Expo's release channels. These will build the apps with the appropriate staging or production config settings.
You will need Apple and Google developer accounts.
We're using Expo Build releasing through Fastlane as a guideline if you want to try to set up your own deploy.
The expo
CLI should be installed if you've run npm install
. Login to expo using the BigNeon credentials:
$ npm run expo -- login
username/email: bigneon
password: <message brad or zach>
In your .bash_profile
(or whichever file hosts your bash/zsh/etc config),
2
export LC_ALL=en_US.UTF-8
export LANG=en_US.UTF-8
export DELIVER_USERNAME=apple developer username
export DELIVER_PASSWORD=apple developer password
export FASTLANE_ITC_TEAM_ID=119447135
export SECRET_SENTRY_AUTH_TOKEN=sentry auth token
The Team ID is the Big Neon Team ID in the App Store. To deploy, you will need to be added to the organization.
Based on the steps here, first you need to set up some keystores:
Android:
$> expo build:android
In the following text, select 2) I want to upload my own keystore!
Would you like to upload a keystore or have us generate one for you?
If you don't know what this means, let us handle it! :)
1) Let Expo handle the process!
2) I want to upload my own keystore!
You can get the keystore file from Brad ([email protected]), as well as the keystpre password
, key alias
, and key password
, which will all be needed.
iOS:
$> expo build:ios
In the following text, select I will provide all the credentials and files needed, Expo does no validation
[exp] Making sure project is set up correctly...
[exp] Your project looks good!
[exp] Checking if current build exists...
[exp] No currently active or previous builds for this project.
? How would you like to upload your credentials?
(Use arrow keys)
❯ Expo handles all credentials, you can still provide overrides
I will provide all the credentials and files needed, Expo does no validation
You can get the relevant mobile provision and p12 files listed below from brad ([email protected]), as well as the Distribution p12 password
and Push p12 password
big-neon-mobile.mobileprovision
big-neon-mobile_dist.p12
big-neon-mobile_dist_cert_private.key
big-neon-mobile_push.p12
big-neon-mobile_push_cert_private.key
To install Fastlane, make sure you have ruby and bundler installed first. Then install the fastlane gem.
$> bundle update
You will also need a google-deploy-key.json
file to upload to Google. Contact Brad at Revelry or Keith at Big Neon for this file, and save it in the .creds directory. Never commit it to github.
First, make sure you bump the version
and android:versionCode
numbers in app.json
.
version
should follow semantic versioning:major.minor.patch
. If the updates are minor, just bump the patch number by one. Moderate changes bump the minor number by 1. And large changes bump the major number by 1.versionNumber
must always be an integer, and can just be incremented by one.
$> ./deploy_staging
This will build the app with the staging variables, and deploy to the Google Play store's alpha track, and to Apple's App Store Connect.
In the Apple App Store Connect, you may need to manually go to the build listing and fix the Missing Compliance issue.
Also, make sure there is always a user: [email protected], pass: test
account so Apple can log in to the app to test it.