widget_output.js
57 lines
| 1.9 KiB
| application/javascript
|
JavascriptLexer
Jonathan Frederic
|
r18953 | // Copyright (c) IPython Development Team. | ||
// Distributed under the terms of the Modified BSD License. | ||||
define([ | ||||
"widgets/js/widget", | ||||
"jquery", | ||||
'notebook/js/outputarea', | ||||
Jonathan Frederic
|
r18958 | ], function(widget, $, outputarea) { | ||
'use strict'; | ||||
Jonathan Frederic
|
r18953 | |||
var OutputView = widget.DOMWidgetView.extend({ | ||||
initialize: function (parameters) { | ||||
// Public constructor | ||||
OutputView.__super__.initialize.apply(this, [parameters]); | ||||
this.model.on('msg:custom', this._handle_route_msg, this); | ||||
}, | ||||
render: function(){ | ||||
// Called when view is rendered. | ||||
this.output_area = new outputarea.OutputArea({ | ||||
selector: this.$el, | ||||
prompt_area: false, | ||||
events: this.model.widget_manager.notebook.events, | ||||
keyboard_manager: this.model.widget_manager.keyboard_manager }); | ||||
Jonathan Frederic
|
r18954 | |||
// Make output area reactive. | ||||
var that = this; | ||||
this.output_area.element.on('changed', function() { | ||||
that.model.set('contents', that.output_area.element.html()); | ||||
}); | ||||
this.model.on('change:contents', function(){ | ||||
var html = this.model.get('contents'); | ||||
if (this.output_area.element.html() != html) { | ||||
this.output_area.element.html(html); | ||||
} | ||||
}, this); | ||||
// Set initial contents. | ||||
this.output_area.element.html(this.model.get('contents')); | ||||
Jonathan Frederic
|
r18953 | }, | ||
_handle_route_msg: function(content) { | ||||
var cell = this.options.cell; | ||||
if (content && cell) { | ||||
if (content.method == 'push') { | ||||
cell.push_output_area(this.output_area); | ||||
} else if (content.method == 'pop') { | ||||
cell.pop_output_area(this.output_area); | ||||
} | ||||
} | ||||
}, | ||||
}); | ||||
return { | ||||
'OutputView': OutputView, | ||||
}; | ||||
}); | ||||