diff --git a/IPython/html/widgets/widget_bool.py b/IPython/html/widgets/widget_bool.py index e21ad3d..a6f1ff5 100644 --- a/IPython/html/widgets/widget_bool.py +++ b/IPython/html/widgets/widget_bool.py @@ -26,6 +26,10 @@ class _Bool(DOMWidget): description = Unicode('', help="Description of the boolean (label).", sync=True) disabled = Bool(False, help="Enable or disable user changes.", sync=True) + def __init__(self, value=None, **kwargs): + if value is not None: + kwargs['value'] = value + super(_Bool, self).__init__(**kwargs) @register('IPython.Checkbox') class Checkbox(_Bool): diff --git a/IPython/html/widgets/widget_float.py b/IPython/html/widgets/widget_float.py index eab4f66..506fb03 100644 --- a/IPython/html/widgets/widget_float.py +++ b/IPython/html/widgets/widget_float.py @@ -25,6 +25,10 @@ class _Float(DOMWidget): disabled = Bool(False, help="Enable or disable user changes", sync=True) description = Unicode(help="Description of the value this widget represents", sync=True) + def __init__(self, value=None, **kwargs): + if value is not None: + kwargs['value'] = value + super(_Float, self).__init__(**kwargs) class _BoundedFloat(_Float): max = CFloat(100.0, help="Max value", sync=True) @@ -33,7 +37,7 @@ class _BoundedFloat(_Float): def __init__(self, *pargs, **kwargs): """Constructor""" - DOMWidget.__init__(self, *pargs, **kwargs) + super(_BoundedFloat, self).__init__(*pargs, **kwargs) self._validate('value', None, self.value) self.on_trait_change(self._validate, ['value', 'min', 'max']) diff --git a/IPython/html/widgets/widget_int.py b/IPython/html/widgets/widget_int.py index 582ae03..ff6efdc 100644 --- a/IPython/html/widgets/widget_int.py +++ b/IPython/html/widgets/widget_int.py @@ -26,6 +26,10 @@ class _Int(DOMWidget): disabled = Bool(False, help="Enable or disable user changes", sync=True) description = Unicode(help="Description of the value this widget represents", sync=True) + def __init__(self, value=None, **kwargs): + if value is not None: + kwargs['value'] = value + super(_Int, self).__init__(**kwargs) class _BoundedInt(_Int): """Base class used to create widgets that represent a int that is bounded @@ -36,7 +40,7 @@ class _BoundedInt(_Int): def __init__(self, *pargs, **kwargs): """Constructor""" - DOMWidget.__init__(self, *pargs, **kwargs) + super(_BoundedInt, self).__init__(*pargs, **kwargs) self.on_trait_change(self._validate_value, ['value']) self.on_trait_change(self._handle_max_changed, ['max']) self.on_trait_change(self._handle_min_changed, ['min']) @@ -104,7 +108,7 @@ class _IntRange(_Int): if lower_given != upper_given: raise ValueError("Must specify both 'lower' and 'upper' for range widget") - DOMWidget.__init__(self, *pargs, **kwargs) + super(_IntRange, self).__init__(*pargs, **kwargs) # ensure the traits match, preferring whichever (if any) was given in kwargs if value_given: diff --git a/IPython/html/widgets/widget_string.py b/IPython/html/widgets/widget_string.py index 30245a2..96d7d44 100644 --- a/IPython/html/widgets/widget_string.py +++ b/IPython/html/widgets/widget_string.py @@ -27,6 +27,10 @@ class _String(DOMWidget): description = Unicode(help="Description of the value this widget represents", sync=True) placeholder = Unicode("", help="Placeholder text to display when nothing has been typed", sync=True) + def __init__(self, value=None, **kwargs): + if value is not None: + kwargs['value'] = value + super(_String, self).__init__(**kwargs) @register('IPython.HTML') class HTML(_String): @@ -55,8 +59,8 @@ class Text(_String): """Single line textbox widget.""" _view_name = Unicode('TextView', sync=True) - def __init__(self, **kwargs): - super(Text, self).__init__(**kwargs) + def __init__(self, *args, **kwargs): + super(Text, self).__init__(*args, **kwargs) self._submission_callbacks = CallbackDispatcher() self.on_msg(self._handle_string_msg)