Eureka! Clinical Analytics Web Client
Georgia Clinical and Translational Science Alliance (Georgia CTSA), Emory University, Atlanta, GA
What does it do?
This project contains the web client for Eureka! Clinical Analytics. It is an angularjs single-page site.
Version 2.0
The job submission page provides experimental support for updating phenotypes in a destination database. There are also numerous bug fixes in the server-side services. On the client side, this version fixes an error when clicking Edit on a phenotype with a percent sign in it.
Version 1.1
The changes for this release are behind the scenes to support a revised server-side architecture that we're implementing. User profile and administration functions have completely moved into separate web clients that, if installed, are available from the user menu in the upper right corner of the screen.
Version 1.1.1
This version fixes an error when clicking Edit on a phenotype with a percent sign in it.
Version 1.0.1
A news item for the new Eureka! Clinical Analytics release on the homepage was omitted. This version adds it back.
Version 1.0
Initial release
Build requirements
Runtime requirements
- Any web browser that is supported by AngularJS version 1.5 (see https://docs.angularjs.org/misc/faq).
eurekaclinical-analytics-webapp
version 1.0 from https://oss.sonatype.org/content/groups/public/org/eurekaclinical/eurekaclinical-analytics-webapp/1.0/eurekaclinical-analytics-webapp-1.0.war, accessible over the internet from your web browser. See https://github.com/eurekaclinical/eurekaclinical-analytics-webapp for installation instructions.eurekaclinical-analytics-service
version 1.0 from https://oss.sonatype.org/content/groups/public/org/eurekaclinical/eurekaclinical-analytics-service/1.0/eurekaclinical-analytics-service-1.0.war, accessible over the internet from your web browser. See https://github.com/eurekaclinical/eurekaclinical-analytics-service for installation instructions.eurekaclinical-protempa-service
version 1.0.1 from https://oss.sonatype.org/content/groups/public/org/eurekaclinical/eurekaclinical-protempa-service/1.0.1/eurekaclinical-protempa-service-1.0.1.war, accessible over the internet from your web browser. See https://github.com/eurekaclinical/eurekaclinical-protempa-service for installation instructions.
Building it
We use maven, node, and gulp to build the project. You need to install maven on your computer. Maven handles downloading and installing node and gulp for you. Maven installs node in the .eurekaclinical/dev directory in your home directory. It installs the node modules that are needed to build this project in the node_modules directory at the root of this project.
To build the project, execute mvn clean install
at the command line. For simple file changes, not additions or deletions, you can usually use mvn install
. To create a zipfile suitable for distribution, execute mvn install -Pdist
.
Performing system tests
To run the web client on your machine for testing purposes, do the following:
- Clone the eurekaclinical-analytics-webapp project from GitHub, and execute
mvn clean install
followed bymvn process-resources cargo:run -Ptomcat
in the root directory of the project on the command line to run the server-side Eureka! Clinical Analytics code in embedded tomcat. The backend services must be listening on port 8443, which is the default. - Back in the root directory of the web client project, execute
mvn clean install -Pwebserver
. It will open the web client in your default web browser at https://localhost:8000 in an embedded web server. You can leave the backend Eureka! Clinical Analytics code running while you repeatedly build and run the web client.
Installation
Copy the contents of the dist
directory into your web server's content directory in the folder of your choice.
Configuration
This web client is configured using a JSON file, config.json
, that should be in the same directory as the index.html file on your web server. It supports specifying the following options:
casLoginUrl
: The URL for logging into your CAS server. The default value ishttps://localhost:8000/cas-server/login
.logoutUrl
: The URL that the web client will go to when the user clicks theLogout
click in the upper right corner of the page. Before going to this URL, the web client will destroy the user's session. The default value ishttps://localhost:8000/cas-server/logout
, which logs the user out of CAS.eurekaWebappUrl
: The URL for eureka-webapp. The default value ishttps://localhost:8000/eurekaclinical-analytics-webapp
.
Specify the options as properties of a single JSON object. See the default config.json
file in the root directory of this project for a sample. The default file is copied into the dist
directory during the build process.
Developer documentation
The build process creates an ng-docs
directory in the root directory of this project. Load the index.html
file in this directory into your web browser to view the developer documentation.
Getting help
Feel free to contact us at [email protected].