Home

Awesome

Digital Paper Edit - Client

---> Work in progress <--

An application to make it faster, easier and more accessible to edit audio and video interviews using automatically generated transcriptions form STT service.

See intro and slides for more info on the project and user journey for a high level overview of the user journey.

Github project board (for my forks) - across linked repos

Project Architecture

It's a React, Express, Electron, Adobe CEP, AWS stack to be able to deploy one modular code base as a Web app or Cross platform Desktop app (for Mac, win and linux).

The project is organised across these repository

Micro services for web app backend

See here to see them as a list in github.

See modular architecture section for more details on the stack and the Modular Architecture ADR for more info on the implementation

The projects use npm semantic versioning

<!-- ![](https://raw.githubusercontent.com/pietrop/digital-paper-edit-infrastructure/master/docs/adr/newest_arch.png) --> <!-- Between the 5 June and 17 July there is a sprint board used for organising the backlog for each two-week sprint cycle. --> <!-- - [BBC News Labs - Digital Paper Edit - Sprint Board](https://github.com/orgs/bbc/projects/33) is a Github project board [with linked repository](https://help.github.com/en/articles/linking-a-repository-to-a-project-board) where issues are added from the relevant repository listed in architecture section. -->

The project is divided into concurrent milestones as described here

And there are github project board for each milestone

With UX being an overarching milestone that cuts across these different parts

See UX Approach in docs guides for more info.

Setup

<!-- _stack - optional_ _How to build and run the code/app_ -->

See optional getting setup with the visual code workspace to get up and running with the various repository needed for this project.

git clone git@github.com:pietrop/digital-paper-edit-client.git
cd digital-paper-edit-client

Optional step to setup nvm to use node version 10, otherwise just use node version 10

nvm use || nvm install`

in root of project

npm install

Usage - development

<!-- `cd` into the individual repository inside [`./packages`](./packages) and npm start, or see respective README and package.json for how deal with each. -->

In root of the client project (cd digital-paper-edit-client) start React

npm run start

To developer for the web app you will need to start setup and the API server as well.

Runs the app in the development mode.<br> Open http://localhost:3000 to view it in the browser.

The page will reload if you make edits.<br> You will also see any lint errors in the console.

<!-- additionally to develop for electron also run ,in another terminal, in root of project. ``` make start-electron ``` -->

Usage - production

The project is also publicly available in the npm registry @pietrop/digital-paper-edit-client

you can add it to your project

npm install @pietrop/digital-paper-edit-client

and eg in an express server you can serve the static build as follows

app.use("/", express.static(path.join(__dirname, '..', 'node_modules/@pietrop/digital-paper-edit-client')));

System Architecture

Client - React, is setup using Create React App.

You can learn more in the Create React App documentation.

To learn React, check out the React documentation.

Development env

<!-- _How to run the development environment_ _Coding style convention ref optional, eg which linter to use_ _Linting, github pre-push hook - optional_ -->

Node version is set in node version manager .nvmrc

<!-- TODO: Setup eslint in express server -->

Documentation

See docs folder

An architectural decision record (ADR) is a document that captures an important architectural decision made along with its context and consequences.

We are using this template for ADR

<!-- [There also QA testing docs](./docs/qa/README.md) to manual test the component before a major release, (QA testing does not require any technical knowledge). -->

Build

<!-- _How to run build_ --> <!-- See README for individual packages for more details ?-->
npm run build

Build of react client side will be in build

Builds the app for production to the build folder.<br> It correctly bundles React in production mode and optimizes the build for the best performance.

The build is minified and the filenames include the hashes.<br> Your app is ready to be deployed!

Electron

See docs for more information on how this works with Electron.

In public/index.html:

if(window.process && window.process.versions.electron){
        const ElectronWrapper = require('../src/ElectronWrapper/index.js');
        window.ElectronWrapper = ElectronWrapper;
}

ElectronWrapper needs to be on the Electron render process otherwise (i.e. from the main process) the app will hang.

<!-- Build proc First do `make build-react` then `make build-electron` `packages/client/dist` will contain your packaged version of the app for desktop -->
  1. run npm run build which will output a build folder
  2. move the build folder to digital-paper-edit-electron repository
  3. from digital-paper-edit-electron, run npm run start:prod

Running in development (npm start:dev) in digital-paper-edit-electron will not work. In development mode, the electron-main.js looks for the app served by webpack in src/ElectronWrapper/index.js, which doesn't resolve as that is in a different repository.

Tests

<!-- _How to carry out tests_ -->

TBC

Test coverage using jest, to run tests

npm run test

During development you can use

npm run test:watch

Launches the test runner in the interactive watch mode.<br> See the section about running tests for more information.

<!-- See README for individual packages for more details --> <!-- ## Travis CI On commit this repo uses the [.travis.yml](./.travis.yml) config tu run the automated test on [travis CI](https://travis-ci.org/bbc/react-transcript-editor). -->

Environment variables

.env contains environment variables config for the React client side app.

<mark>Do not store credentials in .env during development.</mark>

REACT_APP_NAME App name is used in browser title and navbar component.

Deployment

<!-- _How to deploy the code/app into test/staging/production_ -->
npm run publish:public
<!-- See README for individual packages for more details -->

for more info on Create React app deployment:

See the section about deployment for more information.

Demo page on github pages

To update demo on github pages pietrop.github.io/digital-paper-edit-client

npm run deploy:ghpages

Contributing

See CONTRIBUTING.md guidelines and CODE_OF_CONDUCT.md guidelines.

Licence

<!-- mention MIT Licence -->

See LICENCE

Legal Disclaimer

Despite using React and DraftJs, this repo is not promoting any Facebook products or other commercial interest.