Skip to content

Latest commit

 

History

History
209 lines (143 loc) · 5.46 KB

README.md

File metadata and controls

209 lines (143 loc) · 5.46 KB

Project title

Short description about the project (Business case)


Table of Contents

  1. About the project
  2. Run application
    1. Requirements
    2. Setup for Mac
    3. Run E2E tests
  3. Additional info
    1. Fastlane setup
    2. Sentry setup
  4. Coding conventions
    1. Project structure
    2. How to run tests?
    3. How to run lint?
  5. Useful links
  6. Git conventions
  7. Troubleshooting

About the project

This is boilerplate.

Run application

Requirements

  • Yarn
  • Node

NOTE: We always use Yarn as our default package manager tool.

// start development server
yarn start

// run ios app
yarn ios

// run android app
yarn android

Setup for Mac

PRO TIP: Make sure you’re connected to the internet!🙃

Open your terminal or run it inside this project's integrated terminal:

git --version

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"

chmod -R 777 ./scripts
./scripts/reactNativeStarterPack.sh

NOTE: Script doesn't cover Xcode installation so you have to grab it from here.

Run E2E tests

yarn test-e2e

Additional info

  • For application monitoring and error tracking we're using Sentry
  • For deployments and releases we're using Fastlane
  • For navigation we're using react-native-router-flux, you can find demo navigation example on src/containers/Routes.js
  • Localization support is also included in the boilerplate

Fastlane setup:

  1. fastlane/Matchfile: Enter your app_identifier e.g. com.nfq.projectname
  2. fastlane/Fastline: Enter your app name to fields workspace and scheme and edit path to firebase config script.
  3. fastlane/Appfile: Add your app_identifier and package_name e.g. app_identifier("com.nfq.projectname") and package_name("com.nfqprojectname")

Sentry setup:

  1. Fill in your project name defaults.project=<your-project-name> at ios/sentry.properties: and android/sentry.properties:

Managing locales:

We're currently using i18next with react-i18next. Boilerplate includes a working locale demo with language change handler.

Changing language is easy:

import { locale } from 'src/utils/locale';

const languageHandler = (lang) => {
    locale.changeLanguage(lang);
}

Locale config can be found in src/utils/locale/. Language files are located at src/assets/locale/.

Coding conventions

Naming

Event emmiters

on<event-name>, e.g.: onChange, onSubmitClick etc

Event handlers

handle<event-name>, e.g.: handleChange, handleSubmitClick etc

Variables

Avoid shortened variable names:

  • use option instead of opt
  • use event instead of e or evt
  • use nextLevelButton instead of nextLvlBtn or nxtLevelButt
  • exceptions:
    • common shortenings that are used in everyday language, such as "config", "admin" etc
    • for loop variables (i, j etc)

Project Structure

assets/icons

Any new icon should be placed in assets/icons folder. And should be in svg format. And run the script

yarn svg:icons

This script will:

  1. Optimize and replace all svg files
  2. Overwrite assets/icons/index.ts file and add export or update exports

How to run tests?

yarn test

How to run lint?

yarn lint

Useful links

Git conventions

Branches should be named in a following manner:

// new feature
git checkout -b feature/<JiraID (if exists)>-comprehensible-name

// refactoring
git checkout -b refactoring/<JiraID (if exists)>-comprehensible-name

// bugfix
git checkout -b fix/<JiraID (if exists)>-comprehensible-name

// dependency updates
git checkout -b update/<JiraID (if exists)>-package-name
git checkout -b update/<JiraID(if exists)>-other-comprehensible-name

Make sure that for every bigger change you have checked out to new branch. Same goes for complicated package updates (e.g. react-native). Also make sure to be on the new branch when changing something inside native projects (namely ios and android directories).

Troubleshooting

Here we add troubleshooting tips if something needs more setup or one of the module is not working properly.

If you have encountered some problem and managed to fix it please leave a comment. Comment should be written in following manner:

  1. Node module name with version (for example: [email protected])
  2. Error name or text
  3. Platform [ios, android]
  4. Steps to reproduce (if there is some)
  5. Solution or link to solution

Test Data

Here is some test data

Login credentials