From 5f2fa44dee1eb9b1bdc59a76dab6345b47dda186 Mon Sep 17 00:00:00 2001 From: Scott Taylor Date: Wed, 6 Aug 2014 21:43:26 +0000 Subject: [PATCH] Media Grid: expose the `$.Deffered()` object in `media.view.AttachmentsBrowser.updateContent()` so the grid can call `Backbone.history.start()` when models actually exist. This is a lot better then `_.delay( this.pray, 1000 )`, but needs continued study. See #29052. git-svn-id: https://develop.svn.wordpress.org/trunk@29420 602fd350-edb4-49c9-b593-d223f7449a82 --- src/wp-includes/js/media-grid.js | 32 ++++++++++++++++--------------- src/wp-includes/js/media-views.js | 4 ++-- 2 files changed, 19 insertions(+), 17 deletions(-) diff --git a/src/wp-includes/js/media-grid.js b/src/wp-includes/js/media-grid.js index 567702709f..99b28ff292 100644 --- a/src/wp-includes/js/media-grid.js +++ b/src/wp-includes/js/media-grid.js @@ -91,6 +91,8 @@ this.options.uploader = false; } + this.gridRouter = new media.view.MediaFrame.Manage.Router(); + // Call 'initialize' directly on the parent class. media.view.MediaFrame.prototype.initialize.apply( this, arguments ); @@ -109,21 +111,6 @@ } self.gridRouter.navigate( self.gridRouter.baseUrl( url ) ); }, 1000 ) ); - - // This is problematic. - _.delay( _.bind( this.createRouter, this ), 1000 ); - }, - - createRouter: function() { - this.gridRouter = new media.view.MediaFrame.Manage.Router(); - - // Verify pushState support and activate - if ( window.history && window.history.pushState ) { - Backbone.history.start({ - root: _wpMediaGridSettings.adminUrl, - pushState: true - }); - } }, /** @@ -210,6 +197,7 @@ scrollElement: document }); + this.browserView.on( 'ready', _.bind( this.bindDeferred, this ) ); this.errors = wp.Uploader.errors; this.errors.on( 'add remove reset', this.sidebarVisibility, this ); @@ -217,6 +205,20 @@ sidebarVisibility: function() { this.browserView.$( '.media-sidebar' ).toggle( this.errors.length ); + }, + + bindDeferred: function() { + this.browserView.dfd.done( _.bind( this.startHistory, this ) ); + }, + + startHistory: function() { + // Verify pushState support and activate + if ( window.history && window.history.pushState ) { + Backbone.history.start( { + root: _wpMediaGridSettings.adminUrl, + pushState: true + } ); + } } }); diff --git a/src/wp-includes/js/media-views.js b/src/wp-includes/js/media-views.js index fc35be075b..0eefa3db8f 100644 --- a/src/wp-includes/js/media-views.js +++ b/src/wp-includes/js/media-views.js @@ -5819,14 +5819,14 @@ if ( ! this.collection.length ) { this.toolbar.get( 'spinner' ).show(); - this.collection.more().done(function() { + this.dfd = this.collection.more().done( function() { if ( ! view.collection.length ) { noItemsView.$el.removeClass( 'hidden' ); } else { noItemsView.$el.addClass( 'hidden' ); } view.toolbar.get( 'spinner' ).hide(); - }); + } ); } else { noItemsView.$el.addClass( 'hidden' ); view.toolbar.get( 'spinner' ).hide();