|
|
// Copyright (c) IPython Development Team.
|
|
|
// Distributed under the terms of the Modified BSD License.
|
|
|
|
|
|
define([
|
|
|
'base/js/namespace',
|
|
|
'components/jquery/jquery.min',
|
|
|
'base/js/utils',
|
|
|
], function(IPython, $, utils) {
|
|
|
"use strict";
|
|
|
|
|
|
var ClusterList = function (selector, options) {
|
|
|
this.selector = selector;
|
|
|
if (this.selector !== undefined) {
|
|
|
this.element = $(selector);
|
|
|
this.style();
|
|
|
this.bind_events();
|
|
|
}
|
|
|
options = options || {};
|
|
|
this.options = options;
|
|
|
this.base_url = options.base_url || utils.get_body_data("baseUrl");
|
|
|
this.notebook_path = options.notebook_path || utils.get_body_data("notebookPath");
|
|
|
};
|
|
|
|
|
|
ClusterList.prototype.style = function () {
|
|
|
$('#cluster_list').addClass('list_container');
|
|
|
$('#cluster_toolbar').addClass('list_toolbar');
|
|
|
$('#cluster_list_info').addClass('toolbar_info');
|
|
|
$('#cluster_buttons').addClass('toolbar_buttons');
|
|
|
};
|
|
|
|
|
|
|
|
|
ClusterList.prototype.bind_events = function () {
|
|
|
var that = this;
|
|
|
$('#refresh_cluster_list').click(function () {
|
|
|
that.load_list();
|
|
|
});
|
|
|
};
|
|
|
|
|
|
|
|
|
ClusterList.prototype.load_list = function () {
|
|
|
var settings = {
|
|
|
processData : false,
|
|
|
cache : false,
|
|
|
type : "GET",
|
|
|
dataType : "json",
|
|
|
success : $.proxy(this.load_list_success, this),
|
|
|
error : utils.log_ajax_error,
|
|
|
};
|
|
|
var url = utils.url_join_encode(this.base_url, 'clusters');
|
|
|
$.ajax(url, settings);
|
|
|
};
|
|
|
|
|
|
|
|
|
ClusterList.prototype.clear_list = function () {
|
|
|
this.element.children('.list_item').remove();
|
|
|
};
|
|
|
|
|
|
ClusterList.prototype.load_list_success = function (data, status, xhr) {
|
|
|
this.clear_list();
|
|
|
var len = data.length;
|
|
|
for (var i=0; i<len; i++) {
|
|
|
var element = $('<div/>');
|
|
|
var item = new ClusterItem(element, this.options);
|
|
|
item.update_state(data[i]);
|
|
|
element.data('item', item);
|
|
|
this.element.append(element);
|
|
|
}
|
|
|
};
|
|
|
|
|
|
|
|
|
var ClusterItem = function (element, options) {
|
|
|
this.element = $(element);
|
|
|
this.base_url = options.base_url || utils.get_body_data("baseUrl");
|
|
|
this.notebook_path = options.notebook_path || utils.get_body_data("notebookPath");
|
|
|
this.data = null;
|
|
|
this.style();
|
|
|
};
|
|
|
|
|
|
ClusterItem.prototype.style = function () {
|
|
|
this.element.addClass('list_item').addClass("row");
|
|
|
};
|
|
|
|
|
|
ClusterItem.prototype.update_state = function (data) {
|
|
|
this.data = data;
|
|
|
if (data.status === 'running') {
|
|
|
this.state_running();
|
|
|
} else if (data.status === 'stopped') {
|
|
|
this.state_stopped();
|
|
|
}
|
|
|
};
|
|
|
|
|
|
|
|
|
ClusterItem.prototype.state_stopped = function () {
|
|
|
var that = this;
|
|
|
var profile_col = $('<div/>').addClass('profile_col col-md-4').text(this.data.profile);
|
|
|
var status_col = $('<div/>').addClass('status_col col-md-3').text('stopped');
|
|
|
var engines_col = $('<div/>').addClass('engine_col col-md-3');
|
|
|
var input = $('<input/>').attr('type','number')
|
|
|
.attr('min',1)
|
|
|
.attr('size',3)
|
|
|
.addClass('engine_num_input form-control');
|
|
|
engines_col.append(input);
|
|
|
var start_button = $('<button/>').addClass("btn btn-default btn-xs").text("Start");
|
|
|
var action_col = $('<div/>').addClass('action_col col-md-2').append(
|
|
|
$("<span/>").addClass("item_buttons btn-group").append(
|
|
|
start_button
|
|
|
)
|
|
|
);
|
|
|
this.element.empty()
|
|
|
.append(profile_col)
|
|
|
.append(status_col)
|
|
|
.append(engines_col)
|
|
|
.append(action_col);
|
|
|
start_button.click(function (e) {
|
|
|
var n = that.element.find('.engine_num_input').val();
|
|
|
if (!/^\d+$/.test(n) && n.length>0) {
|
|
|
status_col.text('invalid engine #');
|
|
|
} else {
|
|
|
var settings = {
|
|
|
cache : false,
|
|
|
data : {n:n},
|
|
|
type : "POST",
|
|
|
dataType : "json",
|
|
|
success : function (data, status, xhr) {
|
|
|
that.update_state(data);
|
|
|
},
|
|
|
error : function (xhr, status, error) {
|
|
|
status_col.text("error starting cluster");
|
|
|
utils.log_ajax_error(xhr, status, error);
|
|
|
}
|
|
|
};
|
|
|
status_col.text('starting');
|
|
|
var url = utils.url_join_encode(
|
|
|
that.base_url,
|
|
|
'clusters',
|
|
|
that.data.profile,
|
|
|
'start'
|
|
|
);
|
|
|
$.ajax(url, settings);
|
|
|
}
|
|
|
});
|
|
|
};
|
|
|
|
|
|
|
|
|
ClusterItem.prototype.state_running = function () {
|
|
|
var that = this;
|
|
|
var profile_col = $('<div/>').addClass('profile_col col-md-4').text(this.data.profile);
|
|
|
var status_col = $('<div/>').addClass('status_col col-md-3').text('running');
|
|
|
var engines_col = $('<div/>').addClass('engines_col col-md-3').text(this.data.n);
|
|
|
var stop_button = $('<button/>').addClass("btn btn-default btn-xs").text("Stop");
|
|
|
var action_col = $('<div/>').addClass('action_col col-md-2').append(
|
|
|
$("<span/>").addClass("item_buttons btn-group").append(
|
|
|
stop_button
|
|
|
)
|
|
|
);
|
|
|
this.element.empty()
|
|
|
.append(profile_col)
|
|
|
.append(status_col)
|
|
|
.append(engines_col)
|
|
|
.append(action_col);
|
|
|
stop_button.click(function (e) {
|
|
|
var settings = {
|
|
|
cache : false,
|
|
|
type : "POST",
|
|
|
dataType : "json",
|
|
|
success : function (data, status, xhr) {
|
|
|
that.update_state(data);
|
|
|
},
|
|
|
error : function (xhr, status, error) {
|
|
|
utils.log_ajax_error(xhr, status, error),
|
|
|
status_col.text("error stopping cluster");
|
|
|
}
|
|
|
};
|
|
|
status_col.text('stopping');
|
|
|
var url = utils.url_join_encode(
|
|
|
that.base_url,
|
|
|
'clusters',
|
|
|
that.data.profile,
|
|
|
'stop'
|
|
|
);
|
|
|
$.ajax(url, settings);
|
|
|
});
|
|
|
};
|
|
|
|
|
|
// For backwards compatability.
|
|
|
IPython.ClusterList = ClusterList;
|
|
|
IPython.ClusterItem = ClusterItem;
|
|
|
|
|
|
return ClusterList;
|
|
|
});
|
|
|
|