Revisions: Re-work how tick marks and tooltips are aligned. IE fixes.
* Pixel-based alignment of tooltips. * Bottom-based alignment, so arrow lines up using CSS only. * Better RTL styles (mostly mirror-imaged). * Better RTL calculations in `revisions.js` (less logic). * Better IE support. See #24736. Props markjaquith, adamsilverstein, ocean90. git-svn-id: https://develop.svn.wordpress.org/trunk@24751 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
e216254c06
commit
a8611d2a13
@ -1486,7 +1486,7 @@ table.diff .diff-addedline ins {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.revisions-tooltip,
|
.revisions-tooltip,
|
||||||
.revisions-tooltip-arrow:after {
|
.revisions-tooltip-arrow span {
|
||||||
border-color: #d1e5ee;
|
border-color: #d1e5ee;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
}
|
}
|
||||||
|
@ -1380,16 +1380,11 @@ table.diff .diff-addedline ins {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.revisions-tooltip,
|
.revisions-tooltip,
|
||||||
.revisions-tooltip-arrow:after {
|
.revisions-tooltip-arrow span {
|
||||||
border-color: #d7d7d7;
|
border-color: #d7d7d7;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
.revisions-tickmarks {
|
|
||||||
background-color: #f7f7f7;
|
|
||||||
}
|
|
||||||
|
|
||||||
.revisions-tickmarks > div {
|
.revisions-tickmarks > div {
|
||||||
border-color: #aaa;
|
border-color: #aaa;
|
||||||
}
|
}
|
||||||
|
@ -630,3 +630,16 @@ table.ie-fixed {
|
|||||||
* html #adminmenu div.wp-menu-image {
|
* html #adminmenu div.wp-menu-image {
|
||||||
height: 29px;
|
height: 29px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Revisions */
|
||||||
|
.revisions-tooltip-arrow span {
|
||||||
|
left: 25px;
|
||||||
|
top: -24px;
|
||||||
|
filter: progid:DXImageTransform.Microsoft.Matrix(SizingMethod='auto expand', M11=0.7071067811865476, M12=-0.7071067811865475, M21=0.7071067811865475, M22=0.7071067811865476); /* IE7 */
|
||||||
|
}
|
||||||
|
|
||||||
|
.revisions-controls .revisions-tickmarks > div {
|
||||||
|
margin-right: -1px;
|
||||||
|
border-width: 0 0 0 0;
|
||||||
|
border-style: none;
|
||||||
|
}
|
@ -954,18 +954,18 @@ th.sorted a span {
|
|||||||
/*------------------------------------------------------------------------------
|
/*------------------------------------------------------------------------------
|
||||||
11.2 - Post Revisions
|
11.2 - Post Revisions
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
.wp-slider .ui-slider-handle.left-handle:before,
|
.wp-slider .ui-slider-handle.from-handle:before,
|
||||||
.wp-slider .ui-slider-handle.right-handle:before {
|
.wp-slider .ui-slider-handle.to-handle:before {
|
||||||
height: 8px;
|
height: 8px;
|
||||||
width: 7px;
|
width: 7px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.wp-slider .ui-slider-handle.left-handle:before {
|
.wp-slider .ui-slider-handle.from-handle:before {
|
||||||
background-position: -5px -10px;
|
background-position: -5px -10px;
|
||||||
left: 6px;
|
left: 6px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.wp-slider .ui-slider-handle.right-handle:before {
|
.wp-slider .ui-slider-handle.to-handle:before {
|
||||||
background-position: -4px -29px;
|
background-position: -4px -29px;
|
||||||
left: 6px;
|
left: 6px;
|
||||||
}
|
}
|
||||||
@ -1025,8 +1025,8 @@ th.sorted a span {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.revisions-tooltip {
|
.revisions-tooltip {
|
||||||
margin-right: -73px;
|
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
|
margin-right: -70px;
|
||||||
-webkit-transition: right 15ms;
|
-webkit-transition: right 15ms;
|
||||||
-moz-transition: right 15ms;
|
-moz-transition: right 15ms;
|
||||||
-ms-transition: right 15ms;
|
-ms-transition: right 15ms;
|
||||||
@ -1034,17 +1034,30 @@ th.sorted a span {
|
|||||||
transition: right 15ms;
|
transition: right 15ms;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.ie8 .revisions-tooltip {
|
||||||
|
margin-right: -75px;
|
||||||
|
}
|
||||||
|
|
||||||
.revisions-tooltip-arrow {
|
.revisions-tooltip-arrow {
|
||||||
right: 0;
|
right: 0;
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
margin-right: 35px;
|
margin-right: 35px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.revisions-tooltip-image {
|
.revisions-tooltip-arrow > span {
|
||||||
|
right: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.revisions-tooltip img {
|
||||||
float: right;
|
float: right;
|
||||||
margin: 2px 0 0 5px;
|
margin: 2px 0 0 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.revisions-tickmarks > div {
|
||||||
|
float: right;
|
||||||
|
border-width: 0 0 0 1px;
|
||||||
|
}
|
||||||
|
|
||||||
/*------------------------------------------------------------------------------
|
/*------------------------------------------------------------------------------
|
||||||
11.3 - Featured Images
|
11.3 - Featured Images
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
|
@ -3511,10 +3511,6 @@ td.plugin-title p {
|
|||||||
/*------------------------------------------------------------------------------
|
/*------------------------------------------------------------------------------
|
||||||
11.2 - Post Revisions
|
11.2 - Post Revisions
|
||||||
------------------------------------------------------------------------------*/
|
------------------------------------------------------------------------------*/
|
||||||
body.revision-php {
|
|
||||||
overflow-y: scroll; /* Force a scrollbar, so centering doesn't jump */
|
|
||||||
}
|
|
||||||
|
|
||||||
.revisions-control-frame,
|
.revisions-control-frame,
|
||||||
.revisions-diff-frame {
|
.revisions-diff-frame {
|
||||||
position: relative;
|
position: relative;
|
||||||
@ -3533,14 +3529,14 @@ body.revision-php {
|
|||||||
|
|
||||||
.revisions-tickmarks {
|
.revisions-tickmarks {
|
||||||
position: relative;
|
position: relative;
|
||||||
margin: 0 auto 0;
|
margin: 0 auto;
|
||||||
height: 0.8em;
|
height: 0.8em;
|
||||||
z-index: 2;
|
z-index: 2;
|
||||||
top: 7px;
|
top: 7px;
|
||||||
width: 70%;
|
width: 100%;
|
||||||
|
padding: 0 15%;
|
||||||
-moz-box-sizing: border-box;
|
-moz-box-sizing: border-box;
|
||||||
-webkit-box-sizing: border-box;
|
-webkit-box-sizing: border-box;
|
||||||
-ms-box-sizing: border-box; /* ie8 only */
|
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3548,17 +3544,16 @@ body.revision-php {
|
|||||||
position: relative;
|
position: relative;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
float: left;
|
float: left;
|
||||||
z-index: 10002;
|
z-index: 3;
|
||||||
border-style: solid;
|
border-style: solid;
|
||||||
border-width: 0 0 0 1px;
|
border-width: 0 1px 0 0;
|
||||||
-moz-box-sizing: border-box;
|
-moz-box-sizing: border-box;
|
||||||
-webkit-box-sizing: border-box;
|
-webkit-box-sizing: border-box;
|
||||||
-ms-box-sizing: border-box; /* ie8 only */
|
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
.revisions-tickmarks > div:first-of-type {
|
.revisions-tickmarks > div:last-child {
|
||||||
border-left-width: 0;
|
border-width: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.comparing-two-revisions .revisions-controls {
|
.comparing-two-revisions .revisions-controls {
|
||||||
@ -3588,6 +3583,7 @@ body.revision-php {
|
|||||||
-ms-transition: opacity 0.5s;
|
-ms-transition: opacity 0.5s;
|
||||||
-o-transition: opacity 0.5s;
|
-o-transition: opacity 0.5s;
|
||||||
transition: opacity 0.5s;
|
transition: opacity 0.5s;
|
||||||
|
filter: alpha(opacity=0); /* ie8 and earlier */
|
||||||
}
|
}
|
||||||
|
|
||||||
.revisions .loading-indicator span.spinner {
|
.revisions .loading-indicator span.spinner {
|
||||||
@ -3598,6 +3594,7 @@ body.revision-php {
|
|||||||
|
|
||||||
.revisions.loading .loading-indicator {
|
.revisions.loading .loading-indicator {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
|
filter: alpha(opacity=100); /* ie8 and earlier */
|
||||||
}
|
}
|
||||||
|
|
||||||
.revisions .diff {
|
.revisions .diff {
|
||||||
@ -3610,6 +3607,7 @@ body.revision-php {
|
|||||||
|
|
||||||
.revisions.loading .diff {
|
.revisions.loading .diff {
|
||||||
opacity: 0.5;
|
opacity: 0.5;
|
||||||
|
filter: alpha(opacity=50); /* ie8 and earlier */
|
||||||
}
|
}
|
||||||
|
|
||||||
.revisions.diff-error .diff {
|
.revisions.diff-error .diff {
|
||||||
@ -3631,6 +3629,12 @@ body.revision-php {
|
|||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.revisions-previous,
|
||||||
|
.revisions-next {
|
||||||
|
position: relative;
|
||||||
|
z-index: 4;
|
||||||
|
}
|
||||||
|
|
||||||
.revisions-previous {
|
.revisions-previous {
|
||||||
float: left;
|
float: left;
|
||||||
}
|
}
|
||||||
@ -3641,7 +3645,7 @@ body.revision-php {
|
|||||||
|
|
||||||
.wp-slider {
|
.wp-slider {
|
||||||
width: 70%;
|
width: 70%;
|
||||||
margin: 0 auto 0;
|
margin: 0 auto;
|
||||||
top: -3px;
|
top: -3px;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3736,7 +3740,8 @@ table.diff .diff-addedline ins {
|
|||||||
.revisions-tooltip {
|
.revisions-tooltip {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
bottom: 105px;
|
bottom: 105px;
|
||||||
margin-left: -69px;
|
margin-right: 0;
|
||||||
|
margin-left: -70px;
|
||||||
line-height: 28px;
|
line-height: 28px;
|
||||||
z-index: 9999;
|
z-index: 9999;
|
||||||
max-width: 350px;
|
max-width: 350px;
|
||||||
@ -3773,7 +3778,7 @@ table.diff .diff-addedline ins {
|
|||||||
z-index: 10000;
|
z-index: 10000;
|
||||||
}
|
}
|
||||||
|
|
||||||
.revisions-tooltip-arrow:after {
|
.revisions-tooltip-arrow > span {
|
||||||
content: "";
|
content: "";
|
||||||
position: absolute;
|
position: absolute;
|
||||||
left: 20px;
|
left: 20px;
|
||||||
@ -3787,8 +3792,14 @@ table.diff .diff-addedline ins {
|
|||||||
tranform: rotate(45deg);
|
tranform: rotate(45deg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.ie8 .revisions-tooltip-arrow > span {
|
||||||
|
left: 14px;
|
||||||
|
top: -25px;
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(SizingMethod='auto expand', M11=0.7071067811865476, M12=-0.7071067811865475, M21=0.7071067811865475, M22=0.7071067811865476)"; /* IE8 */
|
||||||
|
}
|
||||||
|
|
||||||
.revisions-tooltip,
|
.revisions-tooltip,
|
||||||
.revisions-tooltip-arrow:after {
|
.revisions-tooltip-arrow > span {
|
||||||
border-width: 1px;
|
border-width: 1px;
|
||||||
border-style: solid;
|
border-style: solid;
|
||||||
}
|
}
|
||||||
@ -3828,18 +3839,18 @@ div.revisions-controls > .wp-slider > .ui-slider-handle {
|
|||||||
background: url(../images/arrows-pr.png) no-repeat -2px -47px;
|
background: url(../images/arrows-pr.png) no-repeat -2px -47px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.wp-slider .ui-slider-handle.left-handle:before,
|
.wp-slider .ui-slider-handle.from-handle:before,
|
||||||
.wp-slider .ui-slider-handle.right-handle:before {
|
.wp-slider .ui-slider-handle.to-handle:before {
|
||||||
height: 8px;
|
height: 8px;
|
||||||
width: 7px;
|
width: 7px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.wp-slider .ui-slider-handle.left-handle:before {
|
.wp-slider .ui-slider-handle.from-handle:before {
|
||||||
background-position: -5px -84px;
|
background-position: -5px -84px;
|
||||||
left: 7px;
|
left: 7px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.wp-slider .ui-slider-handle.right-handle:before {
|
.wp-slider .ui-slider-handle.to-handle:before {
|
||||||
background-position: -4px -65px;
|
background-position: -4px -65px;
|
||||||
left: 5px;
|
left: 5px;
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,23 @@ window.wp = window.wp || {};
|
|||||||
console.log.apply( console, arguments );
|
console.log.apply( console, arguments );
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Handy functions to help with positioning
|
||||||
|
$.fn.allOffsets = function() {
|
||||||
|
var offset = this.offset() || {top: 0, left: 0}, win = $(window);
|
||||||
|
return _.extend( offset, {
|
||||||
|
right: win.width() - offset.left - this.outerWidth(),
|
||||||
|
bottom: win.height() - offset.top - this.outerHeight()
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
$.fn.allPositions = function() {
|
||||||
|
var position = this.position() || {top: 0, left: 0}, parent = this.parent();
|
||||||
|
return _.extend( position, {
|
||||||
|
right: parent.outerWidth() - position.left - this.outerWidth(),
|
||||||
|
bottom: parent.outerHeight() - position.top - this.outerHeight()
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
// wp_localize_script transforms top-level numbers into strings. Undo that.
|
// wp_localize_script transforms top-level numbers into strings. Undo that.
|
||||||
if ( revisions.settings.to )
|
if ( revisions.settings.to )
|
||||||
revisions.settings.to = parseInt( revisions.settings.to, 10 );
|
revisions.settings.to = parseInt( revisions.settings.to, 10 );
|
||||||
@ -125,19 +142,24 @@ window.wp = window.wp || {};
|
|||||||
revisions.model.Tooltip = Backbone.Model.extend({
|
revisions.model.Tooltip = Backbone.Model.extend({
|
||||||
defaults: {
|
defaults: {
|
||||||
revision: null,
|
revision: null,
|
||||||
|
offset: {},
|
||||||
hovering: false, // Whether the mouse is hovering
|
hovering: false, // Whether the mouse is hovering
|
||||||
scrubbing: false // Whether the mouse is scrubbing
|
scrubbing: false // Whether the mouse is scrubbing
|
||||||
},
|
},
|
||||||
|
|
||||||
initialize: function( options ) {
|
initialize: function( options ) {
|
||||||
|
this.frame = options.frame;
|
||||||
this.revisions = options.revisions;
|
this.revisions = options.revisions;
|
||||||
this.slider = options.slider;
|
this.slider = options.slider;
|
||||||
|
|
||||||
this.listenTo( this.slider, 'hovered:revision', this.updateRevision );
|
this.listenTo( this.slider, 'hovered:revision', this.updateRevision );
|
||||||
this.listenTo( this.slider, 'change:hovering', this.setHovering );
|
this.listenTo( this.slider, 'change:hovering', this.setHovering );
|
||||||
this.listenTo( this.slider, 'change:scrubbing', this.setScrubbing );
|
this.listenTo( this.slider, 'change:scrubbing', this.setScrubbing );
|
||||||
|
|
||||||
|
this.set({ revision: this.frame.diff() });
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
updateRevision: function( revision ) {
|
updateRevision: function( revision ) {
|
||||||
this.set({ revision: revision });
|
this.set({ revision: revision });
|
||||||
},
|
},
|
||||||
@ -475,6 +497,7 @@ window.wp = window.wp || {};
|
|||||||
render: function() {
|
render: function() {
|
||||||
wp.Backbone.View.prototype.render.apply( this, arguments );
|
wp.Backbone.View.prototype.render.apply( this, arguments );
|
||||||
|
|
||||||
|
$('html').css( 'overflow-y', 'scroll' );
|
||||||
$('#wpbody-content .wrap').append( this.el );
|
$('#wpbody-content .wrap').append( this.el );
|
||||||
this.updateCompareTwoMode();
|
this.updateCompareTwoMode();
|
||||||
this.renderDiff( this.model.diff() );
|
this.renderDiff( this.model.diff() );
|
||||||
@ -524,17 +547,21 @@ window.wp = window.wp || {};
|
|||||||
revisions: this.model.revisions
|
revisions: this.model.revisions
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Prep the tooltip model
|
||||||
|
var tooltip = new revisions.model.Tooltip({
|
||||||
|
frame: this.model,
|
||||||
|
revisions: this.model.revisions,
|
||||||
|
slider: slider
|
||||||
|
});
|
||||||
|
|
||||||
// Add the tooltip view
|
// Add the tooltip view
|
||||||
this.views.add( new revisions.view.Tooltip({
|
this.views.add( new revisions.view.Tooltip({
|
||||||
model: new revisions.model.Tooltip({
|
model: tooltip
|
||||||
revisions: this.model.revisions,
|
|
||||||
slider: slider
|
|
||||||
})
|
|
||||||
}) );
|
}) );
|
||||||
|
|
||||||
// Add the tickmarks view
|
// Add the tickmarks view
|
||||||
this.views.add( new revisions.view.Tickmarks({
|
this.views.add( new revisions.view.Tickmarks({
|
||||||
model: this.model
|
model: tooltip
|
||||||
}) );
|
}) );
|
||||||
|
|
||||||
// Add the slider view
|
// Add the slider view
|
||||||
@ -554,12 +581,37 @@ window.wp = window.wp || {};
|
|||||||
revisions.view.Tickmarks = wp.Backbone.View.extend({
|
revisions.view.Tickmarks = wp.Backbone.View.extend({
|
||||||
className: 'revisions-tickmarks',
|
className: 'revisions-tickmarks',
|
||||||
|
|
||||||
|
initialize: function() {
|
||||||
|
this.listenTo( this.model, 'change:revision', this.reportTickPosition );
|
||||||
|
},
|
||||||
|
|
||||||
|
reportTickPosition: function( model, revision ) {
|
||||||
|
var elWidth, offset, tick, index = this.model.revisions.indexOf( revision );
|
||||||
|
if ( index === this.model.revisions.length - 1 ) {
|
||||||
|
// Last one
|
||||||
|
tick = this.$('div:nth-of-type(' + index + ')');
|
||||||
|
offset = tick.allPositions();
|
||||||
|
elWidth = tick.outerWidth();
|
||||||
|
// adjust
|
||||||
|
_.extend( offset, {
|
||||||
|
right: offset.right + elWidth + 1,
|
||||||
|
left: offset.left + elWidth + 1
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
// Normal tick
|
||||||
|
tick = this.$('div:nth-of-type(' + (index + 1) + ')');
|
||||||
|
offset = tick.allPositions();
|
||||||
|
}
|
||||||
|
this.model.set({ offset: offset });
|
||||||
|
},
|
||||||
|
|
||||||
ready: function() {
|
ready: function() {
|
||||||
var tickCount, tickWidth;
|
var tickCount, tickWidth;
|
||||||
tickCount = this.model.revisions.length - 1;
|
tickCount = this.model.revisions.length - 1;
|
||||||
tickWidth = 1 / tickCount;
|
tickWidth = 1 / tickCount;
|
||||||
|
|
||||||
_(tickCount).times( function(){ this.$el.append( '<div></div>' ); }, this );
|
_(tickCount).times( function(){ this.$el.append( '<div></div>' ); }, this );
|
||||||
|
|
||||||
this.$('div').css( 'width', ( 100 * tickWidth ) + '%' );
|
this.$('div').css( 'width', ( 100 * tickWidth ) + '%' );
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -625,13 +677,25 @@ window.wp = window.wp || {};
|
|||||||
revisions.view.Tooltip = wp.Backbone.View.extend({
|
revisions.view.Tooltip = wp.Backbone.View.extend({
|
||||||
className: 'revisions-tooltip',
|
className: 'revisions-tooltip',
|
||||||
template: wp.template('revisions-tooltip'),
|
template: wp.template('revisions-tooltip'),
|
||||||
|
direction: isRtl ? 'right' : 'left',
|
||||||
|
|
||||||
initialize: function( options ) {
|
initialize: function( options ) {
|
||||||
this.listenTo( this.model, 'change:revision', this.render );
|
this.listenTo( this.model, 'change:offset', this.render );
|
||||||
this.listenTo( this.model, 'change:hovering', this.toggleVisibility );
|
this.listenTo( this.model, 'change:hovering', this.toggleVisibility );
|
||||||
this.listenTo( this.model, 'change:scrubbing', this.toggleVisibility );
|
this.listenTo( this.model, 'change:scrubbing', this.toggleVisibility );
|
||||||
},
|
},
|
||||||
|
|
||||||
|
prepare: function() {
|
||||||
|
return this.model.get('revision').toJSON();
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function() {
|
||||||
|
var css = {};
|
||||||
|
wp.Backbone.View.prototype.render.apply( this, arguments );
|
||||||
|
css[this.direction] = this.model.get('offset')[this.direction] + 'px';
|
||||||
|
this.$el.css( css );
|
||||||
|
},
|
||||||
|
|
||||||
visible: function() {
|
visible: function() {
|
||||||
return this.model.get( 'scrubbing' ) || this.model.get( 'hovering' );
|
return this.model.get( 'scrubbing' ) || this.model.get( 'hovering' );
|
||||||
},
|
},
|
||||||
@ -642,23 +706,6 @@ window.wp = window.wp || {};
|
|||||||
else
|
else
|
||||||
this.$el.stop().fadeTo( this.el.style.opacity * 300, 0, function(){ $(this).hide(); } );
|
this.$el.stop().fadeTo( this.el.style.opacity * 300, 0, function(){ $(this).hide(); } );
|
||||||
return;
|
return;
|
||||||
},
|
|
||||||
|
|
||||||
render: function() {
|
|
||||||
var offset;
|
|
||||||
// Check if a revision exists.
|
|
||||||
if ( _.isNull( this.model.get('revision') ) )
|
|
||||||
return;
|
|
||||||
|
|
||||||
this.$el.html( this.template( this.model.get('revision').toJSON() ) );
|
|
||||||
|
|
||||||
// Set the position.
|
|
||||||
offset = this.model.revisions.indexOf( this.model.get('revision') ) / ( this.model.revisions.length - 1 );
|
|
||||||
// 15% to get us to the start of the slider
|
|
||||||
// 0.7 to convert the slider-relative percentage to a page-relative percentage
|
|
||||||
// 100 to convert to a percentage
|
|
||||||
offset = 15 + (0.7 * offset * 100 ); // Now in a percentage
|
|
||||||
this.$el.css( isRtl ? 'right' : 'left', offset + '%' );
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -681,31 +728,29 @@ window.wp = window.wp || {};
|
|||||||
this.disabledButtonCheck();
|
this.disabledButtonCheck();
|
||||||
},
|
},
|
||||||
|
|
||||||
// Go to a specific modelindex, taking into account RTL mode.
|
// Go to a specific model index
|
||||||
gotoModel: function( toIndex ) {
|
gotoModel: function( toIndex ) {
|
||||||
var attributes = {
|
var attributes = {
|
||||||
to: this.model.revisions.at( isRtl ? this.model.revisions.length - toIndex - 1 : toIndex ) // Reverse directions for RTL.
|
to: this.model.revisions.at( toIndex )
|
||||||
};
|
};
|
||||||
// If we're at the first revision, unset 'from'.
|
// If we're at the first revision, unset 'from'.
|
||||||
if ( isRtl ? this.model.revisions.length - toIndex - 1 : toIndex ) // Reverse directions for RTL
|
if ( toIndex )
|
||||||
attributes.from = this.model.revisions.at( isRtl ? this.model.revisions.length - toIndex - 2 : toIndex - 1 );
|
attributes.from = this.model.revisions.at( toIndex - 1 );
|
||||||
else
|
else
|
||||||
this.model.unset('from', { silent: true });
|
this.model.unset('from', { silent: true });
|
||||||
|
|
||||||
this.model.set( attributes );
|
this.model.set( attributes );
|
||||||
},
|
},
|
||||||
|
|
||||||
// Go to the 'next' revision, direction takes into account RTL mode.
|
// Go to the 'next' revision
|
||||||
nextRevision: function() {
|
nextRevision: function() {
|
||||||
var toIndex = isRtl ? this.model.revisions.length - this.model.revisions.indexOf( this.model.get('to') ) - 1 : this.model.revisions.indexOf( this.model.get('to') );
|
var toIndex = this.model.revisions.indexOf( this.model.get('to') ) + 1;
|
||||||
toIndex = isRtl ? toIndex - 1 : toIndex + 1;
|
|
||||||
this.gotoModel( toIndex );
|
this.gotoModel( toIndex );
|
||||||
},
|
},
|
||||||
|
|
||||||
// Go to the 'previous' revision, direction takes into account RTL mode.
|
// Go to the 'previous' revision
|
||||||
previousRevision: function() {
|
previousRevision: function() {
|
||||||
var toIndex = isRtl ? this.model.revisions.length - this.model.revisions.indexOf( this.model.get('to') ) - 1 : this.model.revisions.indexOf( this.model.get('to') );
|
var toIndex = this.model.revisions.indexOf( this.model.get('to') ) - 1;
|
||||||
toIndex = isRtl ? toIndex + 1 : toIndex - 1;
|
|
||||||
this.gotoModel( toIndex );
|
this.gotoModel( toIndex );
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -729,6 +774,7 @@ window.wp = window.wp || {};
|
|||||||
// The slider view.
|
// The slider view.
|
||||||
revisions.view.Slider = wp.Backbone.View.extend({
|
revisions.view.Slider = wp.Backbone.View.extend({
|
||||||
className: 'wp-slider',
|
className: 'wp-slider',
|
||||||
|
direction: isRtl ? 'right' : 'left',
|
||||||
|
|
||||||
events: {
|
events: {
|
||||||
'mousemove' : 'mouseMove'
|
'mousemove' : 'mouseMove'
|
||||||
@ -757,15 +803,12 @@ window.wp = window.wp || {};
|
|||||||
|
|
||||||
mouseMove: function( e ) {
|
mouseMove: function( e ) {
|
||||||
var zoneCount = this.model.revisions.length - 1, // One fewer zone than models
|
var zoneCount = this.model.revisions.length - 1, // One fewer zone than models
|
||||||
sliderLeft = this.$el.offset().left, // Left edge of slider
|
sliderFrom = this.$el.allOffsets()[this.direction], // "From" edge of slider
|
||||||
sliderWidth = this.$el.width(), // Width of slider
|
sliderWidth = this.$el.width(), // Width of slider
|
||||||
tickWidth = sliderWidth / zoneCount, // Calculated width of zone
|
tickWidth = sliderWidth / zoneCount, // Calculated width of zone
|
||||||
actualX = e.clientX - sliderLeft, // Offset of mouse position in slider
|
actualX = isRtl? $(window).width() - e.pageX : e.pageX; // Flipped for RTL - sliderFrom;
|
||||||
currentModelIndex = Math.floor( ( actualX + ( tickWidth / 2 ) ) / tickWidth ); // Calculate the model index
|
actualX = actualX - sliderFrom; // Offset of mouse position in slider
|
||||||
|
var currentModelIndex = Math.floor( ( actualX + ( tickWidth / 2 ) ) / tickWidth ); // Calculate the model index
|
||||||
// Reverse direction in RTL mode.
|
|
||||||
if ( isRtl )
|
|
||||||
currentModelIndex = this.model.revisions.length - currentModelIndex - 1;
|
|
||||||
|
|
||||||
// Ensure sane value for currentModelIndex.
|
// Ensure sane value for currentModelIndex.
|
||||||
if ( currentModelIndex < 0 )
|
if ( currentModelIndex < 0 )
|
||||||
@ -773,7 +816,7 @@ window.wp = window.wp || {};
|
|||||||
else if ( currentModelIndex >= this.model.revisions.length )
|
else if ( currentModelIndex >= this.model.revisions.length )
|
||||||
currentModelIndex = this.model.revisions.length - 1;
|
currentModelIndex = this.model.revisions.length - 1;
|
||||||
|
|
||||||
// Update the tooltip model
|
// Update the tooltip mode
|
||||||
this.model.set({ hoveredRevision: this.model.revisions.at( currentModelIndex ) });
|
this.model.set({ hoveredRevision: this.model.revisions.at( currentModelIndex ) });
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -792,103 +835,84 @@ window.wp = window.wp || {};
|
|||||||
if ( this.model.get('compareTwoMode') ) {
|
if ( this.model.get('compareTwoMode') ) {
|
||||||
// in RTL mode the 'left handle' is the second in the slider, 'right' is first
|
// in RTL mode the 'left handle' is the second in the slider, 'right' is first
|
||||||
handles.first()
|
handles.first()
|
||||||
.toggleClass( 'right-handle', !! isRtl )
|
.toggleClass( 'to-handle', !! isRtl )
|
||||||
.toggleClass( 'left-handle', ! isRtl );
|
.toggleClass( 'from-handle', ! isRtl );
|
||||||
handles.last()
|
handles.last()
|
||||||
.toggleClass( 'left-handle', !! isRtl )
|
.toggleClass( 'from-handle', !! isRtl )
|
||||||
.toggleClass( 'right-handle', ! isRtl );
|
.toggleClass( 'to-handle', ! isRtl );
|
||||||
} else {
|
} else {
|
||||||
handles.removeClass('left-handle right-handle');
|
handles.removeClass('from-handle to-handle');
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
getSliderPosition: function( ui ){
|
|
||||||
return isRtl ? this.model.revisions.length - ui.value - 1 : ui.value;
|
|
||||||
},
|
|
||||||
|
|
||||||
start: function( event, ui ) {
|
start: function( event, ui ) {
|
||||||
this.model.set({ scrubbing: true });
|
this.model.set({ scrubbing: true });
|
||||||
|
|
||||||
// Track the mouse position to enable smooth dragging,
|
// Track the mouse position to enable smooth dragging,
|
||||||
// overrides default jQuery UI step behavior.
|
// overrides default jQuery UI step behavior.
|
||||||
$( window ).on( 'mousemove.wp.revisions', { view: this }, function( e ) {
|
$( window ).on( 'mousemove.wp.revisions', { view: this }, function( e ) {
|
||||||
var view = e.data.view,
|
var view = e.data.view,
|
||||||
leftDragBoundary = view.$el.offset().left, // Initial left boundary
|
leftDragBoundary = view.$el.offset().left,
|
||||||
sliderOffset = leftDragBoundary,
|
sliderOffset = leftDragBoundary,
|
||||||
sliderRightEdge = leftDragBoundary + view.$el.width(),
|
sliderRightEdge = leftDragBoundary + view.$el.width(),
|
||||||
rightDragBoundary = sliderRightEdge, // Initial right boundary
|
rightDragBoundary = sliderRightEdge,
|
||||||
leftDragReset = 0, // Initial left drag reset
|
leftDragReset = '0',
|
||||||
rightDragReset = sliderRightEdge - sliderOffset; // Initial right drag reset
|
rightDragReset = '100%',
|
||||||
|
handle = $( ui.handle );
|
||||||
|
|
||||||
// In two handle mode, ensure handles can't be dragged past each other.
|
// In two handle mode, ensure handles can't be dragged past each other.
|
||||||
// Adjust left/right boundaries and reset points.
|
// Adjust left/right boundaries and reset points.
|
||||||
if ( view.model.get('compareTwoMode') ) {
|
if ( view.model.get('compareTwoMode') ) {
|
||||||
var rightHandle = $( ui.handle ).parent().find('.right-handle'),
|
var handles = handle.parent().find('.ui-slider-handle');
|
||||||
leftHandle = $( ui.handle ).parent().find('.left-handle');
|
if ( handle.is( handles.first() ) ) { // We're the left handle
|
||||||
|
rightDragBoundary = handles.last().offset().left;
|
||||||
if ( $( ui.handle ).hasClass('left-handle') ) {
|
rightDragReset = rightDragBoundary - sliderOffset;
|
||||||
// Dragging the left handle, boundary is right handle.
|
} else { // We're the right handle
|
||||||
// RTL mode calculations reverse directions.
|
leftDragBoundary = handles.first().offset().left + handles.first().width();
|
||||||
if ( isRtl ) {
|
leftDragReset = leftDragBoundary - sliderOffset;
|
||||||
leftDragBoundary = rightHandle.offset().left + rightHandle.width();
|
|
||||||
leftDragReset = leftDragBoundary - sliderOffset;
|
|
||||||
} else {
|
|
||||||
rightDragBoundary = rightHandle.offset().left;
|
|
||||||
rightDragReset = rightDragBoundary - sliderOffset;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Dragging the right handle, boundary is the left handle.
|
|
||||||
// RTL mode calculations reverse directions.
|
|
||||||
if ( isRtl ) {
|
|
||||||
rightDragBoundary = leftHandle.offset().left;
|
|
||||||
rightDragReset = rightDragBoundary - sliderOffset;
|
|
||||||
} else {
|
|
||||||
leftDragBoundary = leftHandle.offset().left + leftHandle.width() ;
|
|
||||||
leftDragReset = leftDragBoundary - sliderOffset;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Follow mouse movements, as long as handle remains inside slider.
|
// Follow mouse movements, as long as handle remains inside slider.
|
||||||
if ( e.clientX < leftDragBoundary ) {
|
if ( e.pageX < leftDragBoundary ) {
|
||||||
$( ui.handle ).css( 'left', leftDragReset ); // Mouse to left of slider.
|
handle.css( 'left', leftDragReset ); // Mouse to left of slider.
|
||||||
} else if ( e.clientX > rightDragBoundary ) {
|
} else if ( e.pageX > rightDragBoundary ) {
|
||||||
$( ui.handle ).css( 'left', rightDragReset ); // Mouse to right of slider.
|
handle.css( 'left', rightDragReset ); // Mouse to right of slider.
|
||||||
} else {
|
} else {
|
||||||
$( ui.handle ).css( 'left', e.clientX - sliderOffset ); // Mouse in slider.
|
handle.css( 'left', e.pageX - sliderOffset ); // Mouse in slider.
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getPosition: function( position ) {
|
||||||
|
return isRtl ? this.model.revisions.length - position - 1: position;
|
||||||
|
},
|
||||||
|
|
||||||
// Responds to slide events
|
// Responds to slide events
|
||||||
slide: function( event, ui ) {
|
slide: function( event, ui ) {
|
||||||
var attributes, movedRevision, sliderPosition;
|
var attributes, movedRevision;
|
||||||
// Compare two revisions mode
|
// Compare two revisions mode
|
||||||
if ( 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 = {
|
|
||||||
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] )
|
|
||||||
};
|
|
||||||
if ( isRtl )
|
if ( isRtl )
|
||||||
movedRevision = ui.value === ui.values[1] ? attributes.from : attributes.to;
|
ui.values.reverse();
|
||||||
else
|
|
||||||
movedRevision = ui.value === ui.values[0] ? attributes.from : attributes.to;
|
|
||||||
} else {
|
|
||||||
sliderPosition = this.getSliderPosition( ui );
|
|
||||||
attributes = {
|
attributes = {
|
||||||
to: this.model.revisions.at( sliderPosition )
|
from: this.model.revisions.at( this.getPosition( ui.values[0] ) ),
|
||||||
|
to: this.model.revisions.at( this.getPosition( ui.values[1] ) )
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
attributes = {
|
||||||
|
to: this.model.revisions.at( this.getPosition( ui.value ) )
|
||||||
};
|
};
|
||||||
movedRevision = attributes.to;
|
|
||||||
// If we're at the first revision, unset 'from'.
|
// If we're at the first revision, unset 'from'.
|
||||||
if ( sliderPosition ) // Reverse directions for RTL.
|
if ( this.getPosition( ui.value ) > 0 )
|
||||||
attributes.from = this.model.revisions.at( sliderPosition - 1 );
|
attributes.from = this.model.revisions.at( this.getPosition( ui.value ) - 1 );
|
||||||
else
|
else
|
||||||
attributes.from = undefined;
|
attributes.from = undefined;
|
||||||
}
|
}
|
||||||
|
movedRevision = this.model.revisions.at( this.getPosition( ui.value ) );
|
||||||
|
|
||||||
// If we are scrubbing, a scrub to a revision is considered a hover
|
// If we are scrubbing, a scrub to a revision is considered a hover
|
||||||
if ( this.model.get('scrubbing') )
|
if ( this.model.get('scrubbing') )
|
||||||
|
@ -138,7 +138,7 @@ require_once( './admin-header.php' );
|
|||||||
({{ data.dateShort }})
|
({{ data.dateShort }})
|
||||||
<# } #>
|
<# } #>
|
||||||
</div>
|
</div>
|
||||||
<div class="revisions-tooltip-arrow"></div>
|
<div class="revisions-tooltip-arrow"><span></span></div>
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<script id="tmpl-revisions-checkbox" type="text/html">
|
<script id="tmpl-revisions-checkbox" type="text/html">
|
||||||
|
Loading…
Reference in New Issue
Block a user