LocusZoom.js provides many powerful options for visualizing genetic data in biological context. Our goal is to make the most common tasks easy, while providing advanced options for custom visualization and interactivity. For an overview of capabilities (and places where it is used), see our preprint: “LocusZoom.js: Interactive and embeddable visualization of genetic association study results”
LocusZoom.js is designed to work with your web page, regardless of your skill level or the tools you are used to using.
Many of our users work on small projects with a single HTML file and
no special tools. By loading three files, the library will be
automatically available as a global variable LocusZoom that
provides access to all helper methods
(LocusZoom.populate(...), etc).
In the example below, be sure to replace
VERSION_GOES_HERE with the actual version of the newest release.
It is possible to omit @VERSION entirely, but in order to
keep up with a fast changing field, sometimes we need to make breaking
changes. Using a real version string allows you to avoid things breaking
by surprise later.
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/locuszoom@VERSION_GOES_HERE/dist/locuszoom.css" type="text/css" crossorigin="anonymous"/>
<script src="https://cdn.jsdelivr.net/npm/d3@^5.16.0" type="application/javascript"></script>
<script src="https://cdn.jsdelivr.net/npm/locuszoom@VERSION_GOES_HERE/dist/locuszoom.app.min.js" type="application/javascript"></script>Many “modern” JS frameworks (like React or Vue.js) use package managers (npm) and build tools (such as webpack) to manage the code and assets for your app. LocusZoom.js can be incorporated into fully modern tools as follows:
First install the library using your package manager, which will keep track of the version known to work with your app:
$ npm install locuszoom
Then, load the code where it is used, and write code as normally.
This will load from native ES6 module files for a smaller build size.
From there, you can access all helper methods from the parent symbol, eg
LocusZoom.populate().
import LocusZoom from 'locuszoom';
import 'locuszoom/dist/locuszoom.css';TIP: Many build tools will recognize the import of a CSS file, and automatically combine it with your other CSS files into a single bundle. If you have problems importing CSS this way, you can instead load the stylesheet from a
<link>tag in your HTML, as in the previous section.
If you are a very experienced developer, you may notice that we are
using helper methods like LocusZoom.populate(), instead of
importing individual symbols like populate. We have chosen
this coding style because it lets us write a single set of instructions
for all of our users, regardless of what tools they use.
Creating a LocusZoom plot requires three pieces of information:
Once defined, these values can be passed to the populate() method along with a selector to identify a div, like so:
const plot = LocusZoom.populate(selector_id, data_sources, layout);The “classic” LocusZoom plot consists of two panels: a GWAS scatter plot on top, and a view of nearby genes in the region on bottom. See simple GWAS template for the code you will need to get started. This introduction describes the very broad outlines of the process, but additional guides are available that cover each piece in more detail.
If your only goal is to generate a LocusZoom plot, we provide two “plot your own data” services that provide the benefits of LocusZoom.js without writing any code at all:
LocusZoom-style visualizations are widely used throughout the field of genetics, and this is by no means the only tool available for creating them. However, many existing tools only create a static image. LocusZoom.js was designed to power large data-exploration hubs such as PheWeb or the HuGeAMP family of knowledge portals: it can be used by websites that want to take full advantage of what the web browser has to offer.
As you read the examples, you may notice that all of our instructions are based on layout objects that ask for features by name (a declarative style), rather than creating new classes directly and managing every aspect of the plot yourself (imperative). This is for two reasons:
Each piece of the system has many configuration options; we provide a full developer reference with exhaustive details. Most websites will only need a small subset of the options, like “layout point color”. We encourage you to try the premade layouts first, and use the “how to” guidance below to help you focus on the specific page required for a given task.
LocusZoom.js defines reusable, highly configurable building blocks that can be combined to create many kinds of visualization. This approach grants enormous flexibility, but it also means that the configuration (layout) can be very overwhelming at first. Understanding the basic structure and terminology can be very helpful in knowing where to look for more information.
The key pieces are:
LocusZoom.populate(...) method. A plot is defined in
terms of a layout. The visualization can be controlled programmatically
by the initialized plot instance, with various options and supported methodsTo achieve high reusability, each of these building blocks is intended to be loosely coupled: building blocks typically do not know about or depend on the internal data structures, state, or behavior of other pieces. For example, each data layer is responsible for requesting its own data and maintaining its own state. Similarly, scale functions are generally stateless (eg, operate only on a single scalar value from a single datum element).
Plots are not limited to a static visualization: they are capable of sharing data with elements outside the page, as well as forming connections with matching data elements on other panels. (see: guide to interactivity)
This is achieved via events. Common actions (such as clicking a point, dragging to change the view, or receiving new data) will emit an event, along with information about how the event was triggered. Events are used for internal features (such as match events between decoupled data layers), but they can also be used to communicate with external widgets like a table of data on the page.
See the full developer documentation for a list of available events and how they are emitted.
Visualizations are responsible for displaying the information given. Each element is intended to be largely isolated and decoupled: for the most part, pieces can be mixed and matched without needing to know about (or influence) the internal behavior of other pieces.
Operations on data are performed by the following elements:
ScalableParameter in the developer configuration
documentation.{{fieldname|functionname}}Plots are highly customizable, and it can be easy to get lost in the dense web of configuration options. In addition to the prose documentation, we provide a wide range of source code examples that demonstrate how to do specific things. (see the resources below for details) Documentation by example is an explicit and formal part of our documentation process.
LocusZoom.js is an open source project under the permissive MIT license. We welcome and encourage contributions from our users. If there is a new visualization or feature that you would like to see, please reach out via our public issue tracker or mailing list to get started.
LocusZoom.js has many advanced features. Some are implemented in code, and others are available as configuration options. We provide a range of examples for how to use it. Many of the examples below are open source.
LocusZoom provides a lot of functionality, but getting the most of it does requires some help. We provide prose guides on the following topics:
If you are ready to go deeper, see the detailed API documentation, describing all the configuration options, plugins, and visualization types available.