Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/srbrahma/visionmate-rn-application

React Native app developed for Visionmate's mobile position
https://github.com/srbrahma/visionmate-rn-application

assessment-project react-native typescript

Last synced: about 2 months ago
JSON representation

React Native app developed for Visionmate's mobile position

Awesome Lists containing this project

README

        

[![TypeScript](https://badgen.net/npm/types/env-var)](http://www.typescriptlang.org/)

# Visionmate Techinical Test

https://user-images.githubusercontent.com/28177550/179091624-1fc6bfad-aba4-40c6-b703-6039ce1ded04.mp4

[Higher Video Quality - Be sure to select the 1080p](https://drive.google.com/file/d/1PFEryKQYC4CtAui0-aHIBnp1YgMogjnK/view?usp=sharing)

Technical test for Visionmate made in 2~3 days by me, Henrique Almeida, aka [SrBrahma](https://github.com/SrBrahma). [Specifications](https://github.com/SrBrahma/visionmate-rn-application/blob/main/specifications.md).

The recording of the app made it a bit laggy.

When I was thinking about its color pallete and its UI, I remembered Visionmate has a website and I decided to not only follow its color scheme but to also add its hero video, the diagonal pattern present above the video and its logo.

Project created using my [gev](https://github.com/SrBrahma/gev) npx tool, with the `rn` flavor to create React Native projects within a single command with my commonly used configs, such as my [eslint-config](https://github.com/SrBrahma/eslint-config-gev) and directories tree.

I tried to balance the quality and not overdoing it (but still, turned out to be great in just a few days of work!).


## đŸ’ŋ Installation
```bash
yarn install
```

### iOS
* Run `npx pod-install`.
* https://github.com/oblador/react-native-vector-icons#ios - Only `MaterialCommunityIcons.ttf` is required
* https://github.com/react-native-video/react-native-video/blob/master/API.md#ios-installation - May be required

## 📖 Usage

```bash
Start Metro with
â€ĸ yarn start

Run instructions for iOS:
â€ĸ yarn ios
- or -
â€ĸ Open TestRN/ios/TestRN.xcodeproj in Xcode or run "xed -b ios"
â€ĸ Hit the Run button

Run instructions for Android:
â€ĸ Have an Android emulator running (quickest way to get started), or a device connected.
â€ĸ yarn android
```

Also: https://reactnative.dev/docs/running-on-device

## ℹī¸ Info

* Uses JSX transform so `import React from 'react'` isn't required:
https://aryan-mittal.medium.com/enable-the-new-jsx-transform-in-react-native-0-64-aea4f686a640, https://github.com/facebook/metro/issues/646#issuecomment-799174473

* Disabled Android's automatic forced dark mode: https://stackoverflow.com/a/64339016

* We use [Fuse.js](https://github.com/krisk/Fuse) as the fuzzy-search library. It's great!

* And [FlashList](https://github.com/shopify/flash-list) for a FlatList with a way better performance!

* We use react-native-video@next (v6) since v5 is broken.

* I haven't tested it on iOS as at the moment I don't have access to XCode and my [MacInCloud](https://www.macincloud.com) subscription isn't active.

* I took advantage of this project and used React-Query v4 to learn about it, still on beta but with [relevant improvements](https://tanstack.com/query/v4/docs/guides/migrating-to-react-query-4). [Installation](https://github.com/TanStack/query/issues/3790#issuecomment-1179431860).

* [Do use `npx react-native-asset` for adding fonts to react-native@>0.69](https://github.com/facebook/react-native/issues/34095#issuecomment-1174864177)