Skip to content

Latest commit

 

History

History
112 lines (79 loc) · 5.66 KB

README.md

File metadata and controls

112 lines (79 loc) · 5.66 KB

CARTA Frontend

The CARTA frontend is used in conjunction with the CARTA backend, and for general use a pre-built production frontend is usually installed alongside the backend automatically. However, a user may wish to install the frontend component separately in order to test beta versions, for example, or to develop it.

Pre-built production packages

The simplest way to install the frontend component is to use the pre-built production packages from NPM (for any OS with Node.js installed), our PPA (Debian packages for Ubuntu), or our RPM repository (for RHEL based systems).

NPM

Pre-built production frontends can be obtained from the npmjs.com carta-frontend repository.

If you have Node.js and npm already installed on your system, you can install a production frontend using the following command:

npm i carta-frontend

The files will be installed to your node-modules directory. For a system-wide 'global' installation (using the -g flag) this is located at /usr/lib/node_modules, whereas for a local user installation, it is located at $PWD/node_modules.

You can install specific frontend versions by appending @ plus the version number. For example,

The available versions are listed in the npmjs.com carta-frontend versions tab.

Alternatively, the pre-built production frontend can be downloaded directly without npm. For example,

wget https://registry.npmjs.org/carta-frontend/-/carta-frontend-2.0.0.tgz

The standalone tgz archive file extracts as package/build in your current directory.

You can start the CARTA backend with a non-default frontend by specifying its location with the --frontend_folder flag. For example,

./carta-backend --frontend_folder $HOME/package/build

PPA

A Personal Package Archive (PPA) is a third-party package repository for Ubuntu. We supply pre-built production frontends at the CARTAvis-team PPA on the Ubuntu Lauchpad.

To install the latest release version:

sudo add-apt-repository ppa:cartavis-team/carta
sudo apt-get update
sudo apt-get install carta-frontend

The Ubuntu package install location for the frontend is /usr/share/carta/frontend/.

The PPA also provides a carta metapackage which automatically installs the CARTA frontend and backend packages. In addition to the latest release versions, beta versions are provided in a parallel set of packages.

RPM

RPMs are for users of Red Hat Enterprise Linux (RHEL) and other Red Hat-based Linux distributions, e.g. CentOS. To install the latest release version, add the appropriate repository file depending on whether you are using RHEL7 (el7) or RHEL8 (el8):

sudo curl https://packages.cartavis.org/cartavis-el7.repo --output /etc/yum.repos.d/cartavis.repo

or

sudo curl https://packages.cartavis.org/cartavis-el8.repo --output /etc/yum.repos.d/cartavis.repo

Then the frontend component can be installed using yum or dnf :

sudo yum install carta-frontend

The RPM package install location for the frontend is /usr/share/carta/frontend/.

The RPM repo also provides a carta metapackage which automatically installs the CARTA frontend and backend packages. In addition to the latest release versions, beta versions are provided in a parallel set of packages.

Development

If you wish to modify or develop the CARTA frontend, you may build a production or non-production frontend from source. Here are the instructions to do so:

Prerequisites

The build process relies heavily on npm and nodejs, so make sure they are installed and accessible.

We recommend using Docker or Singularity to perform WebAssembly compilation. If neither is available, the Emscripten compiler (emcc version 2.0.14 recommended) needs to be available in the build environment. Installation instructions are available on the Emscripten homepage.

Build process (using Docker/Singularity)

Initialise submodules and install package dependencies:

git submodule update --init --recursive
npm install

WebAssembly libraries can be built with npm run build-libs-docker or npm run build-libs-singularity. Additional build steps (building WebAssembly wrappers, protocol buffer modules and compiling the Typescript code) are performed by npm run build-docker or npm run build-singularity. This produces a production build in the build folder.

To run a development build server, simply run npm run start.

Build process (without Docker/Singularity)

If your build environment does not have access to Docker or Singularity, WebAssembly compilation must be performed in an environment with access to the Emscripten compiler.

Initialise submodules and install package dependencies:

git submodule update --init --recursive
npm install

WebAssembly libraries can be built with npm run build-libs. Additional build steps (building WebAssembly wrappers, protocol buffer modules and compiling the Typescript code) are performed by npm run build. This produces a production build in the build folder.

To run a development build server, simply run npm run start.

Developer documentation

Automatically generated documentation can be found at cartavis.org/carta-frontend.

DOI