2020-06-16 14:13:36 +00:00
|
|
|
/**
|
|
|
|
* @external RevisionList
|
|
|
|
* @external SliderView
|
|
|
|
*/
|
2020-11-18 09:11:12 +00:00
|
|
|
/**
|
|
|
|
* Module handling the slider logic of the RevisionSlider
|
|
|
|
*
|
|
|
|
* @class Slider
|
|
|
|
* @param {RevisionList} revisions
|
|
|
|
* @constructor
|
|
|
|
*/
|
|
|
|
function Slider( revisions ) {
|
|
|
|
this.revisions = revisions;
|
|
|
|
this.view = new mw.libs.revisionSlider.SliderView( this );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class mw.libs.revisionSlider.Slider
|
|
|
|
*/
|
|
|
|
$.extend( Slider.prototype, {
|
2016-06-17 13:06:12 +00:00
|
|
|
/**
|
2020-11-18 09:11:12 +00:00
|
|
|
* @type {RevisionList}
|
|
|
|
*/
|
|
|
|
revisions: null,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @type {number}
|
|
|
|
*/
|
|
|
|
oldestVisibleRevisionIndex: 0,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @type {number}
|
|
|
|
*/
|
|
|
|
revisionsPerWindow: 0,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @type {SliderView}
|
|
|
|
*/
|
|
|
|
view: null,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return {RevisionList}
|
|
|
|
*/
|
|
|
|
getRevisionList: function () {
|
|
|
|
return this.revisions;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return {SliderView}
|
|
|
|
*/
|
|
|
|
getView: function () {
|
|
|
|
return this.view;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the number of revisions that are visible at once (depending on browser window size)
|
2016-06-17 13:06:12 +00:00
|
|
|
*
|
2020-11-18 09:11:12 +00:00
|
|
|
* @param {number} n
|
2016-06-17 13:06:12 +00:00
|
|
|
*/
|
2020-11-18 09:11:12 +00:00
|
|
|
setRevisionsPerWindow: function ( n ) {
|
|
|
|
this.revisionsPerWindow = n;
|
|
|
|
},
|
2016-05-10 12:42:05 +00:00
|
|
|
|
2020-01-24 16:21:23 +00:00
|
|
|
/**
|
2020-11-18 09:11:12 +00:00
|
|
|
* @return {number}
|
2020-01-24 16:21:23 +00:00
|
|
|
*/
|
2020-11-18 09:11:12 +00:00
|
|
|
getRevisionsPerWindow: function () {
|
|
|
|
return this.revisionsPerWindow;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the index of the oldest revision that is visible in the current window
|
|
|
|
*
|
|
|
|
* @return {number}
|
|
|
|
*/
|
|
|
|
getOldestVisibleRevisionIndex: function () {
|
|
|
|
return this.oldestVisibleRevisionIndex;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the index of the newest revision that is visible in the current window
|
|
|
|
*
|
|
|
|
* @return {number}
|
|
|
|
*/
|
|
|
|
getNewestVisibleRevisionIndex: function () {
|
|
|
|
return this.oldestVisibleRevisionIndex + this.revisionsPerWindow - 1;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return {boolean}
|
|
|
|
*/
|
|
|
|
isAtStart: function () {
|
|
|
|
return this.getOldestVisibleRevisionIndex() === 0 || this.revisions.getLength() <= this.revisionsPerWindow;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return {boolean}
|
|
|
|
*/
|
|
|
|
isAtEnd: function () {
|
|
|
|
return this.getNewestVisibleRevisionIndex() === this.revisions.getLength() - 1 || this.revisions.getLength() <= this.revisionsPerWindow;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the index of the first revision that is visible in the current window
|
|
|
|
*
|
|
|
|
* @param {number} value
|
|
|
|
*/
|
|
|
|
setFirstVisibleRevisionIndex: function ( value ) {
|
|
|
|
this.oldestVisibleRevisionIndex = value;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the new oldestVisibleRevisionIndex after sliding in a direction
|
|
|
|
*
|
|
|
|
* @param {number} direction - Either -1, 0 or 1
|
|
|
|
*/
|
|
|
|
slide: function ( direction ) {
|
|
|
|
var highestPossibleFirstRev = this.revisions.getLength() - this.revisionsPerWindow;
|
|
|
|
|
|
|
|
this.oldestVisibleRevisionIndex += direction * this.revisionsPerWindow;
|
|
|
|
this.oldestVisibleRevisionIndex = Math.min( this.oldestVisibleRevisionIndex, highestPossibleFirstRev );
|
|
|
|
this.oldestVisibleRevisionIndex = Math.max( 0, this.oldestVisibleRevisionIndex );
|
|
|
|
}
|
|
|
|
} );
|
|
|
|
|
|
|
|
mw.libs.revisionSlider = mw.libs.revisionSlider || {};
|
|
|
|
mw.libs.revisionSlider.Slider = Slider;
|