Package Exports
- juicebox.js
- juicebox.js/dist/juicebox.esm.js
- juicebox.js/dist/juicebox.min.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (juicebox.js) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
juicebox.js
juicebox.js is an embeddable interactive contact map viewer for .hic files written in JavaScript and CSS. It is based on the desktop Juicebox visualization application.
Installation
Requirements:
- 
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.2.0/css/font-awesome.min.css">
- Juicebox CSS - <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/juicebox.js@2.3.1/dist/css/juicebox.css">
- Juicebox javascript -- see below 
To import juicebox as an ES6 module
import juicebox from "https://cdn.jsdelivr.net/npm/juicebox.js@2.3.1/dist/juicebox.esm.js";Or as a script include (defines the "juicebox" global)
<script src="https://cdn.jsdelivr.net/npm/juicebox.js@2.3.1/dist/juicebox.min.js"></script>Alternatively you can install with npm
 npm install juicebox
and source the appropriate file for your module system (juicebox.min.js or juicebox.esm.js) in node_modules/juicebos.js/dist. Or build from source (see Development section below).
Usage
To create an juicebox instance call juicebox.init with a container div  and an initial configuration object as 
illustrated below.  See also examples/juicebox.html and examples/juicebox-es6.html.  
   const config = {
        url: "https://www.encodeproject.org/files/ENCFF718AWL/@@download/ENCFF718AWL.hic",
        name: "GM12878",
        //locus: "22:33,319,567-36,009,566",   // <= optional initial locus
        tracks: [
            {
                url: "https://www.encodeproject.org/files/ENCFF000ARJ/@@download/ENCFF000ARJ.bigWig",
                name: "CTCF",
                min: 0,
                max: 25,
                color: "#ff8802"
            }
        ]
    }
    const container = document.getElementById("app-container");
    juicebox.init(container, config)
        .then(function (hicBrowser) {
            console.log("Juicebox loaded");
        })
The juicebox.init function returns a promise for a HICBrowser object. This object exposes functions for interacting with the viewer including
- loadHicFile({url: urlString, name: string})
- loadTracks([array of track configs...])
See examples/juicebox-api.html for a working example.
For a description of track configurations see the documentation for igv.js. Example of a basic track configuration object:
{
   url: "https://www.encodeproject.org/files/ENCFF000ARJ/@@download/ENCFF000ARJ.bigWig",
   name: "CTCF
}Development
Requirements
Building juicebox.js requires Linux or MacOS, and node.js.
Other Unix environments will probably work but have not been tested. Windows users can use Windows Subsystem for Linux.
Building
git clone https://github.com/igvteam/juicebox.js.git
cd juicebox.js
npm install
npm run buildThis creates a dist folder with the following files
- juicebox.js - ES5 compatible file. A script include will define the "juicebox" global.
- juicebox.min.js - minified version of juicebox.js
- juicebox.esm.js -- ES6 module
- css -- folder containing required css file juicebox.css and associated images
Supported Browsers
juicebox.js require a modern web browser with support for Javascript ECMAScript 2015.
Juicebox-web
For an out-of-the box web application for viewing and sharing contact maps from .hic files see Juicebox-web, a web application embedding a juicebox.js viewer.
License
juicebox.js is MIT licensed.