- Case Study
- Prerequisites
- Getting Started
- Folder Structure
- Generate Production Version
- Styleguide
- Contributing
During the COVID-19 pandemic, the Canadian government introduced the ArriveCan mobile and web application, usage of which was mandatory in order to digitally collect information about inbound travellers, their vaccination status, and post-arrival accommodation plans. More recently, the application has been used by the government to allow inbound travellers to complete their Advance CBSA Declaration. While its first purpose was related to public health, its secondary purpose is aimed at reducing passenger wait times at Canadian airports.
Upon learning the reported project cost of building and maintaining the ArriveCan app, TribalScale’s team wanted to demonstrate how iterative work and fluid communication can help produce quick results when it comes to building digital products. Our team also wanted to demonstrate the technical passion and prowess of the Canadian engineering community.
With this in mind, our tribe worked together to quickly rebuild the front end version of the ArriveCan mobile app as a learning & team building experience. We refer to our version as ArriveTS.
TribalScale wrapped up its hackathon on Oct. 10, 2022. After two days of work, the team was able to recreate the ArriveCan app and we are now releasing the Git Repo to the public. TribalScale was able to deliver the following features:
- Sign-up flow
- Created ability to add travel documents
- Created ability to add additional traveler profiles to accounts
- Ability to save travelers' details for future trips
- Ability to complete declaration forms (approximately a dozen questions)
- Ability to input trip information; integration with API for list of Canadian International airports
- Created placeholder to scan Passport or PR Card to add traveler details
- List of linked traveler resources
What’s available today:
- Here's a quick video preview of what has been built so far
- Open source code required to build the ArriveTS app
$54 million dollars on an app makes for a flashy headline. But at the end of the day, when it comes to building products, it’s important to focus on the challenges and solutions, rather than finger pointing and laying blame.
TribalScale has spent the last 6 years working with enterprise organizations to help them build digital products, including software for banking, insurance, healthcare, and automotive industries in both Canada and the USA. So we understand that there’s always more than meets the eye when it comes to building digital products, particularly when you’re connecting it with legacy technology systems and working with a wide variety of stakeholders.
Building software is hard. Building software in a legacy organization is even harder. That challenge is exactly what motivates the team at TribalScale, through our mission to Right the Future. With access to the right information and Agile processes, public service teams across Canada can find capital efficiency and productivity, while also building products that better serve the needs of the Canadian public.
Rebuilding one piece of the ArriveCan app is not something our team did to mock the government. Rather, it was a passion project by our team, whose curiosity drove them to ask “Well, what would it actually take to get this done? And where are the faults in current digitization efforts?”
This week TribalScale has announced the formation of The Canadian Technology Consortium. We’re inviting tech leaders from across the country to contribute their expertise, with the stated goal of providing a free resource to our colleagues in the public sector. Building software is challenging, but we believe that experts in this country can come together to make it just a bit simpler for the hardworking people whose day to day work involves making life easier for Canadians.
Anyone interested in learning more is encouraged to RSVP to our first meeting, on Friday, Oct 14th at 7:45am EST. It’s been an interesting week and, with the responses we’ve been hearing, we continue to be excited and optimistic about the future.
- Node.js > 14 and npm (Recommended: Use nvm)
- Watchman
- Xcode 12
- Cocoapods 1.11.3
- JDK > 11
- Android Studio and Android SDK
- aws-amplify for authentication.
- react-navigation navigation library.
- react-native-async-storage for local storage.
- react-hook-form for form handling.
- react-native-paper for pre-built components.
- prop-types to type-check our components exposed properties.
This project uses AWS Amplify with Cognito User Pool to connect app authentication. In order to setup authentication on this app, you must have an AWS Cognito User Pool set up. You will need your AWS account access key id and secret access key to get Amplify setup. You will also need the Amplify CLI setup on your system. Follow instructions here.
Once you have the CLI setup, in the projects root directory run:
amplify init
Once you have setup programmatic access to your AWS account, import the user pool by running the following command:
amplify import auth
Follow the step by step instructions on the CLI to import your AWS Cognito User Pool.
Please refer to the Amplify Documentation for more information on how to configure Amplify to the project.
Run
yarn install
After installing all yarn dependencies, move to your ios folder and run:
pod install
or
From the project root folder, run:
npx pod-install
Run:
yarn ios
Run:
yarn android
This template follows a very simple project structure:
src
: This folder is the main container of all the code inside your application.index.js
: Main component that starts your whole app.assets
: Asset folder to store all images, vectors, etc.components
: Folder to store any common component that you use through your app (such as a generic button)context
: Folder to put all contexts for the application.routes
: Folder to store the navigatorsAuthenticatedStack
: Folder to store all authenticated routesUnauthenticatedStack
: Folder to store all unauthenticated routes
screens
: Folder that contains all your application screens/features.Screen
: Each screen should be stored inside its folder and inside it a file for its code.index.js
utils
: This folder contains all utilities that you may need, such as colors and constants
These are the steps to generate .apk
, .aab
and .ipa
files
- Generate an upload key
- Setting up gradle variables
- Go to the android folder
- Execute
./gradlew assemble[Env][BuildType]
Note: You have three options to execute the project
assemble:
Generates an apk that you can share with others.
install:
When you want to test a release build on a connected device.
bundle:
When you are uploading the app to the Play Store.
For more info please go to https://reactnative.dev/docs/signed-apk-android
- Go to the Xcode
- Select the schema
- Select 'Any iOS device' as target
- Product -> Archive
For more info please go to https://reactnative.dev/docs/publishing-to-app-store
For coding styling, we decided to go with ESLint and React Native community's styleguide.
Want to contribute to this project? Follow these small steps to shoot your first PR!
- Fork our repo
- Create a new branch with the feature you are going to add or any bug you want to solve
- Start working on your new branch
- Send us a pull request!
Here is a more detailed step by step guide from DataSchool for contributing to open source projects