Skip to main content

Gosling custom component for Streamlit

Project description

Streamlit - Gosling

A Streamlit component to display Genomic Visualization using Gosling.

https://user-images.githubusercontent.com/9922882/109852545-e05f3400-7c22-11eb-90f3-7371e4ddeb42.png

An online demo is host at Streamlit Clound.
Checkout the code of the demo

Install

pip install streamlit-gosling

also need to install its dependencies gosling and streamlit

pip install gosling
pip install streamlit

Usage

This library provides 2 functions to display gosling visualization :

  • from_gos to display visualization created by from a gosling instances
  • from_json to display visualization from Golsing JSON spec (in the form Python dict)

using from_gos

import streamlit as st
import gosling as gos
import streamlit_gosling as st_gos

size = 500


# create visualization using gosling
@st.cache
def chart():
    data = gos.matrix("https://server.gosling-lang.org/api/v1/tileset_info/?d=leung2015-hg38")
    return gos.Track(data).mark_bar().encode(
        x=gos.X("xs:G", axis="bottom"),
        xe="xe:G",
        y=gos.Y("ys:G", axis="left"),
        ye="ye:G",
        color=gos.Color("value:Q", range="hot", legend=True),
    ).properties(width=size, height=size).view()

# wrap gosling visualization as a streamlit component
st_gos.from_gos(
    spec=chart(), 
    id='id', 
    height=size+ 100
)

using from_json

import streamlit_gosling as st_gos

spec = {
  "title": "Basic Marks: bar",
  "subtitle": "Tutorial Examples",
  "tracks": [
    {
      "layout": "linear",
      "width": 800,
      "height": 180,
      "data": {
        "url": "https://resgen.io/api/v1/tileset_info/?d=UvVPeLHuRDiYA3qwFlm7xQ",
        "type": "multivec",
        "row": "sample",
        "column": "position",
        "value": "peak",
        "categories": ["sample 1"],
        "binSize": 5
      },
      "mark": "bar",
      "x": {"field": "start", "type": "genomic", "axis": "bottom"},
      "xe": {"field": "end", "type": "genomic"},
      "y": {"field": "peak", "type": "quantitative", "axis": "right"},
      "size": {"value": 5}
    }
  ]
}

st_gos.from_gos(
    spec=spec, 
    id='id', 
    height=size+ 100
)

docs of gosling python package
docs of streamlit

API

st_echarts API

from_gos(id: string,
    spec: a gosling visualization object,
    height: number,
    eventType?: 'mouseOver' | 'click' | 'rangeSelect',
    api?
)
from_json(id: string,
    spec: a gosling JSON spec as python dicts
    height: number,
    eventType?: 'mouseOver' | 'click' | 'rangeSelect',
    api?
)
  • id: string
  • spec: a visualization object created using Gosling or a gosling JSON spec as python dicts
  • height: number
  • eventType: string, one of 'mouseOver', 'click', and 'rangeSelect'. If specified, the event data of the specified mouse event will be returned by the streamlit-gosling component.
  • api: ``. Call an api function of the gosling visualization. Three types of api actions are currently supported.
    { action: "zoomTo", viewId: string, position: string, padding?: number, duration?: number }
    
    { action: "zoomToExtent", viewId: string, duration?: number}
      
    { action: "zoomToGene", viewId: string, gene: string, padding?: number, duration?: number }
    
    
    example
    import streamlit as st
    from streamlit_gosling as st_gos
    
    # user select a chromosome using streamlit select box
    chr = st.select('zoom to a chromosome', [str(i) for i in range(1, 20)])
    
    # the visaulization will zoom to different chromosome based on users' selection
    st_gos.from_gos(
        spec=/****/, 
        id='id', 
        height=350, 
        api={'action': 'zoomTo','viewId': 'track-1', 'position': f'chr{chr}'}
      )
    

Development

Install

  • JS side
cd frontend
npm install
  • Python side
conda create -n streamlit-gosling python=3.7
conda activate streamlit-gosling
pip install -e .

Run

You need to run both the JS side and the Python side for development mode.

  • JS side
cd frontend
npm run start
  • Python side

Demo example is on https://github.com/andfanilo/streamlit-echarts-demo.

git clone https://github.com/andfanilo/streamlit-echarts-demo
cd streamlit-echarts-demo/
streamlit run app.py

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

streamlit-gosling-0.1.3.tar.gz (5.8 MB view hashes)

Uploaded Source

Built Distribution

streamlit_gosling-0.1.3-py3-none-any.whl (9.9 MB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page