From 133e44d3a32b7d93eff9ee27d109f8dda5f5cb8d Mon Sep 17 00:00:00 2001 From: Don Naegely Date: Mon, 8 Sep 2014 13:51:18 -0400 Subject: [PATCH] Don't hide loading overlay until variant data is returned This fixes a bug where the loading overlay was being hidden by Cilantro as soon as the call to /api/data/preview/ returned which was problematic in Varify because the variant data is not retrieved by that call but instead comes back in a successive call to /api/samples/variants/. The loading overlay is now hidden after that second call. Signed-off-by: Don Naegely --- varify/static/js/src/ui/tables/body.js | 7 ++++++- varify/static/js/src/ui/workflows/results.js | 16 +++++++++++++++- 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/varify/static/js/src/ui/tables/body.js b/varify/static/js/src/ui/tables/body.js index 8ca9cfb2..dba621e2 100644 --- a/varify/static/js/src/ui/tables/body.js +++ b/varify/static/js/src/ui/tables/body.js @@ -24,11 +24,16 @@ define([ }, _fetch: function() { + var _this = this; + this.collection.fetch({ data: JSON.stringify({ids: this._collection.pluck('pk')}), type: 'POST', contentType: 'application/json', - parse: true + parse: true, + success: function() { + _this.trigger('synced'); + } }); }, diff --git a/varify/static/js/src/ui/workflows/results.js b/varify/static/js/src/ui/workflows/results.js index 268fa781..b2292439 100644 --- a/varify/static/js/src/ui/workflows/results.js +++ b/varify/static/js/src/ui/workflows/results.js @@ -53,8 +53,19 @@ define([ }, initialize: function() { + _.bindAll(this, 'hideLoadingOverlay'); + c.ui.ResultsWorkflow.prototype.initialize.call(this); + // We will manage the hiding of the loading overlay ourselves. The + // call to the preview endpoint returns the variant IDs. The actual + // variant data is retrieved by another call after the call to the + // preview endpoint comes back so we cannot let Cilantro hide the + // overlay after the preview endpoint syncs like it normally does. + // Insted, we need to hide it after the variant collection becomes + // synced. + this.stopListening(this.data.results, 'sync'); + // The Cilantro workflow no longer requires the context but we // need it to have any hope of referencing the sample name in the // result count. The data object will already have been initialized @@ -85,7 +96,10 @@ define([ view: this.data.view, collection: this.data.results })); - + // When the body of the table reports that it is synced, then the + // variant data has arrived and we can now hide the loading + // overlay. + this.table.currentView.on('itemview:synced', this.hideLoadingOverlay); this.ui.navbarButtons.tooltip({ animation: false,