2013-10-26 02:31:48 +08:00
|
|
|
"""ButtonWidget class.
|
|
|
|
|
|
|
|
Represents a button in the frontend using a widget. Allows user to listen for
|
|
|
|
click events on the button and trigger backend code when the clicks are fired.
|
|
|
|
"""
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
# Copyright (c) 2013, the IPython Development Team.
|
|
|
|
#
|
|
|
|
# Distributed under the terms of the Modified BSD License.
|
|
|
|
#
|
|
|
|
# The full license is in the file COPYING.txt, distributed with this software.
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
# Imports
|
|
|
|
#-----------------------------------------------------------------------------
|
2013-10-22 06:21:34 +08:00
|
|
|
import inspect
|
|
|
|
import types
|
|
|
|
|
2014-01-07 20:04:24 +08:00
|
|
|
from .widget import DOMWidget
|
2014-01-16 19:42:38 +08:00
|
|
|
from IPython.utils.traitlets import Unicode, Bool
|
2013-10-22 04:02:17 +08:00
|
|
|
|
2013-10-26 02:31:48 +08:00
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
# Classes
|
|
|
|
#-----------------------------------------------------------------------------
|
2014-01-07 20:04:24 +08:00
|
|
|
class ButtonWidget(DOMWidget):
|
2014-01-14 23:21:35 +08:00
|
|
|
view_name = Unicode('ButtonView', sync=True)
|
2013-10-26 02:31:48 +08:00
|
|
|
|
|
|
|
# Keys
|
2014-01-14 23:15:19 +08:00
|
|
|
description = Unicode('', help="Description of the button (label).", sync=True)
|
|
|
|
disabled = Bool(False, help="Enable or disable user changes.", sync=True)
|
2013-10-22 04:02:17 +08:00
|
|
|
|
2013-11-02 05:15:28 +08:00
|
|
|
def __init__(self, **kwargs):
|
2014-01-16 22:20:04 +08:00
|
|
|
"""Constructor"""
|
2013-11-02 05:15:28 +08:00
|
|
|
super(ButtonWidget, self).__init__(**kwargs)
|
2013-11-22 07:44:49 +08:00
|
|
|
|
|
|
|
self._click_handlers = []
|
|
|
|
self.on_msg(self._handle_button_msg)
|
2013-10-22 04:02:17 +08:00
|
|
|
|
2013-10-22 06:21:34 +08:00
|
|
|
def on_click(self, callback, remove=False):
|
2014-01-16 22:20:04 +08:00
|
|
|
"""Register a callback to execute when the button is clicked.
|
|
|
|
|
|
|
|
The callback can either accept no parameters or one sender parameter:
|
2013-11-05 07:53:41 +08:00
|
|
|
- callback()
|
|
|
|
- callback(sender)
|
|
|
|
If the callback has a sender parameter, the ButtonWidget instance that
|
|
|
|
called the callback will be passed into the method as the sender.
|
2013-10-26 02:31:48 +08:00
|
|
|
|
|
|
|
Parameters
|
|
|
|
----------
|
|
|
|
remove : bool (optional)
|
2013-11-05 07:53:41 +08:00
|
|
|
Set to true to remove the callback from the list of callbacks."""
|
2013-10-22 04:02:17 +08:00
|
|
|
if remove:
|
|
|
|
self._click_handlers.remove(callback)
|
2013-11-07 01:41:46 +08:00
|
|
|
elif not callback in self._click_handlers:
|
2013-10-22 04:02:17 +08:00
|
|
|
self._click_handlers.append(callback)
|
|
|
|
|
2013-11-22 07:44:49 +08:00
|
|
|
def _handle_button_msg(self, content):
|
2014-01-16 22:20:04 +08:00
|
|
|
"""Handle a msg from the front-end.
|
2013-11-22 07:44:49 +08:00
|
|
|
|
|
|
|
Parameters
|
|
|
|
----------
|
|
|
|
content: dict
|
|
|
|
Content of the msg."""
|
|
|
|
if 'event' in content and content['event'] == 'click':
|
|
|
|
self._handle_click()
|
|
|
|
|
|
|
|
def _handle_click(self):
|
2014-01-16 22:20:04 +08:00
|
|
|
"""Handles when the button has been clicked.
|
|
|
|
|
|
|
|
Fires on_click callbacks when appropriate."""
|
2013-11-22 07:44:49 +08:00
|
|
|
for handler in self._click_handlers:
|
|
|
|
if callable(handler):
|
|
|
|
argspec = inspect.getargspec(handler)
|
|
|
|
nargs = len(argspec[0])
|
|
|
|
|
|
|
|
# Bound methods have an additional 'self' argument
|
|
|
|
if isinstance(handler, types.MethodType):
|
|
|
|
nargs -= 1
|
|
|
|
|
|
|
|
# Call the callback
|
|
|
|
if nargs == 0:
|
|
|
|
handler()
|
|
|
|
elif nargs == 1:
|
|
|
|
handler(self)
|
|
|
|
else:
|
|
|
|
raise TypeError('ButtonWidget click callback must ' \
|
|
|
|
'accept 0 or 1 arguments.')
|