Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace HoloViews widgets with Panel #3836

Merged
merged 43 commits into from
Aug 15, 2019
Merged
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
706b09c
Replace HoloViews widgets with Panel
philippjfr Jul 19, 2019
2cfd3f7
Various fixes for rendering widgets
philippjfr Jul 21, 2019
eac5d26
Removed widgets module from setup.py
philippjfr Jul 21, 2019
6271d9a
Fixed flakes
philippjfr Jul 21, 2019
3a035a4
Small widget rendering fix
philippjfr Jul 24, 2019
937d305
Use Panel to generate HTML output (#3851)
jonmmease Jul 26, 2019
8238ee4
Fixed saving
philippjfr Jul 26, 2019
be57b32
Cleanup of extension loading
philippjfr Aug 5, 2019
f3450c9
Handle fps on scrubber
philippjfr Aug 5, 2019
309f735
Fixed flakes
philippjfr Aug 5, 2019
1e877d0
Removed further files
philippjfr Aug 5, 2019
5e50912
Update holoviews/plotting/renderer.py
philippjfr Aug 5, 2019
9498e4a
Generalized Renderer methods
philippjfr Aug 9, 2019
880e653
Updated nbpublisher submodule reference
philippjfr Aug 9, 2019
d541c7d
Temporarily disable gallery builds [doc-build]
philippjfr Aug 9, 2019
1d7395e
Various rendering fixes
philippjfr Aug 12, 2019
c2c2eef
Fixed flake
philippjfr Aug 13, 2019
628ccf7
Various Renderer fixes
philippjfr Aug 14, 2019
d73a3ed
Set panel doc rendering flags
philippjfr Aug 14, 2019
01a68c4
Fixed flakes
philippjfr Aug 14, 2019
b75d670
Fixed tests
philippjfr Aug 14, 2019
9470dba
Renderer fixes
philippjfr Aug 14, 2019
826effd
Fixed flakes
philippjfr Aug 14, 2019
3788b03
Exposed control over widget layout
philippjfr Aug 14, 2019
e149584
Refactored update handling
philippjfr Aug 14, 2019
35ddabf
Refactored Renderer.__call__
philippjfr Aug 14, 2019
bfecff2
Further renderer cleanup
philippjfr Aug 14, 2019
131164d
Server fixes
philippjfr Aug 14, 2019
1c9fd60
Correctly set theme
philippjfr Aug 14, 2019
51c2944
Fixed py2 imports
philippjfr Aug 14, 2019
f2d87a8
Rendering improvements and tests
philippjfr Aug 15, 2019
bd77a54
Fixed bokeh server tests
philippjfr Aug 15, 2019
6c418bb
Test fixes
philippjfr Aug 15, 2019
fb4c4dd
Small fixes for bokeh renderer tests
philippjfr Aug 15, 2019
98d185d
Fixes for bokeh render tests
philippjfr Aug 15, 2019
b310c36
Added plotly and matplotlib tests
philippjfr Aug 15, 2019
8596ee5
Update holoviews/tests/plotting/bokeh/testrenderer.py
philippjfr Aug 15, 2019
bd22d5c
Factored out generic AdjointLayoutPlot
philippjfr Aug 15, 2019
f5ba343
Fixes for Renderer tests
philippjfr Aug 15, 2019
bb38e2e
Flake fixes
philippjfr Aug 15, 2019
0e57ccd
Addressed review comments
philippjfr Aug 15, 2019
274a6b2
Increase server test timeout
philippjfr Aug 15, 2019
ce52f5e
Improved document and server handling
philippjfr Aug 15, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -142,7 +142,7 @@ jobs:
- &doc_build
<<: *default
stage: docs_dev
env: DESC="docs" CHANS_DEV="-c pyviz/label/dev" HV_DOC_GALLERY='false' HV_REQUIREMENTS="doc"
env: DESC="docs" CHANS_DEV="-c pyviz/label/dev" HV_DOC_GALLERY='false' HV_DOC_REF_GALLERY='false' HV_REQUIREMENTS="doc" PANEL_EMBED='true' PANEL_EMBED_JSON='true' PANEL_EMBED_JSON_PREFIX='json'
script:
- bokeh sampledata
- conda install -c conda-forge awscli
Expand Down Expand Up @@ -171,7 +171,7 @@ jobs:

- <<: *gallery_build
stage: gallery_daily
env: DESC="gallery" CHANS_DEV="-c pyviz/label/dev" HV_DOC_GALLERY='true' HV_REQUIREMENTS="doc" BUCKET="build."
env: DESC="gallery" CHANS_DEV="-c pyviz/label/dev" HV_DOC_GALLERY='false' HV_DOC_REF_GALLERY='false' HV_REQUIREMENTS="doc" BUCKET="build."

- <<: *doc_build
stage: docs
Expand Down
2 changes: 1 addition & 1 deletion doc/nbpublisher
2 changes: 1 addition & 1 deletion examples/user_guide/17-Dashboards.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,7 @@
"\n",
"smoothed = rolling(stock_dmap, rolling_window=rolling_window.param.value)\n",
"\n",
"pn.Row(pn.WidgetBox('## Stock Explorer', symbol, variable, window), smoothed.opts(width=500))"
"pn.Row(pn.WidgetBox('## Stock Explorer', symbol, variable, rolling_window), smoothed.opts(width=500))"
]
},
{
Expand Down
4 changes: 2 additions & 2 deletions examples/user_guide/Plots_and_Renderers.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -374,7 +374,7 @@
"cell_type": "markdown",
"metadata": {},
"source": [
"Rendering plots containing ``HoloMap`` and ``DynamicMap`` objects will automatically generate a widget class instance, which you can get a handle on with the ``get_widget`` method:"
"Rendering plots containing ``HoloMap`` and ``DynamicMap`` objects will automatically generate a Panel HoloViews pane which can be rendered in the notebook, saved or rendered as a server app:"
]
},
{
Expand All @@ -401,7 +401,7 @@
"metadata": {},
"outputs": [],
"source": [
"display_html(renderer.static_html(holomap), raw=True)"
"html = renderer.static_html(holomap)"
]
},
{
Expand Down
30 changes: 7 additions & 23 deletions holoviews/core/util.py
Original file line number Diff line number Diff line change
@@ -1,23 +1,23 @@
import os, sys, warnings, operator
import sys, warnings, operator
import json
import time
import types
import numbers
import inspect
import itertools
import string, fnmatch
import string
import unicodedata
import datetime as dt
from collections import defaultdict

from distutils.version import LooseVersion as _LooseVersion
from functools import partial
from collections import defaultdict
from contextlib import contextmanager
from distutils.version import LooseVersion as _LooseVersion

from threading import Thread, Event

import numpy as np
import param

import json

try:
from cyordereddict import OrderedDict
except:
Expand Down Expand Up @@ -1407,22 +1407,6 @@ def get_spec(obj):
obj.group, obj.label)


def find_file(folder, filename):
"""
Find a file given folder and filename. If the filename can be
resolved directly returns otherwise walks the supplied folder.
"""
matches = []
if os.path.isabs(filename) and os.path.isfile(filename):
return filename
for root, _, filenames in os.walk(folder):
for fn in fnmatch.filter(filenames, filename):
matches.append(os.path.join(root, fn))
if not matches:
raise IOError('File %s could not be found' % filename)
return matches[-1]


def is_dataframe(data):
"""
Checks whether the supplied data is of DataFrame type.
Expand Down
29 changes: 5 additions & 24 deletions holoviews/ipython/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,13 @@
from IPython.core.completer import IPCompleter
from IPython.display import HTML, publish_display_data
from param import ipython as param_ext
from pyviz_comms import nb_mime_js

from ..core.dimension import LabelledData
from ..core.tree import AttrTree
from ..core.options import Store
from ..element.comparison import ComparisonTestCase
from ..util import extension
from ..plotting.renderer import Renderer, MIME_TYPES
from ..plotting.renderer import Renderer
from .magics import load_magics
from .display_hooks import display # noqa (API import)
from .display_hooks import pprint_display, png_display, svg_display
Expand Down Expand Up @@ -172,15 +171,16 @@ def __call__(self, *args, **params):
css += '<style>div.container { width: %s%% }</style>' % p.width
if p.css:
css += '<style>%s</style>' % p.css

if css:
display(HTML(css))

resources = list(resources)
if len(resources) == 0: return

Renderer.load_nb()
for r in [r for r in resources if r != 'holoviews']:
Store.renderers[r].load_nb(inline=p.inline)
Renderer.load_nb()

if hasattr(ip, 'kernel') and not loaded:
Renderer.comm_manager.get_client_comm(notebook_extension._process_comm_msg,
Expand All @@ -191,8 +191,7 @@ def __call__(self, *args, **params):
bokeh_logo= p.logo and ('bokeh' in resources),
mpl_logo= p.logo and (('matplotlib' in resources)
or resources==['holoviews']),
plotly_logo= p.logo and ('plotly' in resources),
JS=('holoviews' in resources))
plotly_logo= p.logo and ('plotly' in resources))

@classmethod
def completions_sorting_key(cls, word):
Expand Down Expand Up @@ -246,35 +245,17 @@ def load_hvjs(cls, logo=False, bokeh_logo=False, mpl_logo=False, plotly_logo=Fal
Displays javascript and CSS to initialize HoloViews widgets.
"""
import jinja2
# Evaluate load_notebook.html template with widgetjs code
if JS:
widgetjs, widgetcss = Renderer.html_assets(extras=False, backends=[], script=True)
else:
widgetjs, widgetcss = '', ''

# Add classic notebook MIME renderer
widgetjs += nb_mime_js

templateLoader = jinja2.FileSystemLoader(os.path.dirname(os.path.abspath(__file__)))
jinjaEnv = jinja2.Environment(loader=templateLoader)
template = jinjaEnv.get_template('load_notebook.html')
html = template.render({'widgetcss': widgetcss,
'logo': logo,
html = template.render({'logo': logo,
'bokeh_logo': bokeh_logo,
'mpl_logo': mpl_logo,
'plotly_logo': plotly_logo,
'message': message})
publish_display_data(data={'text/html': html})

# Vanilla JS mime type is only consumed by classic notebook
# Custom mime type is only consumed by JupyterLab
if JS:
mimebundle = {
MIME_TYPES['js'] : widgetjs,
MIME_TYPES['jlab-hv-load'] : widgetjs
}
publish_display_data(data=mimebundle)


@param.parameterized.bothmethod
def tab_completion_docstring(self_or_cls):
Expand Down
2 changes: 0 additions & 2 deletions holoviews/ipython/load_notebook.html
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
{{ widgetcss }}

{% if logo %}
<div class="logo-block">
<img src='
Expand Down
12 changes: 0 additions & 12 deletions holoviews/plotting/bokeh/bokehwidgets.css

This file was deleted.

68 changes: 0 additions & 68 deletions holoviews/plotting/bokeh/bokehwidgets.js

This file was deleted.

70 changes: 0 additions & 70 deletions holoviews/plotting/bokeh/plot.py
Original file line number Diff line number Diff line change
Expand Up @@ -78,50 +78,10 @@ class BokehPlot(DimensionedPlot):

backend = 'bokeh'

@property
def document(self):
return self._document

@property
def id(self):
return self.root.ref['id'] if self.root else None

@property
def root(self):
if self._root:
return self._root
elif 'plot' in self.handles and self.top_level:
return self.state
else:
return None

@document.setter
def document(self, doc):
if (doc and hasattr(doc, 'on_session_destroyed') and
self.root is self.handles.get('plot') and not isinstance(self, AdjointLayoutPlot)):
doc.on_session_destroyed(self._session_destroy)
if self._document:
if isinstance(self._document._session_destroyed_callbacks, set):
self._document._session_destroyed_callbacks.discard(self._session_destroy)
else:
self._document._session_destroyed_callbacks.pop(self._session_destroy, None)

self._document = doc
if self.subplots:
for plot in self.subplots.values():
if plot is not None:
plot.document = doc


def _session_destroy(self, session_context):
self.cleanup()

def __init__(self, *args, **params):
root = params.pop('root', None)
super(BokehPlot, self).__init__(*args, **params)
self._document = None
self._root = root


def get_data(self, element, ranges, style):
"""
Expand Down Expand Up @@ -176,36 +136,6 @@ def _construct_callbacks(self):
cbs.append(cb(self, cb_streams, source))
return cbs

def refresh(self, **kwargs):
if self.renderer.mode == 'server' and curdoc() is not self.document:
# If we do not have the Document lock, schedule refresh as callback
self.document.add_next_tick_callback(self.refresh)
else:
super(BokehPlot, self).refresh(**kwargs)

def push(self):
"""
Pushes updated plot data via the Comm.
"""
if self.renderer.mode == 'server':
return
if self.comm is None:
raise Exception('Renderer does not have a comm.')

if self._root and 'embedded' in self._root.tags:
# Allows external libraries to prevent comm updates
return

msg = self.renderer.diff(self, binary=True)
if msg is None:
return
self.comm.send(msg.header_json)
self.comm.send(msg.metadata_json)
self.comm.send(msg.content_json)
for header, payload in msg.buffers:
self.comm.send(json.dumps(header))
self.comm.send(buffers=[payload])


def set_root(self, root):
"""
Expand Down
Loading