From d8b6a1a0ba8e28ceac14240487698fb396825255 Mon Sep 17 00:00:00 2001 From: MinRK Date: Tue, 25 Feb 2014 19:08:43 -0800 Subject: [PATCH] don't validate ContainerWidget.children just use a plain Tuple, so we don't have to define a new Trait --- IPython/html/widgets/widget_container.py | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/IPython/html/widgets/widget_container.py b/IPython/html/widgets/widget_container.py index 92a7f9c0f..ccbe4d8b2 100644 --- a/IPython/html/widgets/widget_container.py +++ b/IPython/html/widgets/widget_container.py @@ -14,27 +14,20 @@ Represents a container that can be used to group other widgets. # Imports #----------------------------------------------------------------------------- from .widget import DOMWidget -from IPython.utils.traitlets import Unicode, Tuple, Instance, TraitError +from IPython.utils.traitlets import Unicode, Tuple, TraitError #----------------------------------------------------------------------------- # Classes #----------------------------------------------------------------------------- -class TupleOfDOMWidgets(Tuple): - """Like Tuple(Instance(DOMWidget)), but without checking length.""" - def validate_elements(self, obj, value): - for v in value: - if not isinstance(v, DOMWidget): - raise TraitError("Container.children must be DOMWidgets, not %r" % v) - return value - class ContainerWidget(DOMWidget): _view_name = Unicode('ContainerView', sync=True) - # Keys, all private and managed by helper methods. Flexible box model - # classes... - children = TupleOfDOMWidgets() - _children = TupleOfDOMWidgets(sync=True) + # Child widgets in the container. + # Using a tuple here to force reassignment to update the list. + # When a proper notifying-list trait exists, that is what should be used here. + children = Tuple() + _children = Tuple(sync=True) def _children_changed(self, name, old, new): """Validate children list.