/FrontApp

Front-end Application sourcing data from FeatureService

Primary LanguageHTMLGNU General Public License v3.0GPL-3.0

FrontApp Build Status

Front-end Application sourcing data from FeatureService. It is a React application meant to manage datasets, launch annotation campaigns and annotate dataset files.

For more information about what the application can do or how to use the annotator, see the user guide.

Installation

npm install

Create a config env file:

echo "REACT_APP_API_URL=http://localhost:7231/data.ode.org/v1" > .env.development.local

Setting up development environment:

You should have FeatureService set up, you'd typically do it the following way:

# Install FeatureService if you don't have it already
git clone https://github.com/Project-ODE/FeatureService
# Install needed libraries
cd FeatureService; npm install
# We need to install a patch on hyperswitch to avoid CORS dev problems
curl https://raw.githubusercontent.com/ixio/OdeDocker/master/FeatureService/hyperswitch.patch | patch -p0
# Let's start by running a postgis DB container called testdb, if needed you can delete with "docker rm -f testdb" and re-create it
docker run --name testdb -e POSTGRES_USER=test -p 127.0.0.1:5433:5432 -d mdillon/postgis
# If this the first time postgis is started we need to seed it with knex
NODE_ENV=test knex migrate:latest; NODE_ENV=test knex seed:run
# To use knex like this you need to create an alias "alias knex=node_modules/knex/bin/cli.js" or install it globally with "npm install -g knex"

You can then run the following commands any time you need FeatureService:

# Let's make sure the DB is running
docker start testdb
# We can than start the FeatureService server in test mode (to access the test data)
NODE_ENV=test node server.js -c config.test.yaml

Useful commands:

npm start
npm test

Inspired by CrowdCurio

This project started as a wrapper around CrowdCurio annotator. As our use case diverged we decided to restart from scratch, using CrowdCurio as inspiration. Some features are still missing: waveform representation of the audio file, user feedback through test audio files (that already has reference annotations), and advanced tracking of user actions (deleted_annotations and annotation_events: start-to-create, offline-create, add-annoation-label, add-proxity-label, delete, play-region, select-for-edit, region-moved-end, region-moved-start).