Skip to content

Specifications

Description#

Console is a web-app targeted to App builders and Endusers which help to create and use workspaces, automations and applications.

It runs on every modern browser up to date (Chrome, Firefox, Safari, Edge).

A user account is needed to access the service.

Technical stack#

Library

Usage

Version

Typescript Language 4.5.2
React VDOM library 17
Next Framework 12
next-i18next Internationalization utility 10
final-form Forms management 4
socket.io WebSocket 4

The web app is built on top of typescript language and React/NextJS framework.

Through NextJS, the app is dynamically routed and some pages can be rendered on server side for SEO and caching.

Internationalization is managed by i18next. Translations are located in public/:lang folder under many json files.
Languages supported are english, french and spanish. English is the default language.

Forms are managed by final-form.

Realtime connexion with EDA uses socket.io library.

App states are managed by React context API with thematic Providers.

Design#

The console should be responsive, usable on width > 768px. On smaller devices, some functionalities may not be available. An explication will be displayed to let user knows what he could do on a bigger screen.

The features should have accessibility in mind. Main functionalities should be usable with keyboard and readable with a screen reader.

Performance#

Run Lighthouse to check for performance, best practices, accessibility, and SEO. For best results, use a production build of Next.js and use incognito in your browser so results aren't affected by extensions.

Lighthouse's results must be green.

Quality#

Development and quality standards#

  • At least 70% test coverage
  • Maximum 3 % duplicated code

Tests#

All components have a minimum snapshot test. Complex components have as many snapshots than different possible states. Utils have unit tests.

Tests

Minimal coverage rate

Details

Unit tests At least 70% N/A
Snapshot tests At least 70% All components have a minimum snapshot test. Complex components have as many snapshots than different possible states.
E2E 30% N/A

Logs#

No log must appears in user's console.

Errors#

Unexpected errors are sent to sentry.

Security#

App only read path which is parsed by NextJS. XSS attack should not be possible.

Authenticated user token is stored in local storage.

Company Social Responsibility (CSR)#

  • Use lazy loading for occasional resource loading
  • Limit databases results with pagination
  • Group massive processing into more effective batches

Hosting#

Dockerfile, docker-compose and Helm chart ready to use.

Linting#

The code should be formatted using Prettier, using the version specified in the package.json