From 7b3020024dcb32d4ee48df9ab3f10627679b85d5 Mon Sep 17 00:00:00 2001 From: James Varndell <36902610+JamesVarndell@users.noreply.github.com> Date: Sun, 17 Nov 2024 17:34:18 +0000 Subject: [PATCH] Feature/vertical plots (#26) * Moves interactive plots into earthkit.plots.interactive * Adds plotly to requirements * Moves interactive plots into earthkit.plots.interactive * Remove empty notebook * QA tweaks * Adds default style to improve look and feel with >5 quantiles * Adds default style to improve look and feel with >5 quantiles * Adds docstrings * Adds tests for interactive plots * QA tweaks * Adds better support for interactive vertical plots --- src/earthkit/plots/interactive/charts.py | 36 +++++++++++++++++------- 1 file changed, 26 insertions(+), 10 deletions(-) diff --git a/src/earthkit/plots/interactive/charts.py b/src/earthkit/plots/interactive/charts.py index 1193dbe..2973436 100644 --- a/src/earthkit/plots/interactive/charts.py +++ b/src/earthkit/plots/interactive/charts.py @@ -72,6 +72,7 @@ def __init__(self, rows=None, columns=None, **kwargs): self._subplots_kwargs = kwargs self._subplot_titles = None self._subplot_y_titles = None + self._subplot_x_titles = None self._layout_override = dict() def set_subplot_titles(method): @@ -84,10 +85,14 @@ def wrapper(self, *args, **kwargs): pass else: self._subplot_titles = list(ds.data_vars) - self._subplot_y_titles = [ + titles = [ ds[data_var].attrs.get("units", "") for data_var in ds.data_vars ] + if kwargs.get("y") is not None: + self._subplot_x_titles = titles + else: + self._subplot_y_titles = titles return method(self, *args, **kwargs) return wrapper @@ -286,13 +291,24 @@ def show(self, *args, **kwargs): for i in range(self.rows * self.columns): y_key = f"yaxis{i+1 if i>0 else ''}" x_key = f"xaxis{i+1 if i>0 else ''}" - self.fig.update_layout( - **{ - x_key: layout["xaxis"], - y_key: { - **layout["yaxis"], - **{"title": self._subplot_y_titles[i]}, - }, - } - ) + if self._subplot_x_titles: + self.fig.update_layout( + **{ + y_key: layout["yaxis"], + x_key: { + **layout["xaxis"], + **{"title": self._subplot_x_titles[i]}, + }, + } + ) + if self._subplot_y_titles: + self.fig.update_layout( + **{ + x_key: layout["xaxis"], + y_key: { + **layout["yaxis"], + **{"title": self._subplot_y_titles[i]}, + }, + } + ) return self.fig.show(*args, **kwargs)