feat: drug timeline Gantt chart tab (Task D.3)

This commit is contained in:
Andrew Charlwood
2026-02-07 03:40:29 +00:00
parent 3b1de4933f
commit 0a14f1fce3
6 changed files with 240 additions and 5 deletions
+28
View File
@@ -367,6 +367,31 @@ def _render_network(app_state, title):
return create_drug_network_figure(data, title)
def _render_timeline(app_state, title):
"""Build the drug timeline Gantt chart from current filter state."""
from dash_app.data.queries import get_drug_timeline
from visualization.plotly_generator import create_drug_timeline_figure
filter_id = (app_state or {}).get("date_filter_id", "all_6mo")
chart_type = (app_state or {}).get("chart_type", "directory")
selected_dirs = (app_state or {}).get("selected_directorates") or []
selected_trusts = (app_state or {}).get("selected_trusts") or []
directory = selected_dirs[0] if len(selected_dirs) == 1 else None
trust = selected_trusts[0] if len(selected_trusts) == 1 else None
try:
data = get_drug_timeline(filter_id, chart_type, directory, trust)
except Exception:
log.exception("Failed to load drug timeline data")
return _empty_figure("Failed to load drug timeline data.")
if not data:
return _empty_figure("No drug timeline data available.\nTry adjusting your filters.")
return create_drug_timeline_figure(data, title)
def register_chart_callbacks(app):
"""Register tab switching, pathway data loading, and chart rendering callbacks."""
@@ -519,6 +544,9 @@ def register_chart_callbacks(app):
elif active_tab == "network":
fig = _render_network(app_state, title)
elif active_tab == "timeline":
fig = _render_timeline(app_state, title)
else:
# Placeholder for charts not yet implemented
tab_label = dict(TAB_DEFINITIONS).get(active_tab, active_tab)
+1
View File
@@ -12,6 +12,7 @@ TAB_DEFINITIONS = [
("depth", "Depth"),
("scatter", "Scatter"),
("network", "Network"),
("timeline", "Timeline"),
]
# Full set retained for Trust Comparison dashboard (Phase 10.8)
+11
View File
@@ -28,6 +28,7 @@ from data_processing.pathway_queries import (
get_pathway_depth_distribution as _get_pathway_depth_distribution,
get_duration_cost_scatter as _get_duration_cost_scatter,
get_drug_network as _get_drug_network,
get_drug_timeline as _get_drug_timeline,
)
DB_PATH = Path(__file__).resolve().parents[2] / "data" / "pathways.db"
@@ -227,3 +228,13 @@ def get_drug_network(
) -> dict:
"""Undirected drug co-occurrence network for network graph."""
return _get_drug_network(DB_PATH, date_filter_id, chart_type, directory, trust)
def get_drug_timeline(
date_filter_id: str = "all_6mo",
chart_type: str = "directory",
directory: Optional[str] = None,
trust: Optional[str] = None,
) -> list[dict]:
"""Drug timeline data (first_seen, last_seen) for Gantt chart."""
return _get_drug_timeline(DB_PATH, date_filter_id, chart_type, directory, trust)