Rtdwivedi has uploaded a new change for review.
https://gerrit.wikimedia.org/r/79846
Change subject: Added the zoom library jquery-panzoom.
......................................................................
Added the zoom library jquery-panzoom.
Change-Id: I5831618a5c0d4c23ceab4cedc1633c9a24831326
---
M ProofreadPage.body.php
M ProofreadPage.php
M includes/page/EditProofreadPagePage.php
M modules/ext.proofreadpage.page/ext.proofreadpage.page.js
A modules/ext.proofreadpage.page/jquery-panzoom.js
5 files changed, 528 insertions(+), 2 deletions(-)
git pull ssh://gerrit.wikimedia.org:29418/mediawiki/extensions/ProofreadPage
refs/changes/46/79846/1
diff --git a/ProofreadPage.body.php b/ProofreadPage.body.php
index 4974374..493bd7f 100644
--- a/ProofreadPage.body.php
+++ b/ProofreadPage.body.php
@@ -303,6 +303,7 @@
$out->addJsConfigVars( $jsVars );
$out->addModules( 'ext.proofreadpage.page' );
+ $out->addModules( 'jquery-panzoom' );
return true;
}
diff --git a/ProofreadPage.php b/ProofreadPage.php
index 15cfc07..8398d19 100644
--- a/ProofreadPage.php
+++ b/ProofreadPage.php
@@ -102,7 +102,7 @@
'styles' =>
'ext.proofreadpage.base/ext.proofreadpage.base.css',
),
'ext.proofreadpage.page' => $prpResourceTemplate + array(
- 'scripts' => 'ext.proofreadpage.page/ext.proofreadpage.page.js',
+ 'scripts' => array(
'ext.proofreadpage.page/ext.proofreadpage.page.js',
'ext.proofreadpage.page/jquery-panzoom.js' ),
'styles' =>
'ext.proofreadpage.page/ext.proofreadpage.page.css',
'dependencies' => array( 'ext.proofreadpage.base',
'mediawiki.legacy.wikibits', 'mediawiki.util' ),
'messages' => array(
diff --git a/includes/page/EditProofreadPagePage.php
b/includes/page/EditProofreadPagePage.php
index 800cad6..4552b91 100644
--- a/includes/page/EditProofreadPagePage.php
+++ b/includes/page/EditProofreadPagePage.php
@@ -76,7 +76,29 @@
$text = $content->getBody();
$image = null;
$index = $page->getIndex();
-// $imageHtml = $index->getImageHtml( $page->getPageNumber() );
+ $dir = __DIR__ . '/';
+ $zoomBar =
+ Html::openElement( 'div', array( 'id' => 'controls' ) )
.
+ Html::openElement( 'a', array( 'id' => 'zoomin', 'href'
=> '#' ) ) .
+ Html::openElement( 'img', array( 'src' => $dir .
'../../modules/ext.proofreadpage.base/images/Button_zoom_in.png' ) ) .
+ Html::closeElement( 'a' ) .
+ Html::openElement( 'a', array( 'id' => 'zoomout',
'href' => '#' ) ) .
+ Html::openElement( 'img', array( 'src' => $dir .
'../../modules/ext.proofreadpage.base/images/Button_zoom_out.png' ) ) .
+ Html::closeElement( 'a' ) .
+ Html::openElement( 'a', array( 'id' => 'panup', 'href'
=> '#' ) ) .
+ Html::openElement( 'img', array( 'src' => $dir .
'../../modules/ext.proofreadpage.base/images/arrow_up.png' ) ) .
+ Html::closeElement( 'a' ) .
+ Html::openElement( 'a', array( 'id' => 'pandown',
'href' => '#' ) ) .
+ Html::openElement( 'img', array( 'src' => $dir .
'../../modules/ext.proofreadpage.base/images/arrow_down.png' ) ) .
+ Html::closeElement( 'a' ) .
+ Html::openElement( 'a', array( 'id' => 'panleft',
'href' => '#' ) ) .
+ Html::openElement( 'img', array( 'src' => $dir .
'../../modules/ext.proofreadpage.base/images/arrow_left.png' ) ) .
+ Html::closeElement( 'a' ) .
+ Html::openElement( 'a', array( 'id' => 'panright',
'href' => '#' ) ) .
+ Html::openElement( 'img', array( 'src' => $dir .
'../../modules/ext.proofreadpage.base/images/arrow_right.png' ) ) .
+ Html::closeElement( 'a' ) .
+ Html::closeElement( 'div' );
+
$wgOut->addHTML(
Html::openElement( 'div', array( 'class' => 'wpHeader')
) .
@@ -84,6 +106,7 @@
Html::textarea( 'wpHeaderTextbox',
$content->getHeader(), $headerAttributes ) .
Html::element( 'button', array( 'name' => 'hideHeader',
'type' => 'button', 'value' => wfMessage( 'proofreadpage_toggle_headerfooter' )
), wfMessage( 'proofreadpage_toggle_headerfooter' ) ) .
Html::closeElement( 'div' ) .
+ $zoomBar .
Html::element( 'label', array( 'for' => 'wpTextbox1'),
wfMessage( 'proofreadpage_body' ) ) .
Html::openElement('div', array( 'class' =>
'wpProofreadingArea') ) .
Html::openElement( 'div', array( 'class' =>
'bodyImage') ) .
diff --git a/modules/ext.proofreadpage.page/ext.proofreadpage.page.js
b/modules/ext.proofreadpage.page/ext.proofreadpage.page.js
index 23d1730..7978ef0 100644
--- a/modules/ext.proofreadpage.page/ext.proofreadpage.page.js
+++ b/modules/ext.proofreadpage.page/ext.proofreadpage.page.js
@@ -36,6 +36,17 @@
} );
}
+function initPanZoom() {
+ $('#pan img').panZoom({
+ 'zoomIn' : $('#zoomin'),
+ 'zoomOut' : $('#zoomout'),
+ 'panUp' : $('#panup'),
+ 'panDown' : $('#pandown'),
+ 'panLeft' : $('#panleft'),
+ 'panRight' : $('#panright'),
+
+ });
+}
function prStartup() {
jQuery( function() {
@@ -43,6 +54,7 @@
// prInitZoom();
prSetSummary();
prHideHeaderFooter();
+ initPanZoom();
} );
}
diff --git a/modules/ext.proofreadpage.page/jquery-panzoom.js
b/modules/ext.proofreadpage.page/jquery-panzoom.js
new file mode 100755
index 0000000..6fcd58a
--- /dev/null
+++ b/modules/ext.proofreadpage.page/jquery-panzoom.js
@@ -0,0 +1,490 @@
+/*
+ * jQuery PanZoom Plugin
+ * Pan and zoom an image within a parent div.
+ *
+ * version: 0.10.0
+ * @requires jQuery v1.4.2 or later (earlier probably work, but untested so
far)
+ *
+ * Copyright (c) 2011 Ben Lumley
+ * Examples and documentation at: https://github.com/benlumley/jQuery-PanZoom
+ *
+ * Dual licensed under the MIT and GPL licenses:
+ * http://www.opensource.org/licenses/mit-license.php
+ * http://www.gnu.org/licenses/gpl.html
+*/
+
+(function( $ ){
+
+ $.fn.panZoom = function(method) {
+
+ if ( methods[method] ) {
+ return methods[ method ].apply( this, Array.prototype.slice.call(
arguments, 1 ));
+ } else if ( typeof method === 'object' || ! method ) {
+ return methods.init.apply( this, arguments );
+ } else {
+ $.error( 'Method ' + method + ' does not exist' );
+ }
+
+ };
+
+ $.fn.panZoom.defaults = {
+ zoomIn : false,
+ zoomOut : false,
+ panUp : false,
+ panDown : false,
+ panLeft : false,
+ panRight : false,
+ fit : false,
+ destroy : false,
+ out_x1 : false,
+ out_y1 : false,
+ out_x2 : false,
+ out_y2 : false,
+ min_width : 20,
+ min_height : 20,
+ zoom_step : 3,
+ pan_step : 3,
+ debug : false,
+ directedit : false,
+ aspect : true,
+ factor : 1,
+ animate : true,
+ animate_duration : 200,
+ animate_easing : 'linear',
+ double_click : true,
+ mousewheel : true,
+ mousewheel_delta : 1,
+ draggable : true,
+ clickandhold : true
+ };
+
+ var settings = {}
+
+ var methods = {
+ 'init': function (options) {
+ $.extend(settings, $.fn.panZoom.defaults, options);
+ setupCSS.apply(this);
+ setupData.apply(this);
+ setupBindings.apply(this);
+ methods.readPosition.apply(this);
+ },
+
+ 'destroy': function () {
+ var data = this.data('panZoom');
+ data.bound_elements.unbind('.panZoom');
+ if (settings.draggable && typeof(this.draggable) == 'function') {
+ this.draggable('destroy');
+ }
+ this.removeData('panZoom');
+ },
+
+ 'loadImage': function () {
+ var data = this.data('panZoom');
+ loadTargetDimensions.apply(this);
+ methods.updatePosition.apply(this);
+ if (data.last_image != null && data.last_image != this.attr('src')) {
+ methods.fit.apply(this);
+ }
+ data.last_image = this.attr('src');
+ data.loaded = true;
+ },
+
+ 'readPosition': function () {
+ var data = this.data('panZoom');
+ if (settings.out_x1) { data.position.x1 =
settings.out_x1.val()*settings.factor }
+ if (settings.out_y1) { data.position.y1 =
settings.out_y1.val()*settings.factor }
+ if (settings.out_x2) { data.position.x2 =
settings.out_x2.val()*settings.factor }
+ if (settings.out_y2) { data.position.y2 =
settings.out_y2.val()*settings.factor }
+ methods.updatePosition.apply(this);
+ },
+
+ 'updatePosition': function() {
+ validatePosition.apply(this);
+ writePosition.apply(this);
+ applyPosition.apply(this);
+ },
+
+ 'fit': function () {
+ var data = this.data('panZoom');
+ data.position.x1 = 0;
+ data.position.y1 = 0;
+ data.position.x2 = data.viewport_dimensions.x;
+ data.position.y2 = data.viewport_dimensions.y;
+ methods.updatePosition.apply(this);
+ },
+
+ 'zoomIn': function (steps) {
+ var data = this.data('panZoom');
+ if (typeof(steps) == 'undefined') {
+ var steps = getStepDimensions.apply(this);
+ }
+ data.position.x1 = data.position.x1*1 - steps.zoom.x;
+ data.position.x2 = data.position.x2*1 + steps.zoom.x;
+ data.position.y1 = data.position.y1*1 - steps.zoom.y;
+ data.position.y2 = data.position.y2*1 + steps.zoom.y;
+ methods.updatePosition.apply(this);
+ },
+
+ 'zoomOut': function (steps) {
+ var data = this.data('panZoom');
+ if (typeof(steps) == 'undefined') {
+ var steps = getStepDimensions.apply(this);
+ }
+ data.position.x1 = data.position.x1*1 + steps.zoom.x;
+ data.position.x2 = data.position.x2*1 - steps.zoom.x;
+ data.position.y1 = data.position.y1*1 + steps.zoom.y;
+ data.position.y2 = data.position.y2*1 - steps.zoom.y;
+ methods.updatePosition.apply(this);
+ },
+
+ 'panUp': function () {
+ var data = this.data('panZoom');
+ var steps = getStepDimensions.apply(this);
+ data.position.y1 -= steps.pan.y;
+ data.position.y2 -= steps.pan.y;
+ methods.updatePosition.apply(this);
+ },
+
+ 'panDown': function () {
+ var data = this.data('panZoom');
+ var steps = getStepDimensions.apply(this);
+ data.position.y1 = data.position.y1*1 + steps.pan.y;
+ data.position.y2 = data.position.y2*1 + steps.pan.y;
+ methods.updatePosition.apply(this);
+ },
+
+ 'panLeft': function () {
+ var data = this.data('panZoom');
+ var steps = getStepDimensions.apply(this);
+ data.position.x1 -= steps.pan.x;
+ data.position.x2 -= steps.pan.x;
+ methods.updatePosition.apply(this);
+ },
+
+ 'panRight': function () {
+ var data = this.data('panZoom');
+ var steps = getStepDimensions.apply(this);
+ data.position.x1 = data.position.x1*1 + steps.pan.x;
+ data.position.x2 = data.position.x2*1 + steps.pan.x;
+ methods.updatePosition.apply(this);
+ },
+
+ 'mouseWheel': function (delta) {
+ // first calculate how much to zoom in/out
+ var steps = getStepDimensions.apply(this);
+ steps.zoom.x = steps.zoom.x * (Math.abs(delta) /
settings.mousewheel_delta);
+ steps.zoom.y = steps.zoom.y * (Math.abs(delta) /
settings.mousewheel_delta);
+
+ // then do it
+ if (delta > 0) {
+ methods.zoomIn.apply(this, [steps]);
+ } else if (delta < 0) {
+ methods.zoomOut.apply(this, [steps]);
+ }
+ },
+
+ 'dragComplete': function() {
+ var data = this.data('panZoom');
+ data.position.x1 = this.position().left;
+ data.position.y1 = this.position().top;
+ data.position.x2 = this.position().left*1 + this.width();
+ data.position.y2 = this.position().top*1 + this.height();
+ methods.updatePosition.apply(this);
+ },
+
+ 'mouseDown': function (action) {
+ methods[action].apply(this);
+
+ if (settings.clickandhold) {
+ var data = this.data('panZoom');
+ methods.mouseUp.apply(this);
+ data.mousedown_interval = window.setInterval(function (that, action) {
+ that.panZoom(action);
+ }, settings.animate_duration, this, action);
+ }
+ },
+
+ 'mouseUp': function() {
+ var data = this.data('panZoom');
+ window.clearInterval(data.mousedown_interval);
+ }
+
+ }
+
+ function setupBindings() {
+
+ eventData = { target: this }
+ var data = this.data('panZoom');
+
+ // bind up controls
+ if (settings.zoomIn) {
+ settings.zoomIn.bind('mousedown.panZoom', eventData, function(event) {
+ event.preventDefault(); event.data.target.panZoom('mouseDown',
'zoomIn');
+ }).bind('mouseleave.panZoom mouseup.panZoom', eventData, function(event)
{
+ event.preventDefault(); event.data.target.panZoom('mouseUp');
+ }).bind('click.panZoom', function (event) { event.preventDefault() } );
+ data.bound_elements = data.bound_elements.add(settings.zoomIn);
+ }
+
+ if (settings.zoomOut) {
+ settings.zoomOut.bind('mousedown.panZoom', eventData, function(event) {
+ event.preventDefault(); event.data.target.panZoom('mouseDown',
'zoomOut');
+ }).bind('mouseleave.panZoom mouseup.panZoom', eventData, function(event)
{
+ event.preventDefault(); event.data.target.panZoom('mouseUp');
+ }).bind('click.panZoom', function (event) { event.preventDefault() } );
+ data.bound_elements = data.bound_elements.add(settings.zoomOut);
+ }
+
+ if (settings.panUp) {
+ settings.panUp.bind('mousedown.panZoom', eventData, function(event) {
+ event.preventDefault(); event.data.target.panZoom('mouseDown',
'panUp');
+ }).bind('mouseleave.panZoom mouseup.panZoom', eventData, function(event)
{
+ event.preventDefault(); event.data.target.panZoom('mouseUp');
+ }).bind('click.panZoom', function (event) { event.preventDefault() } );
+ data.bound_elements = data.bound_elements.add(settings.panUp);
+ }
+
+ if (settings.panDown) {
+ settings.panDown.bind('mousedown.panZoom', eventData, function(event) {
+ event.preventDefault(); event.data.target.panZoom('mouseDown',
'panDown');
+ }).bind('mouseleave.panZoom mouseup.panZoom', eventData, function(event)
{
+ event.preventDefault(); event.data.target.panZoom('mouseUp');
+ }).bind('click.panZoom', function (event) { event.preventDefault() } );
+ data.bound_elements = data.bound_elements.add(settings.panDown);
+ }
+
+ if (settings.panLeft) {
+ settings.panLeft.bind('mousedown.panZoom', eventData, function(event) {
+ event.preventDefault(); event.data.target.panZoom('mouseDown',
'panLeft');
+ }).bind('mouseleave.panZoom mouseup.panZoom', eventData, function(event)
{
+ event.preventDefault(); event.data.target.panZoom('mouseUp');
+ }).bind('click.panZoom', function (event) { event.preventDefault() } );
+ data.bound_elements = data.bound_elements.add(settings.panLeft);
+ }
+
+ if (settings.panRight) {
+ settings.panRight.bind('mousedown.panZoom', eventData, function(event) {
+ event.preventDefault(); event.data.target.panZoom('mouseDown',
'panRight');
+ }).bind('mouseleave.panZoom mouseup.panZoom', eventData, function(event)
{
+ event.preventDefault(); event.data.target.panZoom('mouseUp');
+ }).bind('click.panZoom', function (event) { event.preventDefault() } );
+ data.bound_elements = data.bound_elements.add(settings.panRight);
+ }
+
+ if (settings.fit) {
+ settings.fit.bind('click.panZoom', eventData, function(event) {
event.preventDefault(); event.data.target.panZoom('fit'); } );
+ data.bound_elements = data.bound_elements.add(settings.fit);
+ }
+
+ if (settings.destroy) {
+ settings.destroy.bind('click.panZoom', eventData, function(event) {
event.preventDefault(); event.data.target.panZoom('destroy'); } );
+ data.bound_elements = data.bound_elements.add(settings.destroy);
+ }
+
+ // double click
+ if (settings.double_click) {
+ this.bind('dblclick.panZoom', eventData, function(event) {
event.data.target.panZoom('zoomIn') } );
+ // no need to record in bound elements array - gets done anyway when
imageload is bound
+ }
+
+ // mousewheel
+ if (settings.mousewheel && typeof(this.mousewheel) == 'function') {
+ this.parent().bind('mousewheel.panZoom', function(event, delta) {
event.preventDefault(); $(this).find('img').panZoom('mouseWheel', delta) } );
+ data.bound_elements = data.bound_elements.add(this.parent());
+ } else if (settings.mousewheel) {
+ alert('Mousewheel requires jquery-mousewheel by Brandon Aaron
(https://github.com/brandonaaron/jquery-mousewheel) - please include it or
disable mousewheel to remove this warning.')
+ }
+
+ // direct form input
+ if (settings.directedit) {
+
$(settings.out_x1).add(settings.out_y1).add(settings.out_x2).add(settings.out_y2).bind('change.panZoom
blur.panZoom', eventData, function(event) {
event.data.target.panZoom('readPosition') } );
+ data.bound_elements =
data.bound_elements.add($(settings.out_x1).add(settings.out_y1).add(settings.out_x2).add(settings.out_y2));
+ }
+
+ if (settings.draggable && typeof(this.draggable) == 'function') {
+ this.draggable({
+ stop: function () { $(this).panZoom('dragComplete'); }
+ });
+ } else if (settings.draggable) {
+ alert('Draggable requires jQuery UI - please include jQuery UI or
disable draggable to remove this warning.')
+ }
+
+ // image load
+ $(this).bind('load.panZoom', eventData, function (event) {
event.data.target.panZoom('loadImage') })
+ data.bound_elements = data.bound_elements.add(this);
+
+ }
+
+ function setupData() {
+ this.data('panZoom', {
+ target_element: this,
+ target_dimensions: { x: null, y: null },
+ viewport_element: this.parent(),
+ viewport_dimensions: { x: this.parent().width(), y:
this.parent().height() },
+ position: { x1: null, y1: null, x2: null, y2: null },
+ last_image: null,
+ loaded: false,
+ mousewheel_delta: 0,
+ mousedown_interval: false,
+ bound_elements: $()
+ });
+ if (settings.debug) {
+ console.log(this.data('panZoom'));
+ }
+ }
+
+ function setupCSS() {
+ if (this.parent().css('position') == 'static') {
+ this.parent().css('position', 'relative');
+ }
+ this.css({
+ 'position': 'absolute',
+ 'top': 0,
+ 'left': 0
+ });
+ if (settings.draggable) {
+ this.css({
+ 'cursor': 'move'
+ });
+ }
+ }
+
+ function validatePosition() {
+ var data = this.data('panZoom');
+ // if dimensions are too small...
+ if ( data.position.x2 - data.position.x1 <
settings.min_width/settings.factor || data.position.y2 - data.position.y1 <
settings.min_height/settings.factor ) {
+ // and second co-ords are zero (IE: no dims set), fit image
+ if (data.position.x2 == 0 || data.position.y2 == 0) {
+ methods.fit.apply(this);
+ }
+ // otherwise, backout a bit
+ else {
+ if (data.position.x2 - data.position.x1 <
settings.min_width/settings.factor) {
+ data.position.x2 =
data.position.x1*1+settings.min_width/settings.factor;
+ }
+ if (data.position.y2 - data.position.y1 <
settings.min_height/settings.factor) {
+ data.position.y2 =
data.position.y1*1+settings.min_height/settings.factor;
+ }
+ }
+ }
+
+ if (settings.aspect) {
+ target = data.target_dimensions.ratio;
+ current = getCurrentAspectRatio.apply(this)
+ if (current > target) {
+ new_width = getHeight.apply(this) * target;
+ diff = getWidth.apply(this) - new_width;
+ data.position.x1 = data.position.x1*1 + (diff/2);
+ data.position.x2 = data.position.x2*1 - (diff/2);
+ } else if (current < target) {
+ new_height = getWidth.apply(this) / target;
+ diff = getHeight.apply(this) - new_height;
+ data.position.y1 = data.position.y1*1 + (diff/2);
+ data.position.y2 = data.position.y2*1 - (diff/2);
+ }
+ }
+
+
+ }
+
+ function applyPosition() {
+ var data = this.data('panZoom');
+
+ width = getWidth.apply(this);
+ height = getHeight.apply(this);
+ left_offset = getLeftOffset.apply(this);
+ top_offset = getTopOffset.apply(this);
+
+ properties = {
+ 'top': Math.round(top_offset),
+ 'left': Math.round(left_offset),
+ 'width': Math.round(width),
+ 'height': Math.round(height)
+ }
+
+ if (data.loaded && settings.animate) {
+ applyAnimate.apply(this, [ properties ]);
+ } else {
+ applyCSS.apply(this, [ properties ]);
+ }
+
+ if (settings.debug) {
+ console.log('--');
+ console.log('width:' + width);
+ console.log('height:' + height);
+ console.log('left:' + left_offset);
+ console.log('top:' + top_offset);
+ }
+ }
+
+ function applyCSS() {
+ this.css( properties );
+ }
+
+ function applyAnimate() {
+ this.stop().animate( properties , settings.animate_duration,
settings.animate_easing);
+ }
+
+ function getWidth() {
+ var data = this.data('panZoom');
+ width = (data.position.x2 - data.position.x1);
+ return width;
+ }
+
+ function getLeftOffset() {
+ var data = this.data('panZoom');
+ return data.position.x1;
+ }
+
+ function getHeight() {
+ var data = this.data('panZoom');
+ height = (data.position.y2 - data.position.y1);
+ return height;
+ }
+
+ function getTopOffset() {
+ var data = this.data('panZoom');
+ top_offset = data.position.y1;
+ return top_offset;
+ }
+
+ function getCurrentAspectRatio() {
+ return (getWidth.apply(this) / getHeight.apply(this));
+ }
+
+ function writePosition() {
+ var data = this.data('panZoom');
+ if (settings.out_x1) { settings.out_x1.val(Math.round(data.position.x1 /
settings.factor)) }
+ if (settings.out_y1) { settings.out_y1.val(Math.round(data.position.y1 /
settings.factor)) }
+ if (settings.out_x2) { settings.out_x2.val(Math.round(data.position.x2 /
settings.factor)) }
+ if (settings.out_y2) { settings.out_y2.val(Math.round(data.position.y2 /
settings.factor)) }
+ }
+
+ function getStepDimensions() {
+ var data = this.data('panZoom');
+ ret = {
+ zoom: {
+ x: (settings.zoom_step/100 * data.viewport_dimensions.x),
+ y: (settings.zoom_step/100 * data.viewport_dimensions.y)
+ },
+ pan: {
+ x: (settings.pan_step/100 * data.viewport_dimensions.x),
+ y: (settings.pan_step/100 * data.viewport_dimensions.y)
+ }
+ }
+ return ret;
+ }
+
+ function loadTargetDimensions() {
+ var data = this.data('panZoom');
+ var img = document.createElement('img');
+ img.src = this.attr('src');
+ img.id = "jqpz-temp";
+ $('body').append(img);
+ data.target_dimensions.x = $('#jqpz-temp').width();
+ data.target_dimensions.y = $('#jqpz-temp').height();
+ $('#jqpz-temp').remove();
+ data.target_dimensions.ratio = data.target_dimensions.x /
data.target_dimensions.y;
+ }
+
+})( jQuery );
--
To view, visit https://gerrit.wikimedia.org/r/79846
To unsubscribe, visit https://gerrit.wikimedia.org/r/settings
Gerrit-MessageType: newchange
Gerrit-Change-Id: I5831618a5c0d4c23ceab4cedc1633c9a24831326
Gerrit-PatchSet: 1
Gerrit-Project: mediawiki/extensions/ProofreadPage
Gerrit-Branch: pagePagesRefactoring
Gerrit-Owner: Rtdwivedi <[email protected]>
_______________________________________________
MediaWiki-commits mailing list
[email protected]
https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits