Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/cern-phone-apps/mobile-phone-app

CERN Phone Mobile client. Multiplatform phone application compatible with Android and iOS.
https://github.com/cern-phone-apps/mobile-phone-app

android ios phone react react-native telephony

Last synced: about 2 months ago
JSON representation

CERN Phone Mobile client. Multiplatform phone application compatible with Android and iOS.

Awesome Lists containing this project

README

        

# Dial Mobile (CERN Phone Mobile App)

[View all screenshots](docs/all-screenshots.md)

CERN Phone application to make and receive calls.

[![Build Status](https://travis-ci.com/cern-phone-apps/mobile-phone-app.svg?branch=master)](https://travis-ci.com/cern-phone-apps/mobile-phone-app) [![codecov](https://codecov.io/gh/cern-phone-apps/mobile-phone-app/branch/master/graph/badge.svg)](https://codecov.io/gh/cern-phone-apps/mobile-phone-app) [![Dependency Status](https://david-dm.org/cern-phone-apps/mobile-phone-app.svg)](https://david-dm.org/cern-phone-apps/mobile-phone-app)

## Current limitations

| OS | Status |
| -- | -- |
| Android | Tested and working on Android 9 |
| iOS | Not yet compatible |

## Requirements

To install the following components, please follow the React Native guide for your platform

- Android >= 8.1
- Node >= 11.10.1
- [React Native Debugger](https://github.com/jhen0409/react-native-debugger)
- yarn (>1.16.0)
- React Native >= 0.61

## Development

### Read the docs

- [Contributing Guidelines](docs/CONTRIBUTING.md)
- [Git Basics](docs/git-basics.md)

### Environment setup

1. Follow the steps of the official [React Native documentation](https://facebook.github.io/react-native/docs/0.60/getting-started) to setup your development environment. Since we are using native modules, we need to follow the `React Native CLI Quickstart` guide.

### Updating libs

> ⚠️ Beware of the libs used which contain native code. Some of them are highly dependent on the React Native version and might not be compatible with newer ones.

- [React Native Callkeep](https://github.com/react-native-webrtc/react-native-callkeep)
- [React Native Webrtc](https://github.com/react-native-webrtc/react-native-webrtc)
- [React Native Firebase](https://github.com/invertase/react-native-firebase)
- [React Native Vector Icons](https://github.com/oblador/react-native-vector-icons)
- [React Navigation (and it's dependencies)](https://reactnavigation.org/)
- [React Native Gesture Handler](https://github.com/kmagiera/react-native-gesture-handler)
- [React Native Screens](https://github.com/kmagiera/react-native-screens)
- [React Native Reanimated](https://github.com/software-mansion/react-native-reanimated)
- [React Native Sound](https://github.com/zmxv/react-native-sound)

### Debugging

#### On a physical device

- Shake the phone to display the development menu.

#### On the emulator

- Command + M will display the development menu.

#### Change the debugger port

1. Open the development menu
2. On "Dev Settings" change the "Debug server
host & port for device" to something like:
`localhost:8081`

## Run the app

### On Android

```bash
yarn
yarn run android
```

### Troubleshoot your environment

Running the following command will return a diagnosis of your environment:

```bash
npx @react-native-community/cli doctor
```

## Testing

```bash
yarn test
```

## Packaging and Deployment

- Read the https://facebook.github.io/react-native/docs/signed-apk-android

The following command will generate the `apk` for Android.
```
cd android
./gradlew assembleRelease
```