PlotlyExtensionsHelper.jl

Provide a unified way to create plotly based plots that will use the correct dependency depending on the loaded Plotly packages priority
Author disberd
Popularity
0 Stars
Updated Last
2 Months Ago
Started In
February 2024

PlotlyExtensionsHelper

Build Status Aqua QA

The primary objective of this package is to enable package authors to integrate plotting functionality within their packages through extensions that support multiple plotting libraries with a single extension. This package is designed to be compatible with plotting libraries based on PlotlyBase.jl, such as PlotlyBase, PlotlyJS, and PlutoPlotly.

Support for other plotly-based packages might be considered in the future.

The principal way of using this package is to have PlotlyExtensionsHelper as dependency of the target package, and then provide a single extensions with PlotlyBase.jl as trigger. The extension should implement the specific plotting functionality and generate its output (the plot) using PlotlyExtensionsHelper.plotly_plot rather than using PlotlyBase.Plot.

PlotlyExtensionsHelper.plotly_plot will simply forward all argument and keyword arguments provided to it to the relevant function on the 3 supported packages depending on what is loaded and on the priority specified in PlotlyExtensionsHelper.PLOT_FUNC_PRIORITY

The default priority is in this order:

  • PlutoPlotly (highest priority)
  • PlotlyJS
  • PlotlyBase (lowest priority)

You can find a more clarifying example on how to implement plotting in a package using PlotlyExtensionsHelper in the test folder within its ExampleEnvironment subfolder. The example package providing some plotting functionality is within the ExamplePackage folder, while example of its use with seamelss plotting package switching can be checked by either including the test_include.jl file in the REPL, or by opening the test_notebook.jl within Pluto

The first file will use PlotlyJS to show the plot, while the second example (the notebook) will use PlutoPlotly to show the plot.

Required Packages

No packages found.

Used By Packages