SupplyAlly helps ensure that everyone can get their fair share of items. By scanning a person's ID, you'll be able to track whether his allocated quota has been used up.
-
Setup Sentry. Copy
.env.example
to.env
and populate with your values. You can skip this step if you don't want to use Sentry to track app errors. -
Install
expo-cli
globally -
Login to Expo using
expo login
. Ask someone for the credentials. -
Install Expo on your mobile device and/or simulator and login with the same account. When using a mobile device for testing, it needs to be on the same network.
-
Setup Auth for our private package @rationally-app-payment-qr-parser
- Create a new gitHub personal access token(PAT) with
repo
andread:packages
permissions - in terminal, run this command
npm login --scope=@rationally-app --registry=https://npm.pkg.github.com
- type your username, followed by the personal access token created with step 1 as your password, and your email
- Create a new gitHub personal access token(PAT) with
-
Install dependencies:
npm install
-
This step only applies if you are on a windows machine. If not, skip this step.
-
open
package.json
and replace thescripts
object with the following:{ "start": "set APP_BUILD_VERSION=1 && set APP_BINARY_VERSION=dev && set START_STORYBOOK=false && expo start", "start:mock": "set APP_BUILD_VERSION=1 && set APP_BINARY_VERSION=dev && set MOCK=true && expo start", "test": "jest", "test:coverage": "npm run test -- --coverage", "test:watch": "jest --watch", "storybook": "set APP_BUILD_VERSION=1 && set APP_BINARY_VERSION=dev && set START_STORYBOOK=true && expo start", "android": "set APP_BUILD_VERSION=1 && set APP_BINARY_VERSION=dev && expo start --android", "ios": "set APP_BUILD_VERSION=1 && set APP_BINARY_VERSION=dev && expo start --ios", "web": "expo start --web", "eject": "expo eject", "lint": "eslint . --ext .ts,.tsx,.mdx --max-warnings 0", "lint:fix": "npm run lint -- --fix" }
-
-
Download a build mentioned in https://www.notion.so/sally-wallet/Mobile-development-workflow-49a03003b97444a280a75c53e7386600
-
Run one of the following to start development:
npm run start
npm run start:mock
: If you'd like to mock the APIsnpm run storybook
: If you'd like to use Storybook for development
We use remark
for linting .md
files.
npm run markdown:lint
Install the remark
VSCode extension to lint your markdown files.
npm run test
npm run test:watch # If you'd like to test specific files
We use Github Actions and have supplied the .gihthub/workflows
for setting it up. You will need to add the following secrets to the Github Repo:
EXPO_CLI_PROD_USERNAME
EXPO_CLI_PROD_PASSWORD
EXPO_CLI_TEST_USERNAME
EXPO_CLI_TEST_PASSWORD
You will also need to define the following environment variables in a .env file (please refer to .env.example):
SENTRY_ORG: the slug of the organisation to use for a command
SENTRY_PROJECT: the slug of the project to use for a command
SENTRY_AUTH_TOKEN: the authentication token to use for all communication with Sentry
SENTRY_DSN: the DSN to use to connect to sentry
DOMAIN_FORMAT: to validate backend endpoints
If you're releasing this for the first time, you need to create a tag to specify the initial version of the app. This allows the changelog generator to generate the correct set of changes. A base-ref
property will then need to be created in the changelog generator's with
parameter. Once released, this property can be removed.
uses: metcalfc/changelog-generator@v0.4.0
with:
myToken: ${{ secrets.GH_TOKEN_SUPPLYALLY_BOT }}
base-ref: <base-tag> # e.g. prod-0
-
To fix the network issues on expo app in terms of backend api not reachable :
-
import deleteStoreInBuckets from src/utils/bucketStorageHelper.ts
-
to replace useEffect hook in
authStore.tsx
. -
then refresh the app. it will show the login screen
-
after everything is done revert all changes in
authStore.tsx
.import {deleteStoreInBuckets} from "../utils/bucketStorageHelper"; useEffect(() => { if (hasLoadedFromPrimaryStore) { const authCredentialsString = JSON.stringify(authCredentials); const prevAuthCredentialsString = JSON.stringify(prevAuthCredentials); // do a top level check to see if there are any changes if (authCredentialsString) { deleteStoreInBuckets(AUTH_CREDENTIALS_STORE_KEY, authCredentialsString); } } }, [hasLoadedFromPrimaryStore, authCredentials, prevAuthCredentials]);
-