widget_string.py
93 lines
| 3.2 KiB
| text/x-python
|
PythonLexer
Jonathan Frederic
|
r14283 | """StringWidget class. | ||
Represents a unicode string using a widget. | ||||
""" | ||||
#----------------------------------------------------------------------------- | ||||
# 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 | ||||
#----------------------------------------------------------------------------- | ||||
Jonathan Frederic
|
r14391 | import inspect | ||
import types | ||||
Jonathan Frederic
|
r14540 | from .widget import DOMWidget | ||
Jonathan Frederic
|
r14391 | from IPython.utils.traitlets import Unicode, Bool, List, Int | ||
Jonathan Frederic
|
r14243 | |||
Jonathan Frederic
|
r14283 | #----------------------------------------------------------------------------- | ||
# Classes | ||||
#----------------------------------------------------------------------------- | ||||
Jonathan Frederic
|
r14540 | class StringWidget(DOMWidget): | ||
Jonathan Frederic
|
r14243 | target_name = Unicode('StringWidgetModel') | ||
Jonathan Frederic
|
r14541 | view_name = Unicode('TextBoxView') | ||
Jonathan Frederic
|
r14283 | |||
# Keys | ||||
Jonathan Frederic
|
r14540 | keys = ['value', 'disabled', 'description'] + DOMWidget.keys | ||
Jonathan Frederic
|
r14283 | value = Unicode(help="String value") | ||
disabled = Bool(False, help="Enable or disable user changes") | ||||
Jonathan Frederic
|
r14292 | description = Unicode(help="Description of the value this widget represents") | ||
Jonathan Frederic
|
r14391 | |||
def __init__(self, **kwargs): | ||||
super(StringWidget, self).__init__(**kwargs) | ||||
Jonathan Frederic
|
r14402 | self._submission_callbacks = [] | ||
self.on_msg(self._handle_string_msg) | ||||
Jonathan Frederic
|
r14391 | |||
Jonathan Frederic
|
r14393 | def scroll_to_bottom(self): | ||
Jonathan Frederic
|
r14406 | self.send({"method": "scroll_to_bottom"}) | ||
Jonathan Frederic
|
r14393 | |||
Jonathan Frederic
|
r14402 | def _handle_string_msg(self, content): | ||
"""Handle a msg from the front-end | ||||
Parameters | ||||
---------- | ||||
content: dict | ||||
Content of the msg.""" | ||||
if 'event' in content and content['event'] == 'submit': | ||||
self._handle_submit() | ||||
Jonathan Frederic
|
r14391 | def on_submit(self, callback, remove=False): | ||
"""Register a callback to handle text submission (triggered when the | ||||
user clicks enter). | ||||
Parameters | ||||
callback: Method handle | ||||
Function to be called when the text has been submitted. Function | ||||
can have two possible signatures: | ||||
callback() | ||||
callback(sender) | ||||
remove: bool (optional) | ||||
Whether or not to unregister the callback""" | ||||
if remove and callback in self._submission_callbacks: | ||||
self._submission_callbacks.remove(callback) | ||||
elif not remove and not callback in self._submission_callbacks: | ||||
self._submission_callbacks.append(callback) | ||||
Jonathan Frederic
|
r14402 | def _handle_submit(self): | ||
Jonathan Frederic
|
r14391 | """Handles when a string widget view is submitted.""" | ||
Jonathan Frederic
|
r14402 | for handler in self._submission_callbacks: | ||
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('StringWidget submit callback must ' \ | ||||
'accept 0 or 1 arguments.') | ||||