Source code for data_morph.plotting.style

"""Utility functions for styling Matplotlib plots."""

from collections.abc import Generator
from contextlib import contextmanager
from functools import wraps
from importlib.resources import as_file, files
from pathlib import Path
from typing import Any, Callable

import matplotlib.pyplot as plt

from .. import MAIN_DIR


[docs] @contextmanager def style_context() -> Generator[None, None, None]: """Context manager for plotting in a custom style.""" style = files(MAIN_DIR).joinpath( Path('plotting') / 'config' / 'plot_style.mplstyle' ) with ( as_file(style) as style_path, plt.style.context(['seaborn-v0_8-darkgrid', style_path]), ): yield
[docs] def plot_with_custom_style(plotting_function: Callable) -> Callable: """ Wrap a plotting function with a context manager to set the plot style. Parameters ---------- plotting_function : Callable The plotting function. Returns ------- Callable The decorated plotting function. """ @wraps(plotting_function) @style_context() def plot_in_style(*args: Any, **kwargs: Any) -> Any: # noqa: ANN401 """ Use a context manager to set the plot style before running the plotting function. Parameters ---------- *args Positional arguments to pass to the plotting function. **kwargs Keyword arguments to pass to the plotting function. Returns ------- any Output of calling the plotting function. """ return plotting_function(*args, **kwargs) return plot_in_style