From 85897890dde4f072f72111dfed48b001f73dcfee 2013-08-10 17:17:16 From: MinRK Date: 2013-08-10 17:17:16 Subject: [PATCH] Backport PR #3939: minor checkpoint cleanup - remember list of checkpoints browser-side - don't clobber list when a new checkpoint is created - cleanup references in MenuBar restore list. There was a closure issue, where multiple menu items would actually all restore the same checkpoint. Issues revealed by rgbkrk/bookstore, which supports multiple checkpoints. I'm fine if this doesn't get into 1.0, given timing. --- diff --git a/IPython/html/static/notebook/js/menubar.js b/IPython/html/static/notebook/js/menubar.js index 985de1e..4c32551 100644 --- a/IPython/html/static/notebook/js/menubar.js +++ b/IPython/html/static/notebook/js/menubar.js @@ -224,11 +224,11 @@ var IPython = (function (IPython) { this.update_restore_checkpoint(null); $([IPython.events]).on('checkpoints_listed.Notebook', function (event, data) { - that.update_restore_checkpoint(data); + that.update_restore_checkpoint(IPython.notebook.checkpoints); }); $([IPython.events]).on('checkpoint_created.Notebook', function (event, data) { - that.update_restore_checkpoint([data]); + that.update_restore_checkpoint(IPython.notebook.checkpoints); }); }; @@ -247,8 +247,7 @@ var IPython = (function (IPython) { return; }; - for (var i = 0; i < checkpoints.length; i++) { - var checkpoint = checkpoints[i]; + checkpoints.map(function (checkpoint) { var d = new Date(checkpoint.last_modified); ul.append( $("
  • ").append( @@ -260,7 +259,7 @@ var IPython = (function (IPython) { }) ) ); - }; + }); }; IPython.MenuBar = MenuBar; diff --git a/IPython/html/static/notebook/js/notebook.js b/IPython/html/static/notebook/js/notebook.js index 8d6ffd1..488364b 100644 --- a/IPython/html/static/notebook/js/notebook.js +++ b/IPython/html/static/notebook/js/notebook.js @@ -40,6 +40,7 @@ var IPython = (function (IPython) { this.metadata = {}; this._checkpoint_after_save = false; this.last_checkpoint = null; + this.checkpoints = []; this.autosave_interval = 0; this.autosave_timer = null; // autosave *at most* every two minutes @@ -1826,9 +1827,31 @@ var IPython = (function (IPython) { }; /** + * Add a checkpoint for this notebook. + * for use as a callback from checkpoint creation. + * + * @method add_checkpoint + */ + Notebook.prototype.add_checkpoint = function (checkpoint) { + var found = false; + for (var i = 0; i < this.checkpoints.length; i++) { + var existing = this.checkpoints[i]; + if (existing.checkpoint_id == checkpoint.checkpoint_id) { + found = true; + this.checkpoints[i] = checkpoint; + break; + } + } + if (!found) { + this.checkpoints.push(checkpoint); + } + this.last_checkpoint = this.checkpoints[this.checkpoints.length - 1]; + }; + + /** * List checkpoints for this notebook. * - * @method list_checkpoint + * @method list_checkpoints */ Notebook.prototype.list_checkpoints = function () { var url = this.baseProjectUrl() + 'notebooks/' + this.notebook_id + '/checkpoints'; @@ -1849,8 +1872,9 @@ var IPython = (function (IPython) { */ Notebook.prototype.list_checkpoints_success = function (data, status, xhr) { var data = $.parseJSON(data); + this.checkpoints = data; if (data.length) { - this.last_checkpoint = data[0]; + this.last_checkpoint = data[data.length - 1]; } else { this.last_checkpoint = null; } @@ -1893,7 +1917,7 @@ var IPython = (function (IPython) { */ Notebook.prototype.create_checkpoint_success = function (data, status, xhr) { var data = $.parseJSON(data); - this.last_checkpoint = data; + this.add_checkpoint(data); $([IPython.events]).trigger('checkpoint_created.Notebook', data); };