Skip to content

Commit

Permalink
populate missing API docs for plugin user APIs
Browse files Browse the repository at this point in the history
  • Loading branch information
kecnry committed Feb 2, 2024
1 parent 2843859 commit 54a4e1f
Show file tree
Hide file tree
Showing 10 changed files with 114 additions and 20 deletions.
5 changes: 4 additions & 1 deletion lcviz/plugins/binning/binning.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 +33,16 @@ class Binning(PluginTemplateMixin, FluxColumnSelectMixin, DatasetSelectMixin,
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``dataset`` (:class:`~jdaviz.core.template_mixin.DatasetSelect`):
Dataset to bin.
* ``ephemeris`` (:class:`~jdaviz.core.template_mixin.SelectPluginComponent`):
Label of the component corresponding to the active ephemeris.
* :meth:`input_lc`
Data used as input to binning, based on ``dataset`` and ``ephemeris``.
* ``n_bins``
* ``n_bins`` : int
* ``add_results`` (:class:`~jdaviz.core.template_mixin.AddResults`)
* :meth:`bin`
"""
Expand Down
11 changes: 7 additions & 4 deletions lcviz/plugins/ephemeris/ephemeris.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,15 +32,18 @@ class Ephemeris(PluginTemplateMixin, DatasetSelectMixin):
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``component`` (:class:`~jdaviz.template_mixin.EditableSelectPluginComponent`):
Label of the component corresponding to the active ephemeris.
* :attr:`t0`:
* :attr:`t0` : float
Zeropoint of the ephemeris.
* :attr:`period`:
* :attr:`period` : float
Period of the ephemeris, defined at ``t0``.
* :attr:`dpdt`:
* :attr:`dpdt` : float
First derivative of the period of the ephemeris.
* :attr:`wrap_at`:
* :attr:`wrap_at` : float
Phase at which to wrap (phased data will encompass the range 1-wrap_at to wrap_at).
* :meth:`ephemeris`
* :meth:`ephemerides`
Expand Down
13 changes: 13 additions & 0 deletions lcviz/plugins/export_plot/export_plot.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,19 @@

@tray_registry('lcviz-export-plot', label="Export Plot")
class ExportViewer(ExportViewer):
"""
See the :ref:`Export Plot Plugin Documentation <export-plot>` for more details.
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``viewer`` (:class:`~jdaviz.core.template_mixin.ViewerSelect`):
Viewer to select for exporting the figure image.
* :meth:`save_figure`
"""
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.docs_link = f"https://lcviz.readthedocs.io/en/{self.vdocs}/plugins.html#export-plot"
15 changes: 9 additions & 6 deletions lcviz/plugins/flatten/flatten.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,18 +30,21 @@ class Flatten(PluginTemplateMixin, FluxColumnSelectMixin, DatasetSelectMixin):
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``show_live_preview`` : bool
Whether to show the live-preview of the (unnormalized) flattened light curve
* ``show_trend_preview`` : bool
Whether to show the live-preview of the trend curve used to flatten the light curve
* ``dataset`` (:class:`~jdaviz.core.template_mixin.DatasetSelect`):
Dataset to flatten.
* ``window_length``
* ``polyorder``
* ``break_tolerance``
* ``niters``
* ``sigma``
* ``unnormalize``
* ``window_length`` : int
* ``polyorder`` : int
* ``break_tolerance`` : int
* ``niters`` : int
* ``sigma`` : float
* ``unnormalize`` : bool
* ``flux_label`` (:class:`~jdaviz.core.template_mixin.AutoTextField`):
Label for the resulting flux column added to ``dataset`` and automatically selected as the new
flux column (origin).
Expand Down
3 changes: 3 additions & 0 deletions lcviz/plugins/flux_column/flux_column.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,9 @@ class FluxColumn(PluginTemplateMixin, FluxColumnSelectMixin, DatasetSelectMixin)
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``dataset`` (:class:`~jdaviz.core.template_mixin.DatasetSelect`):
Dataset to bin.
* ``flux_column`` (:class:`~lcviz.components.FluxColumnSelect`)
Expand Down
9 changes: 6 additions & 3 deletions lcviz/plugins/frequency_analysis/frequency_analysis.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,15 +24,18 @@ class FrequencyAnalysis(PluginTemplateMixin, DatasetSelectMixin, PlotMixin):
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``dataset`` (:class:`~jdaviz.core.template_mixin.DatasetSelect`):
Dataset to use for analysis.
* ``method`` (:class:`~jdaviz.core.template_mixing.SelectPluginComponent`):
Method/algorithm to determine the period.
* ``xunit`` (:class:`~jdaviz.core.template_mixing.SelectPluginComponent`):
Whether to plot power vs fequency or period.
* ``auto_range``
* ``minimum``
* ``maximum``
* ``auto_range`` : bool
* ``minimum`` : float
* ``maximum`` : float
* :meth:``periodogram``
"""
template_file = __file__, "frequency_analysis.vue"
Expand Down
12 changes: 12 additions & 0 deletions lcviz/plugins/markers/markers.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,18 @@

@tray_registry('lcviz-markers', label="Markers")
class Markers(Markers):
"""
See the :ref:`Markers Plugin Documentation <markers>` for more details.
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* :meth:`clear_table`
* :meth:`~jdaviz.core.template_mixin.TableMixin.export_table`
"""
_default_table_values = {'time': np.nan,
'phase': np.nan,
'ephemeris': '',
Expand Down
19 changes: 19 additions & 0 deletions lcviz/plugins/metadata_viewer/metadata_viewer.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,25 @@

@tray_registry('lcviz-metadata-viewer', label="Metadata")
class MetadataViewer(MetadataViewer):
"""
See the :ref:`Metadata Viewer Plugin Documentation <metadata-viewer>` for more details.
Only the following attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``dataset`` (:class:`~jdaviz.core.template_mixin.DatasetSelect`):
Dataset to expose the metadata.
* :attr:`show_primary` : bool
Whether to show MEF primary header metadata instead.
* :attr:`metadata`:
Read-only metadata. If the data is loaded from a multi-extension FITS file,
this can be the extension header or the primary header, depending on
``show_primary`` setting.
"""
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.docs_link = f"https://lcviz.readthedocs.io/en/{self.vdocs}/plugins.html#metadata-viewer" # noqa
37 changes: 31 additions & 6 deletions lcviz/plugins/plot_options/plot_options.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,43 @@

@tray_registry('lcviz-plot-options', label="Plot Options")
class PlotOptions(PlotOptions):
"""
See the :ref:`Plot Options Plugin Documentation <plot-options>` for more details.
For a full list of exposed attributes, call ``dir(plugin)``. Note that some attributes are
applicable depending on the selection of ``viewer`` and/or ``layer``. Below are
a list of some common attributes and methods are available through the
public plugin API.
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
* ``viewer`` (:class:`~jdaviz.core.template_mixin.ViewerSelect`):
* ``viewer_multiselect``
* ``layer`` (:class:`~jdaviz.core.template_mixin.LayerSelect`):
* ``layer_multiselect``
* :meth:`select_all`
* ``subset_color`` (:class:`~jdaviz.core.template_mixin.PlotOptionsSyncState`):
* ``line_color`` (:class:`~jdaviz.core.template_mixin.PlotOptionsSyncState`):
* ``line_width`` (:class:`~jdaviz.core.template_mixin.PlotOptionsSyncState`):
* ``line_opacity`` (:class:`~jdaviz.core.template_mixin.PlotOptionsSyncState`):
"""
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.docs_link = f"https://lcviz.readthedocs.io/en/{self.vdocs}/plugins.html#plot-options"

@property
def user_api(self):
api = super().user_api
api._expose += ['marker_visible', 'marker_fill', 'marker_opacity',
'marker_size_mode', 'marker_size', 'marker_size_scale',
'marker_size_col', 'marker_size_vmin', 'marker_size_vmax',
'marker_color_mode', 'marker_color', 'marker_color_col',
'marker_colormap', 'marker_colormap_vmin', 'marker_colormap_vmax',
'line_visible', 'line_width']
expose = [e for e in api._expose if e not in ('apply_RGB_presets', 'line_as_steps',
'uncertainty_visible')]

expose += ['marker_visible', 'marker_fill', 'marker_opacity',
'marker_size_mode', 'marker_size', 'marker_size_scale',
'marker_size_col', 'marker_size_vmin', 'marker_size_vmax',
'marker_color_mode', 'marker_color', 'marker_color_col',
'marker_colormap', 'marker_colormap_vmin', 'marker_colormap_vmax',
'line_visible', 'line_width']
api._expose = expose

return api
10 changes: 10 additions & 0 deletions lcviz/plugins/subset_plugin/subset_plugin.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,16 @@

@tray_registry('lcviz-subset-plugin', label="Subset Tools")
class SubsetPlugin(SubsetPlugin):
"""
See the :ref:`Subset Plugin Documentation <subset-tools>` for more details.
Only the following attributes and methods are available through the
:ref:`public plugin API <plugin-apis>`:
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.show`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.open_in_tray`
* :meth:`~jdaviz.core.template_mixin.PluginTemplateMixin.close_in_tray`
"""
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.docs_link = f"https://lcviz.readthedocs.io/en/{self.vdocs}/plugins.html#subset-tools"
Expand Down

0 comments on commit 54a4e1f

Please sign in to comment.