Skip to content

icastillejogomez/fcm_mobile_technical_challenge

Repository files navigation

FCM Mobile Technical Challenge

Challenge instructions

Challenge instructions

What

FCM Digital team want to launch a new shiny travel guide app. We found that we have the chance to deliver a great product to our travelers. All best information about main world cities in their hands.

Why

Our current app is the best business itinerary app for FCM customers and we want to offer them a good curated travel guide, without risking the usability of main app in terms of disk usage and complexity. KISS principle.

How

As we are tech enthusiasts we want to improve our infrastructure, so we decided to implement a GraphQL API to be consumed by our frontend team. Many developers love this technology and after some research we think it fits perfectly for mobile and web apps using React.

We need your help to build a first prototype in react native, so we can test the potential of using this technology.

Brief

First version of the app needs to have following things:

  • Home screen with cities list
  • Detail city screen or embedded component in the list with some useful information as city name, currency, some monuments to visit and some restaurants

Delivery

Final solution is up to you, there are as many solutions as developers exists. You decide how to present the MVP taking design, usability, architecture and completeness decisions.

How to use challenge API

To run GraphQL API execute following command

yarn run graphql

It will launch a local graphql in http://localhost:3000/ to use as graphql endpoint in your app.

This local server gives you all data from db.js file and you can test your graphql queries with integrated GraphiQL IDE in http://localhost:3000/graphql

Example queries

query {
  City(id: 2) {
    name
  }
}

query {
  allCities {
    name
  }
}

How to use Graphql in react native

React native community recommends Apollo Client as the best library to use GraphQL in mobile (Visit https://www.apollographql.com/docs/react/)

How to run the app?

npm install

# Run Metro bundler with Expo
npm run start -c

▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄
█ ▄▄▄▄▄ █ ▀▀▄ ███▄█ ▄▄▄▄▄ █
█ █   █ ███ ▄▄ ▄▄ █ █   █ █
█ █▄▄▄█ █ ▄▄ █▄██▄█ █▄▄▄█ █
█▄▄▄▄▄▄▄█ █ ▀ █ █▄█▄▄▄▄▄▄▄█
█ ▄▄▀█▄▄█   ██ ▄▀█  ▄▄██  █
█▄▄▀▀█ ▄ █▀█▄█▀█ ▄█▄ ▀▄▄█▄█
███ ▄ ▀▄█▄▄█▄ ▄█▀█▄ ▄██▀ ▀█
█▄▄ ▀ ▄▄ ▀  ▀ ▄  ▄█▀▄▄▄█▀▄█
█▄▄█▄██▄█ █ ██    ▄▄▄  ▀█ █
█ ▄▄▄▄▄ █▀██▄█▀██ █▄█ ██▀ █
█ █   █ ████▄ ▄█▄ ▄▄   ▀ ▄█
█ █▄▄▄█ █ ▄█▀ ▄ █▀██ ▄██▄▄█
█▄▄▄▄▄▄▄█▄▄▄██▄▄▄▄▄▄▄▄███▄█

› Metro waiting on exp://<your-ip-address>:8081
› Scan the QR code above with Expo Go (Android) or the Camera app (iOS)

› Using Expo Go
› Press s │ switch to development build

› Press a │ open Android
› Press i │ open iOS simulator
› Press w │ open web

› Press j │ open debugger
› Press r │ reload app
› Press m │ toggle menu
› Press o │ open project code in your editor

› Press ? │ show all commands

Now you are ready to run the app on Android and iOS. Take in consideration that in Android could be necessary a Google Maps API key in order to render the map. It's possible than Expo wraps with need if you run the app with it.

You can also run the app in the iOS or Android simulators with the next commands:

npm run ios

# or

npm run android

In case you want to run the app in an Android emulator without Expo (using npm run android command), you need to install the Google Maps API in the AndroidManifest.xml file.

Git hooks

On commit

Every time you commit your code, the following commands will be executed:

npm run lint
npm run check-types

See file here here

$ git commit -m "Your commit message" -m "Your commit description"


> fcmtravelguide@0.0.1 lint
> expo lint

> npx eslint .

> fcmtravelguide@0.0.1 check-types
> tsc --noEmit

[master 743aff0] docs: Add why native-components wrapping?" section
 1 file changed, 45 insertions(+)

On push

Every time you push your code, the following commands will be executed:

npm run test

See file here here

$ git push origin master

> fcmtravelguide@0.0.1 test
> jest

 PASS  __tests__/app.test.tsx
  When rendering the app
    ✓ should render the app (222 ms)

Test Suites: 1 passed, 1 total
Tests:       1 passed, 1 total
Snapshots:   1 passed, 1 total
Time:        0.841 s, estimated 1 s
Ran all test suites.
Enumerating objects: 5, done.
Counting objects: 100% (5/5), done.
Delta compression using up to 12 threads
Compressing objects: 100% (3/3), done.
Writing objects: 100% (3/3), 1.49 KiB | 1.49 MiB/s, done.
Total 3 (delta 2), reused 0 (delta 0), pack-reused 0
remote: Resolving deltas: 100% (2/2), completed with 2 local objects.
To github.com:icastillejogomez/fcm_mobile_technical_challenge.git
   d6251f4..743aff0  master -> master

Known issues

Show map button

The "View map" button only works after the maps are visible al least one pixel.

Android Safe Area View

In some android emulators the safe area view is not working properly.

Todo list

Setting up the challenge

  • Ensure NPM as package manager
  • Upgrade React Native to the latest version
  • Check app runs and tests are passing
  • Install Expo framework and run the app
  • Install Prettier and Git hooks
  • Update Expo configuration (Typescript, app.json, etc.)
  • Prepare basic Pipeline to ensure code quality
  • Check GraphQL API works as expected

Implementing the challenge

  • Optimize images
  • Create project structure
  • Retrieve data and draw a simply list with cities
  • Choose a theme palette
  • Create app theme hooks
  • Create Header component
  • Create Explore screen Header
  • Create BottomTabNavigation component
  • Think about missing data in the API and also think about the UI
  • Pick a few icons and images for the app
  • Define the models
  • Code the contexts (domains and repositories)
  • Implement the UI MVP (and thinks next steps...)
  • Wrap native components
  • Splash screen

Finish the challenge

  • Improve the place type selector
  • Check app runs on Android and iOS
  • CD: Create a release pipeline based on Semver Versioning tags.

Nice to implement

  • Snap on city selector
  • Offline message
  • Divide the Explore Header compontent into smaller components
  • Divide TabBar component into smaller components
  • Snap on place type selector
  • Generate a production build
  • Error snackbar
  • Create i18n dictionaries and hooks
  • Deep linking
  • Map view
  • Animations
  • Code a few end-to-end tests