diff --git a/IPython/html/static/widgets/js/widget_bool.js b/IPython/html/static/widgets/js/widget_bool.js
index 02340543d..27e492875 100644
--- a/IPython/html/static/widgets/js/widget_bool.js
+++ b/IPython/html/static/widgets/js/widget_bool.js
@@ -129,10 +129,11 @@ define([
var description = this.model.get('description');
this.$el.attr("title", this.model.get("tooltip"));
- if (description.trim().length === 0) {
+ this.$el.text(description);
+ var icon = this.model.get("icon");
+ $('').prependTo(this.$el).addClass(icon);
+ if (description.trim().length === 0 && icon.trim().length ===0) {
this.$el.html(" "); // Preserve button height
- } else {
- this.$el.text(description);
}
}
return ToggleButtonView.__super__.update.apply(this);
diff --git a/IPython/html/static/widgets/js/widget_button.js b/IPython/html/static/widgets/js/widget_button.js
index c4765818f..cc55f47e1 100644
--- a/IPython/html/static/widgets/js/widget_button.js
+++ b/IPython/html/static/widgets/js/widget_button.js
@@ -32,12 +32,12 @@ define([
*/
var description = this.model.get('description');
this.$el.attr("title", this.model.get("tooltip"));
- if (description.length === 0) {
+ this.$el.text(description);
+ var icon = this.model.get("icon");
+ $('').prependTo(this.$el).addClass(icon);
+ if (description.trim().length === 0 && icon.trim().length ===0) {
this.$el.html(" "); // Preserve button height
- } else {
- this.$el.text(description);
}
-
if (this.model.get('disabled')) {
this.$el.attr('disabled','disabled');
} else {
diff --git a/IPython/html/tests/widgets/widget_bool.js b/IPython/html/tests/widgets/widget_bool.js
index 1d3ec62b2..556031c9b 100644
--- a/IPython/html/tests/widgets/widget_bool.js
+++ b/IPython/html/tests/widgets/widget_bool.js
@@ -49,7 +49,7 @@ casper.notebook_test(function () {
'Toggle button exists.');
this.test.assert(this.cell_element_function(bool_index,
- widget_togglebutton_selector, 'html')=="Title",
+ widget_togglebutton_selector, 'html')=='Title',
'Toggle button labeled correctly.');
this.test.assert(this.cell_element_function(bool_index,
diff --git a/IPython/html/tests/widgets/widget_button.js b/IPython/html/tests/widgets/widget_button.js
index e98da48d0..97ea5ee77 100644
--- a/IPython/html/tests/widgets/widget_button.js
+++ b/IPython/html/tests/widgets/widget_button.js
@@ -29,7 +29,7 @@ casper.notebook_test(function () {
'Widget button exists.');
this.test.assert(this.cell_element_function(button_index,
- widget_button_selector, 'html')=='Title',
+ widget_button_selector, 'html')=='Title',
'Set button description.');
this.cell_element_function(button_index,
diff --git a/IPython/html/widgets/widget_bool.py b/IPython/html/widgets/widget_bool.py
index a6f1ff55f..976c721fd 100644
--- a/IPython/html/widgets/widget_bool.py
+++ b/IPython/html/widgets/widget_bool.py
@@ -55,10 +55,15 @@ class ToggleButton(_Bool):
value of the toggle button: True-pressed, False-unpressed
description : str
description displayed next to the button
+ tooltip: str
+ tooltip caption of the toggle button
+ icon: str
+ font-awesome icon name
"""
_view_name = Unicode('ToggleButtonView', sync=True)
tooltip = Unicode(help="Tooltip caption of the toggle button.", sync=True)
+ icon = Unicode('', help= "Font-awesome icon.", sync=True)
button_style = CaselessStrEnum(
values=['primary', 'success', 'info', 'warning', 'danger', ''],
diff --git a/IPython/html/widgets/widget_button.py b/IPython/html/widgets/widget_button.py
index e91f3d2b7..4d5549c0a 100644
--- a/IPython/html/widgets/widget_button.py
+++ b/IPython/html/widgets/widget_button.py
@@ -24,15 +24,25 @@ from IPython.utils.warn import DeprecatedClass
@register('IPython.Button')
class Button(DOMWidget):
"""Button widget.
+ This widget has an `on_click` method that allows you to listen for the
+ user clicking on the button. The click event itself is stateless.
- This widget has an `on_click` method that allows you to listen for the
- user clicking on the button. The click event itself is stateless."""
+ Parameters
+ ----------
+ description : str
+ description displayed next to the button
+ tooltip: str
+ tooltip caption of the toggle button
+ icon: str
+ font-awesome icon name
+ """
_view_name = Unicode('ButtonView', sync=True)
# Keys
description = Unicode('', help="Button label.", sync=True)
tooltip = Unicode(help="Tooltip caption of the button.", sync=True)
disabled = Bool(False, help="Enable or disable user changes.", sync=True)
+ icon = Unicode('', help= "Font-awesome icon.", sync=True)
button_style = CaselessStrEnum(
values=['primary', 'success', 'info', 'warning', 'danger', ''],