diff --git a/README.md b/README.md index 21eb1c337..bd994867b 100644 --- a/README.md +++ b/README.md @@ -14,10 +14,9 @@ The repository contains the following: - /library: shared library for the project - /tests: contains the end-to-end tests for the project - ## Local development quick start -Ensure you have uuid installed e.g. +Ensure you have uuid installed e.g. ```bash sudo apt-get install uuid @@ -27,7 +26,7 @@ Also check you have a modern npm installed, ideally v10.x.y. We recommend using [`nvm`](https://github.com/nvm-sh/nvm) (node version manager). To set this up -``` +```bash curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.0/install.sh | bash ``` @@ -52,7 +51,6 @@ Now run the script to get a docker service running locally. ./localdev.sh ``` - ## Initial step-by step setup Clone the repository and install node modules (note this only needs to be run from the parent folder) diff --git a/app/README.md b/app/README.md index eed7f4e37..e35fa488f 100644 --- a/app/README.md +++ b/app/README.md @@ -1,89 +1,5 @@ -# FAIMS3 +# FAIMS3 Mobile App -FAIMS3 is an open-source tool for offline field data-collection brought to you by the FAIMS Project. The FAIMS Project was funded by the ARDC ([https://dx.doi.org/10.47486/PL110]), Macquarie University, and CSIRO along with our other partners. This code is appropriate for building and deploying the Webapp, Android and iOS versions. The conductor, needed for user authentication, is located at [https://github.com/FAIMS/FAIMS3-conductor]. Contact [info@faims.edu.au](mailto:info@faims.edu.au) to enrol to try out the software. +This project contains the code for the FAIMS3 mobile app. -## Setting up a field server - -- [Draft instructions for a local offline server.](https://github.com/FAIMS/FAIMS3/settingUpFieldServer.md) - -## Developer notes to run test copies of FAIMS - -Before you do anything (apart from cloning this repository), you should run -npm install`to get all the dependencies -for the scripts installed (If you have been doing some development, either -stashing or committing your changes before -running`npm install` would be wise). - -Once the dependencies are installed, you should check any changes that have been -made, and commit them if needed. - -There are a number of helper scripts (which can be seen in the `package.json`), -but the ones that should always exist -are: - -- `npm run build`: builds the webapp (not the Android/iOS apps) -- `npm run test`: runs the main test suite -- `npm run serve`: runs the webapp in a browser (currently via capacitor's - system, to ensure that the webapp and the phone apps are as similar as - possible). -- `npm run start`: runs the webapp in a browser (unoptimized dev build). - -You should also be aware of the -[cli interface to capacitor](https://capacitorjs.com/docs/cli), as that does the -building/management of the Android/iOS -apps. - -Further build/install instructions can be found at -. - -### Docker Desktop setup - -1. Install [Docker desktop](https://www.docker.com/get-started/). -1. Create a new `Dev Environment`. -1. When prompted for `Existing Git repo` add the FAIMS3 git repo web address. -1. Click on `Open in VSCode` which will open your new container. -1. Then follow `Setup and development (quick-start)` steps inside of the VSCode which was opened. - -### (Alternatively) Use the terminal to create containers with Docker - -1. Install docker with brew using `brew install docker`. -1. Clone repository to your local machine. -1. Spin up a new Ubuntu container with your local machine location of the repository and give it a CONTAINERNAME of your choice `docker run -dt -v /LOCAL_REPO_LOCATION:/opt/projects -p 3000-4000:3000-4000 --name CONTAINERNAME ubuntu /bin/bash` -1. Check the container was created successfully with `docker container list -a`. -1. If successfully enter the container environment using `docker exec -it CONTAINERNAME bash` -1. Update linux package sources list to the latest and upgrade the current packages installed to latest versions with `apt update && apt upgrade`, type `y` and press enter for any prompts to allow installs to use disk space. -1. Install curl and fetch node with `apt install curl` then `curl -fsSL https://deb.nodesource.com/setup_16.x | bash -` to fetch node and make it visible to bash. -1. Install required tools for the project to run with `apt install gcc g++ make nodejs` which installs GNU Compiler Collection, GNU c++ compiler, Make unix utility and Nodejs. -1. Enter project folder `cd /opt/projects`. -1. Now follow `Setup and development (quick-start)`. - -- To exit container use `exit` command. -- To stop container use `docker stop CONTAINERNAME` -- To remove container use `docker rm CONTAINERNAME` - -## Choosing couchdb instances - -The `server_configs` directory contains scripts for some of the -development servers, but primarily exporting: - -```!shell -export REACT_APP_DIRECTORY_HOST= -export REACT_APP_DIRECTORY_PORT= -``` - -will allow you to choose which couchdb instance to use. Remember to add the -host-port pair of the system the _FAIMS_ app is running on (in most cases -`localhost:3000`) to the CORS allow list via the Fauxton running on the couchdb -server (located at `http://:/_utils/`). - -## Build mobile app - -1. Build the source code - - `npm run webapp-build` -1. Synchronise Gradle files - - `npm run webapp-sync` OR `cap sync` -1. [Optional] Allow to copy to /Library/Ruby/Gems/2.3.0: - - `export GEM_HOME="$HOME/.gem"` -1. [Optional] Resolve `xcode-select` error - - `sudo xcode-select -s /Applications/Xcode.app/Contents/Developer` -1. Build the apk from the build/build bundle/build apk section +Contact [info@faims.edu.au](mailto:info@faims.edu.au) to enrol to try out the software.