From 35604482aacccd8cb58eb70174dfc3edc8480f2b Mon Sep 17 00:00:00 2001 From: unknown Date: Fri, 8 Sep 2023 13:38:45 +0800 Subject: [PATCH 1/4] Add display node data in coexpression --- callbacks/coexpression/callbacks.py | 14 +++++++++++++- pages/analysis/co_expr.py | 2 ++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/callbacks/coexpression/callbacks.py b/callbacks/coexpression/callbacks.py index 08865572..a34e0ed2 100644 --- a/callbacks/coexpression/callbacks.py +++ b/callbacks/coexpression/callbacks.py @@ -6,6 +6,8 @@ from ..lift_over import util as lift_over_util from ..branch import * +import json + Input_parameter_module = namedtuple('Input_parameter_module', [ 'param_slider_marks', 'param_slider_value']) @@ -532,8 +534,18 @@ def download_coexpression_table_to_csv(download_n_clicks, coexpression_df, genom State('coexpression-module-graph', 'elements'), State('homepage-genomic-intervals-submitted-input', 'data') ) - def download_coexpression_table_to_csv(download_n_clicks, coexpression_dict, genomic_intervals): + def download_coexpression_graph_to_csv(download_n_clicks, coexpression_dict, genomic_intervals): if download_n_clicks >= 1: return dict(content='Hello world!', filename=f'[{genomic_intervals}] Co-Expression Network Analysis Graph.txt') raise PreventUpdate + + @app.callback( + Output('coexpression-module-graph-node-data', 'children'), + Input('coexpression-module-graph', 'tapNodeData') + ) + def display_node_data(node_data): + if node_data: + return json.dumps(node_data) + + raise PreventUpdate diff --git a/pages/analysis/co_expr.py b/pages/analysis/co_expr.py index 232d58ca..9c56b844 100644 --- a/pages/analysis/co_expr.py +++ b/pages/analysis/co_expr.py @@ -495,6 +495,8 @@ ] ), + html.Div(id='coexpression-module-graph-node-data'), + dcc.Loading([ cyto.Cytoscape( id='coexpression-module-graph', From 45c6b93febe694796a4dd8cd3d9b7fc9583569a6 Mon Sep 17 00:00:00 2001 From: unknown Date: Mon, 11 Sep 2023 21:33:36 +0800 Subject: [PATCH 2/4] Sanitize nb intervals str in browse loci --- callbacks/browse_loci/callbacks.py | 3 ++- callbacks/browse_loci/util.py | 4 +++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/callbacks/browse_loci/callbacks.py b/callbacks/browse_loci/callbacks.py index fe931fff..b4e8e420 100644 --- a/callbacks/browse_loci/callbacks.py +++ b/callbacks/browse_loci/callbacks.py @@ -110,7 +110,8 @@ def send_open_chromatin_panicle_url(filename): ) def display_selected_genomic_intervals(nb_intervals_str, homepage_is_submitted, selected_nb_interval): if homepage_is_submitted: - igv_options = nb_intervals_str.split(';') + igv_options = util.sanitize_nb_intervals_str(nb_intervals_str) + igv_options = igv_options.split(';') if not selected_nb_interval: selected_nb_interval = igv_options[0] diff --git a/callbacks/browse_loci/util.py b/callbacks/browse_loci/util.py index ed420357..56edd059 100644 --- a/callbacks/browse_loci/util.py +++ b/callbacks/browse_loci/util.py @@ -23,7 +23,9 @@ def write_igv_tracks_to_file(nb_intervals_str): def write_gff_igv_track_to_file(source_dir, source_file, nb_intervals_str): if path_exists(source_dir): - loci_list = nb_intervals_str.split(';') + loci_list = util.sanitize_nb_intervals_str(nb_intervals_str) + loci_list = loci_list.split(';') + genomic_interval_list = util.get_genomic_intervals_from_input( nb_intervals_str) From 189aab27540134a08933fe12888059b9bf648bc7 Mon Sep 17 00:00:00 2001 From: unknown Date: Mon, 11 Sep 2023 21:57:48 +0800 Subject: [PATCH 3/4] Sanitize selected nb interval string in the igv --- callbacks/browse_loci/callbacks.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/callbacks/browse_loci/callbacks.py b/callbacks/browse_loci/callbacks.py index b4e8e420..c7e376ce 100644 --- a/callbacks/browse_loci/callbacks.py +++ b/callbacks/browse_loci/callbacks.py @@ -172,6 +172,9 @@ def display_igv(selected_nb_intervals_str, selected_tracks, homepage_is_submitte display_tracks = [ track for track in track_info if selected_tracks and track['name'] in selected_tracks] + selected_nb_intervals_str = lift_over_util.to_genomic_interval(selected_nb_intervals_str) + selected_nb_intervals_str = str(selected_nb_intervals_str.chrom) + ':' + str(selected_nb_intervals_str.start) + '-' + str(selected_nb_intervals_str.stop) + return html.Div([ dashbio.Igv( id='igv-Nipponbare-local', From a8872a918f77cce1179b246865b53aab086d8a1f Mon Sep 17 00:00:00 2001 From: unknown Date: Mon, 11 Sep 2023 22:27:06 +0800 Subject: [PATCH 4/4] Hide coexpression node data div --- pages/analysis/co_expr.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pages/analysis/co_expr.py b/pages/analysis/co_expr.py index 7599ef1a..f3c603dd 100644 --- a/pages/analysis/co_expr.py +++ b/pages/analysis/co_expr.py @@ -495,7 +495,7 @@ ] ), - html.Div(id='coexpression-module-graph-node-data'), + html.Div(id='coexpression-module-graph-node-data', hidden=True), dcc.Loading([ cyto.Cytoscape(