Revisions: Code and whitespace cleanup.
See #24425. git-svn-id: https://develop.svn.wordpress.org/trunk@24679 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
db9e747264
commit
f215ae599a
@ -737,9 +737,7 @@ window.wp = window.wp || {};
|
|||||||
currentModelIndex = this.model.revisions.length - 1;
|
currentModelIndex = this.model.revisions.length - 1;
|
||||||
|
|
||||||
// Update the tooltip model
|
// Update the tooltip model
|
||||||
this.model.set({
|
this.model.set({ hoveredRevision: this.model.revisions.at( currentModelIndex ) });
|
||||||
'hoveredRevision': this.model.revisions.at( currentModelIndex )
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
mouseLeave: function() {
|
mouseLeave: function() {
|
||||||
@ -827,21 +825,20 @@ window.wp = window.wp || {};
|
|||||||
|
|
||||||
// Responds to slide events
|
// Responds to slide events
|
||||||
slide: function( event, ui ) {
|
slide: function( event, ui ) {
|
||||||
var attributes, movedRevision;
|
var attributes, movedRevision, sliderPosition;
|
||||||
// Compare two revisions mode
|
// Compare two revisions mode
|
||||||
if ( ! _.isUndefined( ui.values ) && this.model.get('compareTwoMode') ) {
|
if ( this.model.get('compareTwoMode') ) {
|
||||||
// Prevent sliders from occupying same spot
|
// Prevent sliders from occupying same spot
|
||||||
if ( ui.values[1] === ui.values[0] )
|
if ( ui.values[1] === ui.values[0] )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
attributes = {
|
attributes = {
|
||||||
to: this.model.revisions.at( isRtl ? this.model.revisions.length - ui.values[0] - 1 : ui.values[1] ), // Reverse directions for RTL.
|
to: this.model.revisions.at( isRtl ? this.model.revisions.length - ui.values[0] - 1 : ui.values[1] ),
|
||||||
from: this.model.revisions.at( isRtl ? this.model.revisions.length - ui.values[1] - 1 : ui.values[0] ) // Reverse directions for RTL.
|
from: this.model.revisions.at( isRtl ? this.model.revisions.length - ui.values[1] - 1 : ui.values[0] )
|
||||||
};
|
};
|
||||||
movedRevision = ! isRtl && ui.value === ui.values[0] ? attributes.from : attributes.to;
|
movedRevision = ! isRtl && ui.value === ui.values[0] ? attributes.from : attributes.to;
|
||||||
} else {
|
} else {
|
||||||
// Compare single revision mode
|
sliderPosition = this.getSliderPosition( ui );
|
||||||
var sliderPosition = this.getSliderPosition( ui );
|
|
||||||
attributes = {
|
attributes = {
|
||||||
to: this.model.revisions.at( sliderPosition )
|
to: this.model.revisions.at( sliderPosition )
|
||||||
};
|
};
|
||||||
@ -884,20 +881,15 @@ window.wp = window.wp || {};
|
|||||||
revisions.Router = Backbone.Router.extend({
|
revisions.Router = Backbone.Router.extend({
|
||||||
initialize: function( options ) {
|
initialize: function( options ) {
|
||||||
this.model = options.model;
|
this.model = options.model;
|
||||||
this.routes = this.getRoutes();
|
this.routes = _.object([
|
||||||
|
[ this.baseUrl( '?from=:from&to=:to' ), 'handleRoute' ],
|
||||||
// Maintain state history when dragging/clicking
|
[ this.baseUrl( '?from=:from&to=:to' ), 'handleRoute' ]
|
||||||
|
]);
|
||||||
|
// Maintain state and history when navigating
|
||||||
this.listenTo( this.model, 'update:diff', _.debounce( this.updateUrl, 250 ) );
|
this.listenTo( this.model, 'update:diff', _.debounce( this.updateUrl, 250 ) );
|
||||||
this.listenTo( this.model, 'change:compareTwoMode', this.updateUrl );
|
this.listenTo( this.model, 'change:compareTwoMode', this.updateUrl );
|
||||||
},
|
},
|
||||||
|
|
||||||
getRoutes: function() {
|
|
||||||
var routes = {};
|
|
||||||
routes[this.baseUrl( '?from=:from&to=:to' )] = 'handleRoute';
|
|
||||||
routes[this.baseUrl( '?revision=:to' )] = 'handleRoute';
|
|
||||||
return routes;
|
|
||||||
},
|
|
||||||
|
|
||||||
baseUrl: function( url ) {
|
baseUrl: function( url ) {
|
||||||
return this.model.get('baseUrl') + url;
|
return this.model.get('baseUrl') + url;
|
||||||
},
|
},
|
||||||
@ -912,35 +904,21 @@ window.wp = window.wp || {};
|
|||||||
},
|
},
|
||||||
|
|
||||||
handleRoute: function( a, b ) {
|
handleRoute: function( a, b ) {
|
||||||
var from, to, compareTwo;
|
var from, to, compareTwo = _.isUndefined( b );
|
||||||
|
|
||||||
// If `b` is undefined, this is an 'at/:to' route, for a single revision
|
if ( ! compareTwo ) {
|
||||||
if ( _.isUndefined( b ) ) {
|
|
||||||
b = this.model.revisions.get( a );
|
b = this.model.revisions.get( a );
|
||||||
a = this.model.revisions.prev( b );
|
a = this.model.revisions.prev( b );
|
||||||
b = b ? b.id : 0;
|
b = b ? b.id : 0;
|
||||||
a = a ? a.id : 0;
|
a = a ? a.id : 0;
|
||||||
compareTwo = false;
|
|
||||||
} else {
|
|
||||||
compareTwo = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
from = parseInt( a, 10 );
|
|
||||||
to = parseInt( b, 10 );
|
|
||||||
|
|
||||||
this.model.set({ compareTwoMode: compareTwo });
|
|
||||||
|
|
||||||
if ( ! _.isUndefined( this.model ) ) {
|
|
||||||
var selectedToRevision = this.model.revisions.get( to ),
|
|
||||||
selectedFromRevision = this.model.revisions.get( from );
|
|
||||||
|
|
||||||
this.model.set({
|
this.model.set({
|
||||||
to: selectedToRevision,
|
from: this.model.revisions.get( parseInt( a, 10 ) ),
|
||||||
from: selectedFromRevision
|
to: this.model.revisions.get( parseInt( a, 10 ) ),
|
||||||
|
compareTwoMode: compareTwo
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
revisions.settings.to = to;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Initialize the revisions UI.
|
// Initialize the revisions UI.
|
||||||
|
Loading…
Reference in New Issue
Block a user