widget_button.js
77 lines
| 2.3 KiB
| application/javascript
|
JavascriptLexer
Jonathan Frederic
|
r17198 | // Copyright (c) IPython Development Team. | ||
// Distributed under the terms of the Modified BSD License. | ||||
Jonathan Frederic
|
r14366 | |||
Jonathan Frederic
|
r17198 | define([ | ||
"widgets/js/widget", | ||||
Jonathan Frederic
|
r17216 | "jquery", | ||
MinRK
|
r17312 | "bootstrap", | ||
Jonathan Frederic
|
r17216 | ], function(widget, $){ | ||
Jonathan Frederic
|
r14366 | |||
Jonathan Frederic
|
r17198 | var ButtonView = widget.DOMWidgetView.extend({ | ||
Jonathan Frederic
|
r14270 | render : function(){ | ||
Jonathan Frederic
|
r19176 | /** | ||
* Called when view is rendered. | ||||
*/ | ||||
Jonathan Frederic
|
r14397 | this.setElement($("<button />") | ||
Jonathan Frederic
|
r16913 | .addClass('btn btn-default')); | ||
Sylvain Corlay
|
r18115 | this.$el.attr("data-toggle", "tooltip"); | ||
Jonathan Frederic
|
r17728 | this.model.on('change:button_style', function(model, value) { | ||
this.update_button_style(); | ||||
}, this); | ||||
this.update_button_style(''); | ||||
Jonathan Frederic
|
r14270 | this.update(); // Set defaults. | ||
}, | ||||
update : function(){ | ||||
Jonathan Frederic
|
r19176 | /** | ||
* Update the contents of this view | ||||
* | ||||
* Called when the model is changed. The model may have been | ||||
* changed by another view or by a state update from the back-end. | ||||
*/ | ||||
Jonathan Frederic
|
r14292 | var description = this.model.get('description'); | ||
Sylvain Corlay
|
r18115 | this.$el.attr("title", this.model.get("tooltip")); | ||
Jonathan Frederic
|
r14466 | if (description.length === 0) { | ||
MinRK
|
r15329 | this.$el.html(" "); // Preserve button height | ||
Jonathan Frederic
|
r14292 | } else { | ||
Jonathan Frederic
|
r14663 | this.$el.text(description); | ||
Jonathan Frederic
|
r14292 | } | ||
Jonathan Frederic
|
r14430 | if (this.model.get('disabled')) { | ||
this.$el.attr('disabled','disabled'); | ||||
} else { | ||||
this.$el.removeAttr('disabled'); | ||||
} | ||||
Jonathan Frederic
|
r14583 | return ButtonView.__super__.update.apply(this); | ||
Jonathan Frederic
|
r14270 | }, | ||
Jonathan Frederic
|
r14400 | |||
Jonathan Frederic
|
r17728 | update_button_style: function(previous_trait_value) { | ||
var class_map = { | ||||
primary: ['btn-primary'], | ||||
success: ['btn-success'], | ||||
info: ['btn-info'], | ||||
warning: ['btn-warning'], | ||||
danger: ['btn-danger'] | ||||
}; | ||||
this.update_mapped_classes(class_map, 'button_style', previous_trait_value); | ||||
}, | ||||
Jonathan Frederic
|
r14400 | events: { | ||
Jonathan Frederic
|
r14609 | // Dictionary of events and their handlers. | ||
Jonathan Frederic
|
r14400 | 'click': '_handle_click', | ||
}, | ||||
Jonathan Frederic
|
r14270 | |||
Jonathan Frederic
|
r14400 | _handle_click: function(){ | ||
Jonathan Frederic
|
r19176 | /** | ||
* Handles when the button is clicked. | ||||
*/ | ||||
Jonathan Frederic
|
r14403 | this.send({event: 'click'}); | ||
Jonathan Frederic
|
r14400 | }, | ||
Jonathan Frederic
|
r14270 | }); | ||
Jonathan Frederic
|
r17198 | |||
return { | ||||
'ButtonView': ButtonView, | ||||
}; | ||||
Jonathan Frederic
|
r14270 | }); | ||