diff --git a/IPython/html/auth/login.py b/IPython/html/auth/login.py
index 51ab621..1ad4673 100644
--- a/IPython/html/auth/login.py
+++ b/IPython/html/auth/login.py
@@ -32,13 +32,13 @@ class LoginHandler(IPythonHandler):
def _render(self, message=None):
self.write(self.render_template('login.html',
- next=url_escape(self.get_argument('next', default=self.base_project_url)),
+ next=url_escape(self.get_argument('next', default=self.base_url)),
message=message,
))
def get(self):
if self.current_user:
- self.redirect(self.get_argument('next', default=self.base_project_url))
+ self.redirect(self.get_argument('next', default=self.base_url))
else:
self._render()
@@ -51,7 +51,7 @@ class LoginHandler(IPythonHandler):
self._render(message={'error': 'Invalid password'})
return
- self.redirect(self.get_argument('next', default=self.base_project_url))
+ self.redirect(self.get_argument('next', default=self.base_url))
#-----------------------------------------------------------------------------
diff --git a/IPython/html/base/handlers.py b/IPython/html/base/handlers.py
index 4cb674b..5941d11 100644
--- a/IPython/html/base/handlers.py
+++ b/IPython/html/base/handlers.py
@@ -133,8 +133,8 @@ class IPythonHandler(AuthenticatedHandler):
return self.settings.get('mathjax_url', '')
@property
- def base_project_url(self):
- return self.settings.get('base_project_url', '/')
+ def base_url(self):
+ return self.settings.get('base_url', '/')
@property
def base_kernel_url(self):
@@ -180,7 +180,7 @@ class IPythonHandler(AuthenticatedHandler):
@property
def template_namespace(self):
return dict(
- base_project_url=self.base_project_url,
+ base_url=self.base_url,
base_kernel_url=self.base_kernel_url,
logged_in=self.logged_in,
login_available=self.login_available,
diff --git a/IPython/html/notebook/handlers.py b/IPython/html/notebook/handlers.py
index e442d00..fe415e6 100644
--- a/IPython/html/notebook/handlers.py
+++ b/IPython/html/notebook/handlers.py
@@ -58,7 +58,7 @@ class NotebookRedirectHandler(IPythonHandler):
nbm = self.notebook_manager
if nbm.path_exists(path):
# it's a *directory*, redirect to /tree
- url = url_path_join(self.base_project_url, 'tree', path)
+ url = url_path_join(self.base_url, 'tree', path)
else:
# otherwise, redirect to /files
if '/files/' in path:
@@ -73,7 +73,7 @@ class NotebookRedirectHandler(IPythonHandler):
if not os.path.exists(files_path):
path = path.replace('/files/', '/', 1)
- url = url_path_join(self.base_project_url, 'files', path)
+ url = url_path_join(self.base_url, 'files', path)
url = url_escape(url)
self.log.debug("Redirecting %s to %s", self.request.path, url)
self.redirect(url)
diff --git a/IPython/html/notebookapp.py b/IPython/html/notebookapp.py
index 51902a2..1168451 100644
--- a/IPython/html/notebookapp.py
+++ b/IPython/html/notebookapp.py
@@ -133,42 +133,42 @@ def load_handlers(name):
class NotebookWebApplication(web.Application):
def __init__(self, ipython_app, kernel_manager, notebook_manager,
- cluster_manager, session_manager, log, base_project_url,
+ cluster_manager, session_manager, log, base_url,
settings_overrides):
settings = self.init_settings(
ipython_app, kernel_manager, notebook_manager, cluster_manager,
- session_manager, log, base_project_url, settings_overrides)
+ session_manager, log, base_url, settings_overrides)
handlers = self.init_handlers(settings)
super(NotebookWebApplication, self).__init__(handlers, **settings)
def init_settings(self, ipython_app, kernel_manager, notebook_manager,
- cluster_manager, session_manager, log, base_project_url,
+ cluster_manager, session_manager, log, base_url,
settings_overrides):
# Python < 2.6.5 doesn't accept unicode keys in f(**kwargs), and
- # base_project_url will always be unicode, which will in turn
+ # base_url will always be unicode, which will in turn
# make the patterns unicode, and ultimately result in unicode
# keys in kwargs to handler._execute(**kwargs) in tornado.
- # This enforces that base_project_url be ascii in that situation.
+ # This enforces that base_url be ascii in that situation.
#
# Note that the URLs these patterns check against are escaped,
# and thus guaranteed to be ASCII: 'héllo' is really 'h%C3%A9llo'.
- base_project_url = py3compat.unicode_to_str(base_project_url, 'ascii')
+ base_url = py3compat.unicode_to_str(base_url, 'ascii')
template_path = settings_overrides.get("template_path", os.path.join(os.path.dirname(__file__), "templates"))
settings = dict(
# basics
log_function=log_request,
- base_project_url=base_project_url,
+ base_url=base_url,
base_kernel_url=ipython_app.base_kernel_url,
template_path=template_path,
static_path=ipython_app.static_file_path,
static_handler_class = FileFindHandler,
- static_url_prefix = url_path_join(base_project_url,'/static/'),
+ static_url_prefix = url_path_join(base_url,'/static/'),
# authentication
cookie_secret=ipython_app.cookie_secret,
- login_url=url_path_join(base_project_url,'/login'),
+ login_url=url_path_join(base_url,'/login'),
password=ipython_app.password,
# managers
@@ -206,10 +206,10 @@ class NotebookWebApplication(web.Application):
(r"/files/(.*)", AuthenticatedFileHandler, {'path' : settings['notebook_manager'].notebook_dir}),
(r"/nbextensions/(.*)", FileFindHandler, {'path' : settings['nbextensions_path']}),
])
- # prepend base_project_url onto the patterns that we match
+ # prepend base_url onto the patterns that we match
new_handlers = []
for handler in handlers:
- pattern = url_path_join(settings['base_project_url'], handler[0])
+ pattern = url_path_join(settings['base_url'], handler[0])
new_handler = tuple([pattern] + list(handler[1:]))
new_handlers.append(new_handler)
# add 404 on the end, which will catch everything that falls through
@@ -414,17 +414,22 @@ class NotebookApp(BaseIPythonApplication):
if not new:
self.mathjax_url = u''
- base_project_url = Unicode('/', config=True,
+ base_url = Unicode('/', config=True,
help='''The base URL for the notebook server.
Leading and trailing slashes can be omitted,
and will automatically be added.
''')
- def _base_project_url_changed(self, name, old, new):
+ def _base_url_changed(self, name, old, new):
if not new.startswith('/'):
- self.base_project_url = '/'+new
+ self.base_url = '/'+new
elif not new.endswith('/'):
- self.base_project_url = new+'/'
+ self.base_url = new+'/'
+
+ base_project_url = Unicode('/', config=True, help="""DEPRECATED use base_url""")
+ def _base_project_url_changed(self, name, old, new):
+ self.log.warn("base_project_url is deprecated, use base_url")
+ self.base_url = new
base_kernel_url = Unicode('/', config=True,
help='''The base URL for the kernel server
@@ -473,12 +478,12 @@ class NotebookApp(BaseIPythonApplication):
if not self.enable_mathjax:
return u''
static_url_prefix = self.webapp_settings.get("static_url_prefix",
- url_path_join(self.base_project_url, "static")
+ url_path_join(self.base_url, "static")
)
# try local mathjax, either in nbextensions/mathjax or static/mathjax
for (url_prefix, search_path) in [
- (url_path_join(self.base_project_url, "nbextensions"), self.nbextensions_path),
+ (url_path_join(self.base_url, "nbextensions"), self.nbextensions_path),
(static_url_prefix, self.static_file_path),
]:
self.log.debug("searching for local mathjax in %s", search_path)
@@ -586,7 +591,7 @@ class NotebookApp(BaseIPythonApplication):
self.web_app = NotebookWebApplication(
self, self.kernel_manager, self.notebook_manager,
self.cluster_manager, self.session_manager,
- self.log, self.base_project_url, self.webapp_settings
+ self.log, self.base_url, self.webapp_settings
)
if self.certfile:
ssl_options = dict(certfile=self.certfile)
@@ -639,7 +644,7 @@ class NotebookApp(BaseIPythonApplication):
def _url(self, ip):
proto = 'https' if self.certfile else 'http'
- return "%s://%s:%i%s" % (proto, ip, self.port, self.base_project_url)
+ return "%s://%s:%i%s" % (proto, ip, self.port, self.base_url)
def init_signal(self):
if not sys.platform.startswith('win'):
@@ -745,7 +750,7 @@ class NotebookApp(BaseIPythonApplication):
'hostname': self.ip if self.ip else 'localhost',
'port': self.port,
'secure': bool(self.certfile),
- 'base_project_url': self.base_project_url,
+ 'base_url': self.base_url,
'notebook_dir': os.path.abspath(self.notebook_manager.notebook_dir),
}
diff --git a/IPython/html/services/notebooks/handlers.py b/IPython/html/services/notebooks/handlers.py
index ac44dd6..dc34c88 100644
--- a/IPython/html/services/notebooks/handlers.py
+++ b/IPython/html/services/notebooks/handlers.py
@@ -47,7 +47,7 @@ class NotebookHandler(IPythonHandler):
The URL path of the notebook.
"""
return url_escape(url_path_join(
- self.base_project_url, 'api', 'notebooks', path, name
+ self.base_url, 'api', 'notebooks', path, name
))
def _finish_model(self, model, location=True):
@@ -242,7 +242,7 @@ class NotebookCheckpointsHandler(IPythonHandler):
nbm = self.notebook_manager
checkpoint = nbm.create_checkpoint(name, path)
data = json.dumps(checkpoint, default=date_default)
- location = url_path_join(self.base_project_url, 'api/notebooks',
+ location = url_path_join(self.base_url, 'api/notebooks',
path, name, 'checkpoints', checkpoint['id'])
self.set_header('Location', url_escape(location))
self.set_status(201)
diff --git a/IPython/html/static/auth/js/loginwidget.js b/IPython/html/static/auth/js/loginwidget.js
index 1998aca..0ed24ab 100644
--- a/IPython/html/static/auth/js/loginwidget.js
+++ b/IPython/html/static/auth/js/loginwidget.js
@@ -10,10 +10,11 @@
//============================================================================
var IPython = (function (IPython) {
+ "use strict";
var LoginWidget = function (selector, options) {
- var options = options || {};
- this.base_url = options.baseProjectUrl || $('body').data('baseProjectUrl') ;
+ options = options || {};
+ this.base_url = options.base_url || IPython.utils.get_body_data("baseUrl");
this.selector = selector;
if (this.selector !== undefined) {
this.element = $(selector);
@@ -30,10 +31,16 @@ var IPython = (function (IPython) {
LoginWidget.prototype.bind_events = function () {
var that = this;
this.element.find("button#logout").click(function () {
- window.location = that.base_url+"logout";
+ window.location = IPythin.utils.url_join_encode(
+ that.base_url,
+ "logout"
+ );
});
this.element.find("button#login").click(function () {
- window.location = that.base_url+"login";
+ window.location = IPythin.utils.url_join_encode(
+ that.base_url,
+ "login"
+ );
});
};
diff --git a/IPython/html/static/base/js/utils.js b/IPython/html/static/base/js/utils.js
index 0e6c9fb..c110ecc 100644
--- a/IPython/html/static/base/js/utils.js
+++ b/IPython/html/static/base/js/utils.js
@@ -417,15 +417,29 @@ IPython.utils = (function (IPython) {
url = url + arguments[i];
}
}
+ url = url.replace(/\/\/+/, '/');
return url;
};
+ var parse_url = function (url) {
+ // an `a` element with an href allows attr-access to the parsed segments of a URL
+ // a = parse_url("http://localhost:8888/path/name#hash")
+ // a.protocol = "http:"
+ // a.host = "localhost:8888"
+ // a.hostname = "localhost"
+ // a.port = 8888
+ // a.pathname = "/path/name"
+ // a.hash = "#hash"
+ var a = document.createElement("a");
+ a.href = url;
+ return a;
+ };
var encode_uri_components = function (uri) {
// encode just the components of a multi-segment uri,
// leaving '/' separators
return uri.split('/').map(encodeURIComponent).join('/');
- }
+ };
var url_join_encode = function () {
// join a sequence of url components with '/',
@@ -443,7 +457,15 @@ IPython.utils = (function (IPython) {
} else {
return [filename, ''];
}
- }
+ };
+
+
+ var get_body_data = function(key) {
+ // get a url-encoded item from body.data and decode it
+ // we should never have any encoded URLs anywhere else in code
+ // until we are building an actual request
+ return decodeURIComponent($('body').data(key));
+ };
// http://stackoverflow.com/questions/2400935/browser-detection-in-javascript
@@ -508,6 +530,8 @@ IPython.utils = (function (IPython) {
fixCarriageReturn : fixCarriageReturn,
autoLinkUrls : autoLinkUrls,
points_to_pixels : points_to_pixels,
+ get_body_data : get_body_data,
+ parse_url : parse_url,
url_path_join : url_path_join,
url_join_encode : url_join_encode,
encode_uri_components : encode_uri_components,
diff --git a/IPython/html/static/notebook/js/main.js b/IPython/html/static/notebook/js/main.js
index 32a9090..59e69f6 100644
--- a/IPython/html/static/notebook/js/main.js
+++ b/IPython/html/static/notebook/js/main.js
@@ -8,7 +8,6 @@
//============================================================================
// On document ready
//============================================================================
-"use strict";
// for the time beeing, we have to pass marked as a parameter here,
// as injecting require.js make marked not to put itself in the globals,
@@ -18,28 +17,28 @@ require(['components/marked/lib/marked',
'notebook/js/widgets/init'],
function (marked) {
+ "use strict";
- window.marked = marked
+ window.marked = marked;
// monkey patch CM to be able to syntax highlight cell magics
// bug reported upstream,
// see https://github.com/marijnh/CodeMirror2/issues/670
- if(CodeMirror.getMode(1,'text/plain').indent == undefined ){
+ if(CodeMirror.getMode(1,'text/plain').indent === undefined ){
console.log('patching CM for undefined indent');
CodeMirror.modes.null = function() {
- return {token: function(stream) {stream.skipToEnd();},indent : function(){return 0}}
- }
+ return {token: function(stream) {stream.skipToEnd();},indent : function(){return 0;}};
+ };
}
CodeMirror.patchedGetMode = function(config, mode){
var cmmode = CodeMirror.getMode(config, mode);
- if(cmmode.indent == null)
- {
+ if(cmmode.indent === null) {
console.log('patch mode "' , mode, '" on the fly');
- cmmode.indent = function(){return 0};
+ cmmode.indent = function(){return 0;};
}
return cmmode;
- }
+ };
// end monkey patching CodeMirror
IPython.mathjaxutils.init();
@@ -47,35 +46,32 @@ function (marked) {
$('#ipython-main-app').addClass('border-box-sizing');
$('div#notebook_panel').addClass('border-box-sizing');
- var baseProjectUrl = $('body').data('baseProjectUrl');
- var notebookPath = $('body').data('notebookPath');
- var notebookName = $('body').data('notebookName');
- notebookName = decodeURIComponent(notebookName);
- notebookPath = decodeURIComponent(notebookPath);
- console.log(notebookName);
- if (notebookPath == 'None'){
- notebookPath = "";
- }
+ var opts = {
+ base_url : IPython.utils.get_body_data("baseUrl"),
+ base_kernel_url : IPython.utils.get_body_data("baseKernelUrl"),
+ notebook_path : IPython.utils.get_body_data("notebookPath"),
+ notebook_name : IPython.utils.get_body_data('notebookName')
+ };
IPython.page = new IPython.Page();
IPython.layout_manager = new IPython.LayoutManager();
IPython.pager = new IPython.Pager('div#pager', 'div#pager_splitter');
IPython.quick_help = new IPython.QuickHelp();
- IPython.login_widget = new IPython.LoginWidget('span#login_widget',{baseProjectUrl:baseProjectUrl});
- IPython.notebook = new IPython.Notebook('div#notebook',{baseProjectUrl:baseProjectUrl, notebookPath:notebookPath, notebookName:notebookName});
+ IPython.login_widget = new IPython.LoginWidget('span#login_widget', opts);
+ IPython.notebook = new IPython.Notebook('div#notebook', opts);
IPython.keyboard_manager = new IPython.KeyboardManager();
IPython.save_widget = new IPython.SaveWidget('span#save_widget');
- IPython.menubar = new IPython.MenuBar('#menubar',{baseProjectUrl:baseProjectUrl, notebookPath: notebookPath})
- IPython.toolbar = new IPython.MainToolBar('#maintoolbar-container')
- IPython.tooltip = new IPython.Tooltip()
- IPython.notification_area = new IPython.NotificationArea('#notification_area')
+ IPython.menubar = new IPython.MenuBar('#menubar', opts);
+ IPython.toolbar = new IPython.MainToolBar('#maintoolbar-container');
+ IPython.tooltip = new IPython.Tooltip();
+ IPython.notification_area = new IPython.NotificationArea('#notification_area');
IPython.notification_area.init_notification_widgets();
IPython.layout_manager.do_resize();
$('body').append('
')
+ 'x');
var nh = $('#test1').innerHeight();
var bh = $('#test2').innerHeight();
var ih = $('#test3').innerHeight();
@@ -101,7 +97,7 @@ function (marked) {
$([IPython.events]).on('notebook_loaded.Notebook', first_load);
$([IPython.events]).trigger('app_initialized.NotebookApp');
- IPython.notebook.load_notebook(notebookName, notebookPath);
+ IPython.notebook.load_notebook(opts.notebook_name, opts.notebook_path);
if (marked) {
marked.setOptions({
@@ -121,8 +117,6 @@ function (marked) {
}
return highlighted.value;
}
- })
+ });
}
-}
-
-);
+});
diff --git a/IPython/html/static/notebook/js/menubar.js b/IPython/html/static/notebook/js/menubar.js
index 622d76e..dacf18e 100644
--- a/IPython/html/static/notebook/js/menubar.js
+++ b/IPython/html/static/notebook/js/menubar.js
@@ -30,16 +30,14 @@ var IPython = (function (IPython) {
*
* @param selector {string} selector for the menubar element in DOM
* @param {object} [options]
- * @param [options.baseProjectUrl] {String} String to use for the
- * Base Project url, default would be to inspect
- * $('body').data('baseProjectUrl');
+ * @param [options.base_url] {String} String to use for the
+ * base project url. Default is to inspect
+ * $('body').data('baseUrl');
* does not support change for now is set through this option
*/
var MenuBar = function (selector, options) {
options = options || {};
- if (options.baseProjectUrl !== undefined) {
- this._baseProjectUrl = options.baseProjectUrl;
- }
+ this.base_url = options.base_url || IPython.utils.get_body_data("baseUrl");
this.selector = selector;
if (this.selector !== undefined) {
this.element = $(selector);
@@ -48,16 +46,6 @@ var IPython = (function (IPython) {
}
};
- MenuBar.prototype.baseProjectUrl = function(){
- return this._baseProjectUrl || $('body').data('baseProjectUrl');
- };
-
- MenuBar.prototype.notebookPath = function() {
- var path = $('body').data('notebookPath');
- path = decodeURIComponent(path);
- return path;
- };
-
MenuBar.prototype.style = function () {
this.element.addClass('border-box-sizing');
this.element.find("li").click(function (event, ui) {
@@ -71,20 +59,21 @@ var IPython = (function (IPython) {
MenuBar.prototype._nbconvert = function (format, download) {
download = download || false;
- var notebook_name = IPython.notebook.get_notebook_name();
+ var notebook_path = IPython.notebook.notebook_path;
+ var notebook_name = IPython.notebook.notebook_name;
if (IPython.notebook.dirty) {
IPython.notebook.save_notebook({async : false});
}
- var url = utils.url_path_join(
- this.baseProjectUrl(),
+ var url = utils.url_join_encode(
+ this.base_url,
'nbconvert',
format,
- this.notebookPath(),
- notebook_name + '.ipynb'
+ notebook_path,
+ notebook_name
) + "?download=" + download.toString();
window.open(url);
- }
+ };
MenuBar.prototype.bind_events = function () {
// File
@@ -94,9 +83,9 @@ var IPython = (function (IPython) {
});
this.element.find('#open_notebook').click(function () {
window.open(utils.url_join_encode(
- that.baseProjectUrl(),
+ IPython.notebook.base_url,
'tree',
- that.notebookPath()
+ IPython.notebook.notebook_path
));
});
this.element.find('#copy_notebook').click(function () {
@@ -104,16 +93,18 @@ var IPython = (function (IPython) {
return false;
});
this.element.find('#download_ipynb').click(function () {
- var notebook_name = IPython.notebook.get_notebook_name();
+ var base_url = IPython.notebook.base_url;
+ var notebook_path = IPython.notebook.notebook_path;
+ var notebook_name = IPython.notebook.notebook_name;
if (IPython.notebook.dirty) {
IPython.notebook.save_notebook({async : false});
}
var url = utils.url_join_encode(
- that.baseProjectUrl(),
+ base_url,
'files',
- that.notebookPath(),
- notebook_name + '.ipynb'
+ notebook_path,
+ notebook_name
);
window.location.assign(url);
});
diff --git a/IPython/html/static/notebook/js/notebook.js b/IPython/html/static/notebook/js/notebook.js
index 90c73aa..e4c45c7 100644
--- a/IPython/html/static/notebook/js/notebook.js
+++ b/IPython/html/static/notebook/js/notebook.js
@@ -23,10 +23,10 @@ var IPython = (function (IPython) {
* @param {Object} [options] A config object
*/
var Notebook = function (selector, options) {
- var options = options || {};
- this._baseProjectUrl = options.baseProjectUrl;
- this.notebook_path = options.notebookPath;
- this.notebook_name = options.notebookName;
+ this.options = options = options || {};
+ this.base_url = options.base_url;
+ this.notebook_path = options.notebook_path;
+ this.notebook_name = options.notebook_name;
this.element = $(selector);
this.element.scroll();
this.element.data("notebook", this);
@@ -53,8 +53,8 @@ var IPython = (function (IPython) {
// single worksheet for now
this.worksheet_metadata = {};
this.notebook_name_blacklist_re = /[\/\\:]/;
- this.nbformat = 3 // Increment this when changing the nbformat
- this.nbformat_minor = 0 // Increment this when changing the nbformat
+ this.nbformat = 3; // Increment this when changing the nbformat
+ this.nbformat_minor = 0; // Increment this when changing the nbformat
this.style();
this.create_elements();
this.bind_events();
@@ -70,24 +70,6 @@ var IPython = (function (IPython) {
};
/**
- * Get the root URL of the notebook server.
- *
- * @method baseProjectUrl
- * @return {String} The base project URL
- */
- Notebook.prototype.baseProjectUrl = function() {
- return this._baseProjectUrl || $('body').data('baseProjectUrl');
- };
-
- Notebook.prototype.notebookName = function() {
- return $('body').data('notebookName');
- };
-
- Notebook.prototype.notebookPath = function() {
- return $('body').data('notebookPath');
- };
-
- /**
* Create an HTML and CSS representation of the notebook.
*
* @method create_elements
@@ -163,7 +145,7 @@ var IPython = (function (IPython) {
};
this.element.bind('collapse_pager', function (event, extrap) {
- var time = (extrap != undefined) ? ((extrap.duration != undefined ) ? extrap.duration : 'fast') : 'fast';
+ var time = (extrap !== undefined) ? ((extrap.duration !== undefined ) ? extrap.duration : 'fast') : 'fast';
collapse_time(time);
});
@@ -176,7 +158,7 @@ var IPython = (function (IPython) {
};
this.element.bind('expand_pager', function (event, extrap) {
- var time = (extrap != undefined) ? ((extrap.duration != undefined ) ? extrap.duration : 'fast') : 'fast';
+ var time = (extrap !== undefined) ? ((extrap.duration !== undefined ) ? extrap.duration : 'fast') : 'fast';
expand_time(time);
});
@@ -205,7 +187,7 @@ var IPython = (function (IPython) {
} else {
return "Unsaved changes will be lost.";
}
- };
+ }
// Null is the *only* return value that will make the browser not
// pop up the "don't leave" dialog.
return null;
@@ -237,7 +219,7 @@ var IPython = (function (IPython) {
*/
Notebook.prototype.scroll_to_cell = function (cell_number, time) {
var cells = this.get_cells();
- var time = time || 0;
+ time = time || 0;
cell_number = Math.min(cells.length-1,cell_number);
cell_number = Math.max(0 ,cell_number);
var scroll_value = cells[cell_number].element.position().top-cells[0].element.position().top ;
@@ -349,7 +331,7 @@ var IPython = (function (IPython) {
result = ce.data('cell');
}
return result;
- }
+ };
/**
* Get the cell below a given cell.
@@ -365,7 +347,7 @@ var IPython = (function (IPython) {
result = this.get_cell(index+1);
}
return result;
- }
+ };
/**
* Get the cell above a given cell.
@@ -383,7 +365,7 @@ var IPython = (function (IPython) {
result = this.get_cell(index-1);
}
return result;
- }
+ };
/**
* Get the numeric index of a given cell.
@@ -397,7 +379,7 @@ var IPython = (function (IPython) {
this.get_cell_elements().filter(function (index) {
if ($(this).data("cell") === cell) {
result = index;
- };
+ }
});
return result;
};
@@ -444,8 +426,8 @@ var IPython = (function (IPython) {
return true;
} else {
return false;
- };
- }
+ }
+ };
/**
* Get the index of the currently selected cell.
@@ -458,7 +440,7 @@ var IPython = (function (IPython) {
this.get_cell_elements().filter(function (index) {
if ($(this).data("cell").selected === true) {
result = index;
- };
+ }
});
return result;
};
@@ -475,11 +457,11 @@ var IPython = (function (IPython) {
*/
Notebook.prototype.select = function (index) {
if (this.is_valid_cell_index(index)) {
- var sindex = this.get_selected_index()
+ var sindex = this.get_selected_index();
if (sindex !== null && index !== sindex) {
this.command_mode();
this.get_cell(sindex).unselect();
- };
+ }
var cell = this.get_cell(index);
cell.select();
if (cell.cell_type === 'heading') {
@@ -490,8 +472,8 @@ var IPython = (function (IPython) {
$([IPython.events]).trigger('selected_cell_type_changed.Notebook',
{'cell_type':cell.cell_type}
);
- };
- };
+ }
+ }
return this;
};
@@ -527,7 +509,7 @@ var IPython = (function (IPython) {
this.get_cell_elements().filter(function (index) {
if ($(this).data("cell").mode === 'edit') {
result = index;
- };
+ }
});
return result;
};
@@ -539,10 +521,10 @@ var IPython = (function (IPython) {
var cell = this.get_cell(index);
if (cell) {
cell.command_mode();
- };
+ }
this.mode = 'command';
IPython.keyboard_manager.command_mode();
- };
+ }
};
Notebook.prototype.edit_mode = function () {
@@ -555,7 +537,7 @@ var IPython = (function (IPython) {
this.mode = 'edit';
IPython.keyboard_manager.edit_mode();
cell.edit_mode();
- };
+ }
};
Notebook.prototype.focus_cell = function () {
@@ -584,9 +566,9 @@ var IPython = (function (IPython) {
this.select(i-1);
var cell = this.get_selected_cell();
cell.focus_cell();
- };
+ }
this.set_dirty(true);
- };
+ }
return this;
};
@@ -609,8 +591,8 @@ var IPython = (function (IPython) {
this.select(i+1);
var cell = this.get_selected_cell();
cell.focus_cell();
- };
- };
+ }
+ }
this.set_dirty();
return this;
};
@@ -650,10 +632,10 @@ var IPython = (function (IPython) {
this.select(i);
this.undelete_index = i;
this.undelete_below = false;
- };
+ }
$([IPython.events]).trigger('delete.Cell', {'cell': cell, 'index': i});
this.set_dirty(true);
- };
+ }
return this;
};
@@ -691,7 +673,7 @@ var IPython = (function (IPython) {
this.undelete_index = null;
}
$('#undelete_cell').addClass('disabled');
- }
+ };
/**
* Insert a cell so that after insertion the cell is at given index.
@@ -709,8 +691,8 @@ var IPython = (function (IPython) {
Notebook.prototype.insert_cell_at_index = function(type, index){
var ncells = this.ncells();
- var index = Math.min(index,ncells);
- index = Math.max(index,0);
+ index = Math.min(index,ncells);
+ index = Math.max(index,0);
var cell = null;
if (ncells === 0 || this.is_valid_cell_index(index) || index === ncells) {
@@ -850,8 +832,8 @@ var IPython = (function (IPython) {
source_element.remove();
this.select(i);
this.set_dirty(true);
- };
- };
+ }
+ }
};
/**
@@ -870,7 +852,7 @@ var IPython = (function (IPython) {
var text = source_cell.get_text();
if (text === source_cell.placeholder) {
text = '';
- };
+ }
// We must show the editor before setting its contents
target_cell.unrender();
target_cell.set_text(text);
@@ -883,8 +865,8 @@ var IPython = (function (IPython) {
target_cell.render();
}
this.set_dirty(true);
- };
- };
+ }
+ }
};
/**
@@ -904,7 +886,7 @@ var IPython = (function (IPython) {
var text = source_cell.get_text();
if (text === source_cell.placeholder) {
text = '';
- };
+ }
// We must show the editor before setting its contents
target_cell.unrender();
target_cell.set_text(text);
@@ -914,8 +896,8 @@ var IPython = (function (IPython) {
source_element.remove();
this.select(i);
this.set_dirty(true);
- };
- };
+ }
+ }
};
/**
@@ -939,7 +921,7 @@ var IPython = (function (IPython) {
var text = source_cell.get_text();
if (text === source_cell.placeholder) {
text = '';
- };
+ }
// We must show the editor before setting its contents
target_cell.set_level(level);
target_cell.unrender();
@@ -952,12 +934,12 @@ var IPython = (function (IPython) {
if ((source_cell instanceof IPython.TextCell) && source_cell.rendered) {
target_cell.render();
}
- };
+ }
this.set_dirty(true);
$([IPython.events]).trigger('selected_cell_type_changed.Notebook',
{'cell_type':'heading',level:level}
);
- };
+ }
};
@@ -978,7 +960,7 @@ var IPython = (function (IPython) {
$('#paste_cell_below').removeClass('disabled')
.on('click', function () {that.paste_cell_below();});
this.paste_enabled = true;
- };
+ }
};
/**
@@ -992,7 +974,7 @@ var IPython = (function (IPython) {
$('#paste_cell_above').addClass('disabled').off('click');
$('#paste_cell_below').addClass('disabled').off('click');
this.paste_enabled = false;
- };
+ }
};
/**
@@ -1003,7 +985,7 @@ var IPython = (function (IPython) {
Notebook.prototype.cut_cell = function () {
this.copy_cell();
this.delete_cell();
- }
+ };
/**
* Copy a cell.
@@ -1029,7 +1011,7 @@ var IPython = (function (IPython) {
var old_cell = this.get_next_cell(new_cell);
this.delete_cell(this.find_cell_index(old_cell));
this.select(this.find_cell_index(new_cell));
- };
+ }
};
/**
@@ -1043,7 +1025,7 @@ var IPython = (function (IPython) {
var new_cell = this.insert_cell_above(cell_data.cell_type);
new_cell.fromJSON(cell_data);
new_cell.focus_cell();
- };
+ }
};
/**
@@ -1057,7 +1039,7 @@ var IPython = (function (IPython) {
var new_cell = this.insert_cell_below(cell_data.cell_type);
new_cell.fromJSON(cell_data);
new_cell.focus_cell();
- };
+ }
};
// Split/merge
@@ -1088,7 +1070,7 @@ var IPython = (function (IPython) {
new_cell.unrender();
new_cell.set_text(texta);
}
- };
+ }
};
/**
@@ -1122,10 +1104,10 @@ var IPython = (function (IPython) {
// that of the original selected cell;
cell.render();
}
- };
+ }
this.delete_cell(index-1);
this.select(this.find_cell_index(cell));
- };
+ }
};
/**
@@ -1159,10 +1141,10 @@ var IPython = (function (IPython) {
// that of the original selected cell;
cell.render();
}
- };
+ }
this.delete_cell(index+1);
this.select(this.find_cell_index(cell));
- };
+ }
};
@@ -1365,7 +1347,7 @@ var IPython = (function (IPython) {
* @method start_session
*/
Notebook.prototype.start_session = function () {
- this.session = new IPython.Session(this.notebook_name, this.notebook_path, this);
+ this.session = new IPython.Session(this, this.options);
this.session.start($.proxy(this._session_started, this));
};
@@ -1382,8 +1364,8 @@ var IPython = (function (IPython) {
var cell = this.get_cell(i);
if (cell instanceof IPython.CodeCell) {
cell.set_kernel(this.session.kernel);
- };
- };
+ }
+ }
};
/**
@@ -1424,7 +1406,7 @@ var IPython = (function (IPython) {
this.command_mode();
cell.focus_cell();
this.set_dirty(true);
- }
+ };
/**
* Execute or render cell outputs and insert a new cell below.
@@ -1520,7 +1502,7 @@ var IPython = (function (IPython) {
for (var i=start; i0) {
+ if (nbname.length>0 && !this.notebook_name_blacklist_re.test(nbname)) {
return true;
} else {
return false;
- };
+ }
};
/**
@@ -1577,7 +1559,7 @@ var IPython = (function (IPython) {
for (i=0; i 1) {
IPython.dialog.modal({
title : "Multiple worksheets",
@@ -1630,7 +1612,7 @@ var IPython = (function (IPython) {
var cell_array = new Array(ncells);
for (var i=0; i').append(
$("").addClass("rename-message")
.text('This notebook name already exists.')
- )
+ );
$([IPython.events]).trigger('notebook_rename_failed.Notebook', [xhr, status, error]);
IPython.dialog.modal({
title: "Notebook Rename Error!",
@@ -1896,7 +1880,7 @@ var IPython = (function (IPython) {
that.find('input[type="text"]').focus();
}
});
- }
+ };
/**
* Request a notebook's data from the server.
@@ -1919,7 +1903,7 @@ var IPython = (function (IPython) {
};
$([IPython.events]).trigger('notebook_loading.Notebook');
var url = utils.url_join_encode(
- this._baseProjectUrl,
+ this.base_url,
'api/notebooks',
this.notebook_path,
this.notebook_name
@@ -1946,7 +1930,7 @@ var IPython = (function (IPython) {
} else {
this.select(0);
this.command_mode();
- };
+ }
this.set_dirty(false);
this.scroll_to_top();
if (data.orig_nbformat !== undefined && data.nbformat !== data.orig_nbformat) {
@@ -1971,7 +1955,7 @@ var IPython = (function (IPython) {
var this_vs = 'v' + data.nbformat + '.' + this.nbformat_minor;
var msg = "This notebook is version " + orig_vs + ", but we only fully support up to " +
this_vs + ". You can still work with this notebook, but some features " +
- "introduced in later notebook versions may not be available."
+ "introduced in later notebook versions may not be available.";
IPython.dialog.modal({
title : "Newer Notebook",
@@ -1987,7 +1971,7 @@ var IPython = (function (IPython) {
// Create the session after the notebook is completely loaded to prevent
// code execution upon loading, which is a security risk.
- if (this.session == null) {
+ if (this.session === null) {
this.start_session();
}
// load our checkpoint list
@@ -2012,10 +1996,11 @@ var IPython = (function (IPython) {
*/
Notebook.prototype.load_notebook_error = function (xhr, status, error) {
$([IPython.events]).trigger('notebook_load_failed.Notebook', [xhr, status, error]);
+ var msg;
if (xhr.status === 400) {
- var msg = error;
+ msg = error;
} else if (xhr.status === 500) {
- var msg = "An unknown error occurred while loading this notebook. " +
+ msg = "An unknown error occurred while loading this notebook. " +
"This version can load notebook formats " +
"v" + this.nbformat + " or earlier.";
}
@@ -2026,7 +2011,7 @@ var IPython = (function (IPython) {
"OK": {}
}
});
- }
+ };
/********************* checkpoint-related *********************/
@@ -2069,7 +2054,7 @@ var IPython = (function (IPython) {
*/
Notebook.prototype.list_checkpoints = function () {
var url = utils.url_join_encode(
- this._baseProjectUrl,
+ this.base_url,
'api/notebooks',
this.notebook_path,
this.notebook_name,
@@ -2091,7 +2076,7 @@ var IPython = (function (IPython) {
* @param {jqXHR} xhr jQuery Ajax object
*/
Notebook.prototype.list_checkpoints_success = function (data, status, xhr) {
- var data = $.parseJSON(data);
+ data = $.parseJSON(data);
this.checkpoints = data;
if (data.length) {
this.last_checkpoint = data[data.length - 1];
@@ -2120,9 +2105,9 @@ var IPython = (function (IPython) {
*/
Notebook.prototype.create_checkpoint = function () {
var url = utils.url_join_encode(
- this._baseProjectUrl,
+ this.base_url,
'api/notebooks',
- this.notebookPath(),
+ this.notebook_path,
this.notebook_name,
'checkpoints'
);
@@ -2142,7 +2127,7 @@ var IPython = (function (IPython) {
* @param {jqXHR} xhr jQuery Ajax object
*/
Notebook.prototype.create_checkpoint_success = function (data, status, xhr) {
- var data = $.parseJSON(data);
+ data = $.parseJSON(data);
this.add_checkpoint(data);
$([IPython.events]).trigger('checkpoint_created.Notebook', data);
};
@@ -2161,7 +2146,7 @@ var IPython = (function (IPython) {
Notebook.prototype.restore_checkpoint_dialog = function (checkpoint) {
var that = this;
- var checkpoint = checkpoint || this.last_checkpoint;
+ checkpoint = checkpoint || this.last_checkpoint;
if ( ! checkpoint ) {
console.log("restore dialog, but no checkpoint to restore to!");
return;
@@ -2196,7 +2181,7 @@ var IPython = (function (IPython) {
Cancel : {}
}
});
- }
+ };
/**
* Restore the notebook to a checkpoint state.
@@ -2207,9 +2192,9 @@ var IPython = (function (IPython) {
Notebook.prototype.restore_checkpoint = function (checkpoint) {
$([IPython.events]).trigger('notebook_restoring.Notebook', checkpoint);
var url = utils.url_join_encode(
- this._baseProjectUrl,
+ this.base_url,
'api/notebooks',
- this.notebookPath(),
+ this.notebook_path,
this.notebook_name,
'checkpoints',
checkpoint
@@ -2255,9 +2240,9 @@ var IPython = (function (IPython) {
Notebook.prototype.delete_checkpoint = function (checkpoint) {
$([IPython.events]).trigger('notebook_restoring.Notebook', checkpoint);
var url = utils.url_join_encode(
- this._baseProjectUrl,
+ this.base_url,
'api/notebooks',
- this.notebookPath(),
+ this.notebook_path,
this.notebook_name,
'checkpoints',
checkpoint
diff --git a/IPython/html/static/notebook/js/savewidget.js b/IPython/html/static/notebook/js/savewidget.js
index c6c11f8..87d3ad6 100644
--- a/IPython/html/static/notebook/js/savewidget.js
+++ b/IPython/html/static/notebook/js/savewidget.js
@@ -127,7 +127,7 @@ var IPython = (function (IPython) {
SaveWidget.prototype.update_address_bar = function(){
var nbname = IPython.notebook.notebook_name;
- var path = IPython.notebook.notebookPath();
+ var path = IPython.notebook.notebook_path;
var state = {path : utils.url_join_encode(path, nbname)};
window.history.replaceState(state, "", utils.url_join_encode(
"/notebooks",
diff --git a/IPython/html/static/services/kernels/js/kernel.js b/IPython/html/static/services/kernels/js/kernel.js
index 4d0c45e..c321f55 100644
--- a/IPython/html/static/services/kernels/js/kernel.js
+++ b/IPython/html/static/services/kernels/js/kernel.js
@@ -25,12 +25,12 @@ var IPython = (function (IPython) {
* A Kernel Class to communicate with the Python kernel
* @Class Kernel
*/
- var Kernel = function (base_url) {
+ var Kernel = function (kernel_service_url) {
this.kernel_id = null;
this.shell_channel = null;
this.iopub_channel = null;
this.stdin_channel = null;
- this.base_url = base_url;
+ this.kernel_service_url = kernel_service_url;
this.running = false;
this.username = "username";
this.session_id = utils.uuid();
@@ -94,8 +94,7 @@ var IPython = (function (IPython) {
params = params || {};
if (!this.running) {
var qs = $.param(params);
- var url = this.base_url + '?' + qs;
- $.post(url,
+ $.post(utils.url_join_encode(this.kernel_service_url) + '?' + qs,
$.proxy(this._kernel_started, this),
'json'
);
@@ -114,8 +113,7 @@ var IPython = (function (IPython) {
$([IPython.events]).trigger('status_restarting.Kernel', {kernel: this});
if (this.running) {
this.stop_channels();
- var url = utils.url_join_encode(this.kernel_url, "restart");
- $.post(url,
+ $.post(utils.url_join_encode(this.kernel_url, "restart"),
$.proxy(this._kernel_started, this),
'json'
);
@@ -133,8 +131,10 @@ var IPython = (function (IPython) {
var prot = location.protocol.replace('http', 'ws') + "//";
ws_url = prot + location.host + ws_url;
}
- this.ws_url = ws_url;
- this.kernel_url = utils.url_join_encode(this.base_url, this.kernel_id);
+ var parsed = utils.parse_url(ws_url);
+ this.ws_host = parsed.protocol + "//" + parsed.host;
+ this.kernel_url = utils.url_path_join(this.kernel_service_url, this.kernel_id);
+ this.ws_url = utils.url_path_join(parsed.pathname, this.kernel_url);
this.start_channels();
};
@@ -155,12 +155,18 @@ var IPython = (function (IPython) {
Kernel.prototype.start_channels = function () {
var that = this;
this.stop_channels();
- var ws_url = this.ws_url + this.kernel_url;
- console.log("Starting WebSockets:", ws_url);
- this.shell_channel = new this.WebSocket(ws_url + "/shell");
- this.stdin_channel = new this.WebSocket(ws_url + "/stdin");
- this.iopub_channel = new this.WebSocket(ws_url + "/iopub");
+ console.log("Starting WebSockets:", this.ws_host + this.ws_url);
+ this.shell_channel = new this.WebSocket(
+ this.ws_host + utils.url_join_encode(this.ws_url, "shell")
+ );
+ this.stdin_channel = new this.WebSocket(
+ this.ws_host + utils.url_join_encode(this.ws_url, "stdin")
+ );
+ this.iopub_channel = new this.WebSocket(
+ this.ws_host + utils.url_join_encode(this.ws_url, "iopub")
+ );
+ var ws_host_url = this.ws_host + this.ws_url;
var already_called_onclose = false; // only alert once
var ws_closed_early = function(evt){
if (already_called_onclose){
@@ -168,7 +174,7 @@ var IPython = (function (IPython) {
}
already_called_onclose = true;
if ( ! evt.wasClean ){
- that._websocket_closed(ws_url, true);
+ that._websocket_closed(ws_host_url, true);
}
};
var ws_closed_late = function(evt){
@@ -177,7 +183,7 @@ var IPython = (function (IPython) {
}
already_called_onclose = true;
if ( ! evt.wasClean ){
- that._websocket_closed(ws_url, false);
+ that._websocket_closed(ws_host_url, false);
}
};
var channels = [this.shell_channel, this.iopub_channel, this.stdin_channel];
@@ -387,7 +393,7 @@ var IPython = (function (IPython) {
Kernel.prototype.interrupt = function () {
if (this.running) {
$([IPython.events]).trigger('status_interrupting.Kernel', {kernel: this});
- $.post(this.kernel_url + "/interrupt");
+ $.post(utils.url_join_encode(this.kernel_url, "interrupt"));
}
};
@@ -399,7 +405,7 @@ var IPython = (function (IPython) {
cache : false,
type : "DELETE"
};
- $.ajax(this.kernel_url, settings);
+ $.ajax(utils.url_join_encode(this.kernel_url), settings);
}
};
diff --git a/IPython/html/static/services/sessions/js/session.js b/IPython/html/static/services/sessions/js/session.js
index 0f0c4a9..bb3ab6c 100644
--- a/IPython/html/static/services/sessions/js/session.js
+++ b/IPython/html/static/services/sessions/js/session.js
@@ -14,13 +14,14 @@ var IPython = (function (IPython) {
var utils = IPython.utils;
- var Session = function(notebook_name, notebook_path, notebook){
+ var Session = function(notebook, options){
this.kernel = null;
this.id = null;
- this.name = notebook_name;
- this.path = notebook_path;
this.notebook = notebook;
- this._baseProjectUrl = notebook.baseProjectUrl();
+ this.name = notebook.notebook_name;
+ this.path = notebook.notebook_path;
+ this.base_url = notebook.base_url;
+ this.base_kernel_url = options.base_kernel_url || utils.get_body_data("baseKernelUrl");
};
Session.prototype.start = function(callback) {
@@ -44,7 +45,7 @@ var IPython = (function (IPython) {
}
},
};
- var url = utils.url_join_encode(this._baseProjectUrl, 'api/sessions');
+ var url = utils.url_join_encode(this.base_url, 'api/sessions');
$.ajax(url, settings);
};
@@ -64,7 +65,7 @@ var IPython = (function (IPython) {
data: JSON.stringify(model),
dataType : "json",
};
- var url = utils.url_join_encode(this._baseProjectUrl, 'api/sessions', this.id);
+ var url = utils.url_join_encode(this.base_url, 'api/sessions', this.id);
$.ajax(url, settings);
};
@@ -76,7 +77,7 @@ var IPython = (function (IPython) {
dataType : "json",
};
this.kernel.running = false;
- var url = utils.url_join_encode(this._baseProjectUrl, 'api/sessions', this.id);
+ var url = utils.url_join_encode(this.base_url, 'api/sessions', this.id);
$.ajax(url, settings);
};
@@ -88,8 +89,8 @@ var IPython = (function (IPython) {
*/
Session.prototype._handle_start_success = function (data, status, xhr) {
this.id = data.id;
- var base_url = utils.url_path_join($('body').data('baseKernelUrl'), "api/kernels");
- this.kernel = new IPython.Kernel(base_url);
+ var kernel_service_url = utils.url_path_join(this.base_kernel_url, "api/kernels");
+ this.kernel = new IPython.Kernel(kernel_service_url);
this.kernel._kernel_started(data.kernel);
};
diff --git a/IPython/html/static/tree/js/clusterlist.js b/IPython/html/static/tree/js/clusterlist.js
index 9d607d5..48de0d3 100644
--- a/IPython/html/static/tree/js/clusterlist.js
+++ b/IPython/html/static/tree/js/clusterlist.js
@@ -14,17 +14,17 @@ var IPython = (function (IPython) {
var utils = IPython.utils;
- var ClusterList = function (selector) {
+ var ClusterList = function (selector, options) {
this.selector = selector;
if (this.selector !== undefined) {
this.element = $(selector);
this.style();
this.bind_events();
}
- };
-
- ClusterList.prototype.baseProjectUrl = function(){
- return this._baseProjectUrl || $('body').data('baseProjectUrl');
+ 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 () {
@@ -51,7 +51,7 @@ var IPython = (function (IPython) {
dataType : "json",
success : $.proxy(this.load_list_success, this)
};
- var url = utils.url_join_encode(this.baseProjectUrl(), 'clusters');
+ var url = utils.url_join_encode(this.base_url, 'clusters');
$.ajax(url, settings);
};
@@ -65,7 +65,7 @@ var IPython = (function (IPython) {
var len = data.length;
for (var i=0; i');
- var item = new ClusterItem(element);
+ var item = new ClusterItem(element, this.options);
item.update_state(data[i]);
element.data('item', item);
this.element.append(element);
@@ -73,17 +73,14 @@ var IPython = (function (IPython) {
};
- var ClusterItem = function (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.baseProjectUrl = function(){
- return this._baseProjectUrl || $('body').data('baseProjectUrl');
- };
-
-
ClusterItem.prototype.style = function () {
this.element.addClass('list_item').addClass("row-fluid");
};
@@ -138,7 +135,7 @@ var IPython = (function (IPython) {
};
status_col.text('starting');
var url = utils.url_join_encode(
- that.baseProjectUrl(),
+ that.base_url,
'clusters',
that.data.profile,
'start'
@@ -180,7 +177,7 @@ var IPython = (function (IPython) {
};
status_col.text('stopping');
var url = utils.url_join_encode(
- that.baseProjectUrl(),
+ that.base_url,
'clusters',
that.data.profile,
'stop'
diff --git a/IPython/html/static/tree/js/main.js b/IPython/html/static/tree/js/main.js
index ddcd9da..d66bb68 100644
--- a/IPython/html/static/tree/js/main.js
+++ b/IPython/html/static/tree/js/main.js
@@ -15,12 +15,16 @@ $(document).ready(function () {
IPython.page = new IPython.Page();
$('#new_notebook').button().click(function (e) {
- IPython.notebook_list.new_notebook($('body').data('baseProjectUrl'))
+ IPython.notebook_list.new_notebook()
});
-
- IPython.notebook_list = new IPython.NotebookList('#notebook_list');
- IPython.cluster_list = new IPython.ClusterList('#cluster_list');
- IPython.login_widget = new IPython.LoginWidget('#login_widget');
+
+ var opts = {
+ base_url : IPython.utils.get_body_data("baseUrl"),
+ notebook_path : IPython.utils.get_body_data("notebookPath"),
+ };
+ IPython.notebook_list = new IPython.NotebookList('#notebook_list', opts);
+ IPython.cluster_list = new IPython.ClusterList('#cluster_list', opts);
+ IPython.login_widget = new IPython.LoginWidget('#login_widget', opts);
var interval_id=0;
// auto refresh every xx secondes, no need to be fast,
diff --git a/IPython/html/static/tree/js/notebooklist.js b/IPython/html/static/tree/js/notebooklist.js
index e92c343..fbfed9d 100644
--- a/IPython/html/static/tree/js/notebooklist.js
+++ b/IPython/html/static/tree/js/notebooklist.js
@@ -14,7 +14,7 @@ var IPython = (function (IPython) {
var utils = IPython.utils;
- var NotebookList = function (selector) {
+ var NotebookList = function (selector, options) {
this.selector = selector;
if (this.selector !== undefined) {
this.element = $(selector);
@@ -23,16 +23,10 @@ var IPython = (function (IPython) {
}
this.notebooks_list = [];
this.sessions = {};
+ this.base_url = options.base_url || utils.get_body_data("baseUrl");
+ this.notebook_path = options.notebook_path || utils.get_body_data("notebookPath");
};
- NotebookList.prototype.baseProjectUrl = function () {
- return $('body').data('baseProjectUrl');
- };
-
- NotebookList.prototype.notebookPath = function() {
- return $('body').data('notebookPath');
- };
-
NotebookList.prototype.style = function () {
$('#notebook_toolbar').addClass('list_toolbar');
$('#drag_info').addClass('toolbar_info');
@@ -112,7 +106,7 @@ var IPython = (function (IPython) {
dataType : "json",
success : $.proxy(that.sessions_loaded, this)
};
- var url = this.baseProjectUrl() + 'api/sessions';
+ var url = utils.url_join_encode(this.base_url, 'api/sessions');
$.ajax(url,settings);
};
@@ -152,10 +146,10 @@ var IPython = (function (IPython) {
};
var url = utils.url_join_encode(
- this.baseProjectUrl(),
+ this.base_url,
'api',
'notebooks',
- this.notebookPath()
+ this.notebook_path
);
$.ajax(url, settings);
};
@@ -175,7 +169,7 @@ var IPython = (function (IPython) {
span12.empty();
span12.append($('').text(message));
}
- var path = this.notebookPath();
+ var path = this.notebook_path;
var offset = 0;
if (path !== '') {
item = this.new_notebook_item(0);
@@ -233,7 +227,7 @@ var IPython = (function (IPython) {
item.find("a.item_link")
.attr('href',
utils.url_join_encode(
- this.baseProjectUrl(),
+ this.base_url,
"tree",
path,
name
@@ -250,7 +244,7 @@ var IPython = (function (IPython) {
item.find("a.item_link")
.attr('href',
utils.url_join_encode(
- this.baseProjectUrl(),
+ this.base_url,
"notebooks",
path,
nbname
@@ -291,7 +285,7 @@ var IPython = (function (IPython) {
}
};
var url = utils.url_join_encode(
- that.baseProjectUrl(),
+ that.base_url,
'api/sessions',
session
);
@@ -331,9 +325,9 @@ var IPython = (function (IPython) {
}
};
var url = utils.url_join_encode(
- notebooklist.baseProjectUrl(),
+ notebooklist.base_url,
'api/notebooks',
- notebooklist.notebookPath(),
+ notebooklist.notebook_path,
nbname
);
$.ajax(url, settings);
@@ -357,7 +351,7 @@ var IPython = (function (IPython) {
if (nbname.slice(nbname.length-6, nbname.length) != ".ipynb") {
nbname = nbname + ".ipynb";
}
- var path = that.notebookPath();
+ var path = that.notebook_path;
var nbdata = item.data('nbdata');
var content_type = 'application/json';
var model = {
@@ -380,9 +374,9 @@ var IPython = (function (IPython) {
};
var url = utils.url_join_encode(
- that.baseProjectUrl(),
+ that.base_url,
'api/notebooks',
- that.notebookPath(),
+ that.notebook_path,
nbname
);
$.ajax(url, settings);
@@ -402,8 +396,8 @@ var IPython = (function (IPython) {
NotebookList.prototype.new_notebook = function(){
- var path = this.notebookPath();
- var base_project_url = this.baseProjectUrl();
+ var path = this.notebook_path;
+ var base_url = this.base_url;
var settings = {
processData : false,
cache : false,
@@ -414,7 +408,7 @@ var IPython = (function (IPython) {
var notebook_name = data.name;
window.open(
utils.url_join_encode(
- base_project_url,
+ base_url,
'notebooks',
path,
notebook_name),
@@ -423,7 +417,7 @@ var IPython = (function (IPython) {
}
};
var url = utils.url_join_encode(
- base_project_url,
+ base_url,
'api/notebooks',
path
);
diff --git a/IPython/html/templates/login.html b/IPython/html/templates/login.html
index f388c6e..7244bee 100644
--- a/IPython/html/templates/login.html
+++ b/IPython/html/templates/login.html
@@ -20,7 +20,7 @@
Password:
-
diff --git a/IPython/html/templates/logout.html b/IPython/html/templates/logout.html
index 5efbe8b..35c65c5 100644
--- a/IPython/html/templates/logout.html
+++ b/IPython/html/templates/logout.html
@@ -21,9 +21,9 @@
{% endif %}
{% if not login_available %}
- Proceed to the
dashboard.
+ Proceed to the
dashboard.
{% else %}
- Proceed to the
login page.
+ Proceed to the
login page.
{% endif %}
diff --git a/IPython/html/templates/notebook.html b/IPython/html/templates/notebook.html
index 5020713..b05ec42 100644
--- a/IPython/html/templates/notebook.html
+++ b/IPython/html/templates/notebook.html
@@ -22,7 +22,7 @@ window.mathjax_url = "{{mathjax_url}}";
{% block params %}
data-project="{{project}}"
-data-base-project-url="{{base_project_url}}"
+data-base-url="{{base_url}}"
data-base-kernel-url="{{base_kernel_url}}"
data-notebook-name="{{notebook_name}}"
data-notebook-path="{{notebook_path}}"
diff --git a/IPython/html/templates/page.html b/IPython/html/templates/page.html
index a9751b6..4d882f4 100644
--- a/IPython/html/templates/page.html
+++ b/IPython/html/templates/page.html
@@ -21,7 +21,7 @@
require.config({
baseUrl: '{{static_url("")}}',
paths: {
- nbextensions : '{{ base_project_url }}nbextensions',
+ nbextensions : '{{ base_url }}nbextensions',
underscore : '{{static_url("components/underscore/underscore-min")}}',
backbone : '{{static_url("components/backbone/backbone-min")}}',
},
@@ -54,7 +54,7 @@