MediaWiki:Gadget-recentChanges.js: mudanças entre as edições

Página de Interface do MediaWiki
m (Adicionada espaço da Biblioteca para mudanças recentes)
m (oops if duplo)
 
(7 revisões intermediárias pelo mesmo usuário não estão sendo mostradas)
Linha 1: Linha 1:
//<nowiki>
/**
/**
  * Adds a recent changes widget to the sidebar
  * Recent changes sidebar gadget for the Citizen skin
*
  * Originally created by @author JaydenKieran from RunescapeWiki
  * @author JaydenKieran
**/
*/
"use strict";
'use strict';
 


;
(function($, mw) {
(function($, mw) {
     var $prependTo
     var $prependTo;
     var $rcContainer
     var $rcContainer;
     var recentChanges
     var recentChanges;
     var $recentChangesDOM
     var $recentChangesDOM;
    var $final;
   
    var citizen = mw.config.get('skin') == 'citizen';
    var vector = mw.config.get('skin') == 'vector';


     function init() {
     function init() {
         $prependTo = $('#p-Navigation')
         $prependTo = $('#p-navigation');
         var api = new mw.Api()
         var api = new mw.Api();
 
       
         // Build our container
         //Adopting different structures for different skins
         $rcContainer = $('<nav>')
         if (citizen) {
        $final = $('<ul>').after($rcContainer);
var $div = $('<div>').text('Mudanças recentes')
        .addClass('citizen-menu__heading');
        $rcContainer = $('<nav>')
.addClass('citizen-menu mw-portlet mw-portlet-RecentChanges')
.attr('id', 'p-RecentChanges')
.append($div)
.append($final);
        } else if (vector) {
        $rcContainer = $('<nav>')
             .addClass('vector-menu vector-menu-portal portal')
             .addClass('vector-menu vector-menu-portal portal')
             .attr('id', 'p-RecentChanges')
             .attr('id', 'p-RecentChanges')
             .append(
             .append(
                 $('<h3>').text('Mudanças recentes')
                 $('<label>').text('Recent changes')
                .addClass('vector-menu-heading')
                .attr('id', 'p-RecentChanges-label')
             )
             )
        }


         // Add the container to the sidebar
         // Add the container to the sidebar
Linha 33: Linha 48:
                 list: "recentchanges",
                 list: "recentchanges",
                 rcprop: "title|timestamp|sizes|user",
                 rcprop: "title|timestamp|sizes|user",
                 rcnamespace: 0|3000,
                 rcnamespace: "0|3000",
                 rclimit: "5",
                 rclimit: "5",
                 rctype: "edit|new",
                 rctype: "edit|new",
                 rcshow: "!bot",
                 rcshow: "!bot|!redirect",
                 rctoponly: 1,
                 rctoponly: 1,
                 format: "json"
                 format: "json"
Linha 48: Linha 63:
                     var Time = 1;
                     var Time = 1;
                     $recentChangesDOM = recentChanges.map(function(rc) {
                     $recentChangesDOM = recentChanges.map(function(rc) {
                    const timeMatch = rc.timestamp.match(/([0-9]+)-([0-9]+)-([0-9]+)T([0-9]+):([0-9]+):([0-9]+)Z/);
                        const timeMatch = rc.timestamp.match(/([0-9]+)-([0-9]+)-([0-9]+)T([0-9]+):([0-9]+):([0-9]+)Z/);
                     var editYear = timeMatch[1];
                     var editYear = timeMatch[1];
                     var editMonth = timeMatch[2];
                     var editMonth = timeMatch[2];
Linha 66: Linha 81:
if (diffDays > 0) {
if (diffDays > 0) {
Time = diffDays + 'd atrás – ';
Time = diffDays + 'd ago – ';
} else if (diffHours > 0) {
} else if (diffHours > 0) {
Time = diffHours + 'h atrás – ';
Time = diffHours + 'h ago – ';
} else if (diffMinutes > 0) {
} else if (diffMinutes > 0) {
Time = diffMinutes + 'm atrás – ';
Time = diffMinutes + 'm ago – ';
} else if (diffSeconds > 0) {
} else if (diffSeconds > 0) {
Time = diffSeconds + 's atrás – ';
Time = diffSeconds + 's ago – ';
} else {
} else {
Time = 1 + Math.floor(Math.random() * 10) + 'm atrás – ';
Time = 1 + Math.floor(Math.random() * 10) + 'm ago – ';
}
}
 
if (citizen) {
                         return $('<div>').addClass('rc-sidebar-item').append(
var $a = $('<a>')
                            $('<a>')
                            .css('white-space', 'normal')
                            .addClass('rc-sidebar-page')
                            .addClass('rc-sidebar-page')
                            .text(' ' + rc.title)
                            .css({
                            .attr('href', new mw.Title(rc.title).getUrl()),
                            'padding-top': '0.25em',
                            $('<p>')
                            'padding-bottom': '0.25em'
                            .addClass('rc-sidebar-user')
                            })
                            .text(Time)
                            .text(' ' + rc.title)
                            .append(
                            .attr('href', new mw.Title(rc.title).getUrl());
                                $('<a>')
                        var $p = $('<p>')
                                .text(rc.user)
                            .css({
                                .attr('href', new mw.Title(rc.user, 2).getUrl())
                            'text-align': 'right',
                            'margin-right': '2.5em'
                            })
                            .addClass('rc-sidebar-user')
                            .text(Time)
                            .append(
                                $('<a>')
                                .css({
                            'display' : '-webkit-inline-box',
                            'padding' : '0px'
                                })
                                .text(rc.user)
                                .attr('href', new mw.Title(rc.user, 2).getUrl())
                            );
                        return $('<li>').addClass('mw-list-item').append($a,$p);
                         } else if (vector) {
                        return $('<div>').addClass('rc-sidebar-item').append(
                            $('<a>')
                            .addClass('rc-sidebar-page')
                            .text(' ' + rc.title)
                            .attr('href', new mw.Title(rc.title).getUrl()),
                            $('<p>')
                            .addClass('rc-sidebar-user')
                            .text(Time)
                            .append(
                            $('<a>')
                                .text(rc.user)
                                .attr('href', new mw.Title(rc.user, 2).getUrl())
                            )
                             )
                             )
                         )
                         }
                     })
                     })
                 } else {
                 } else {
                     $recentChangesDOM = $('<p>').text('Sem mudanças recentes.')
                     $recentChangesDOM = $('<p>').text('No recent changes.')
                }
                if (vector) {
                $final = $rcContainer;
                 }
                 }
                 $rcContainer.append($recentChangesDOM)
                 $final.append($recentChangesDOM)
                 var $showMore
                 var $showMore
$showMore = $('<div>')
$showMore = $('<div>')
Linha 102: Linha 148:
                 $('<a>')
                 $('<a>')
                 .addClass('rc-sidebar-page')
                 .addClass('rc-sidebar-page')
                 .text('Ver mais...')
                 .text('See more...')
                 .attr('href', '/wiki/Especial:Mudanças recentes')
                 .attr('href', '/wiki/Special:RecentChanges')
                 )
                 )
                 $rcContainer.append($showMore)
                 $final.append($showMore)
             })
             })
             .fail(function(_, data) {
             .fail(function(_, data) {
Linha 116: Linha 162:
     })
     })
}(jQuery, mediaWiki));
}(jQuery, mediaWiki));
//</nowiki>

Edição atual tal como às 17h17min de 23 de julho de 2023

/**
 *		Recent changes sidebar gadget for the Citizen skin
 *		Originally created by @author JaydenKieran from RunescapeWiki
**/
"use strict";


(function($, mw) {
    var $prependTo;
    var $rcContainer;
    var recentChanges;
    var $recentChangesDOM;
    var $final;
    
    var citizen = mw.config.get('skin') == 'citizen';
    var vector = mw.config.get('skin') == 'vector';

    function init() {
        $prependTo = $('#p-navigation');
        var api = new mw.Api();
        
        //Adopting different structures for different skins
        if (citizen) {
        	$final = $('<ul>').after($rcContainer);
			var $div = $('<div>').text('Mudanças recentes')
        		.addClass('citizen-menu__heading');
	        $rcContainer = $('<nav>')
				.addClass('citizen-menu mw-portlet mw-portlet-RecentChanges')
				.attr('id', 'p-RecentChanges')
				.append($div)
				.append($final);
        } else if (vector) {
        	$rcContainer = $('<nav>')
            .addClass('vector-menu vector-menu-portal portal')
            .attr('id', 'p-RecentChanges')
            .append(
                $('<label>').text('Recent changes')
                	.addClass('vector-menu-heading')
                	.attr('id', 'p-RecentChanges-label')
            )
        }

        // Add the container to the sidebar
        $prependTo.after($rcContainer)

        api.get({
                action: "query",
                list: "recentchanges",
                rcprop: "title|timestamp|sizes|user",
                rcnamespace: "0|3000",
                rclimit: "5",
                rctype: "edit|new",
                rcshow: "!bot|!redirect",
                rctoponly: 1,
                format: "json"
            })
            .done(function(data) {
                if (data.query && data.query.recentchanges) {
                    recentChanges = data.query.recentchanges
                }

                if (recentChanges.length > 0) {
                    var Time = 1;
                    $recentChangesDOM = recentChanges.map(function(rc) {
                        const timeMatch = rc.timestamp.match(/([0-9]+)-([0-9]+)-([0-9]+)T([0-9]+):([0-9]+):([0-9]+)Z/);
                    	var editYear = timeMatch[1];
                    	var editMonth = timeMatch[2];
                    	var editDay = timeMatch[3];
                    	var editHour = timeMatch[4];
                    	var editMinute = timeMatch[5];
                    	var editSecond = timeMatch[6];
                    	
                    	var editDate = new Date(editYear, (editMonth-1), editDay, editHour, editMinute, editSecond);
						var currentDate = new Date();
						currentDate = currentDate.getTime() + (currentDate.getTimezoneOffset() * 60000)
						var diffDate = currentDate - editDate;
						var diffDays = Math.floor(diffDate/(1000*60*60*24));
						var diffHours = Math.floor(diffDate/(1000*60*60));
						var diffMinutes = Math.floor(diffDate/(1000*60));
						var diffSeconds = Math.floor(diffDate/(1000));
						
						if (diffDays > 0) {
							Time = diffDays + 'd ago – ';
						} else if (diffHours > 0) {
							Time = diffHours + 'h ago – ';
						} else if (diffMinutes > 0) {
							Time = diffMinutes + 'm ago – ';
						} else if (diffSeconds > 0) {
							Time = diffSeconds + 's ago – ';
						} else {
							Time = 1 + Math.floor(Math.random() * 10) + 'm ago – ';
						}
						if (citizen) {
							var $a = $('<a>')
	                            .css('white-space', 'normal')
	                            .addClass('rc-sidebar-page')
	                            .css({
	                            	'padding-top': '0.25em',
	                            	'padding-bottom': '0.25em'
	                            })
	                            .text(' ' + rc.title)
	                            .attr('href', new mw.Title(rc.title).getUrl());
	                        var $p = $('<p>')
	                            .css({
	                            	'text-align': 'right',
	                            	'margin-right': '2.5em'
	                            	})
	                            .addClass('rc-sidebar-user')
	                            .text(Time)
	                            .append(
	                                $('<a>')
	                                .css({
	                            	'display' : '-webkit-inline-box',
	                            	'padding' : '0px'
	                                })
	                                .text(rc.user)
	                                .attr('href', new mw.Title(rc.user, 2).getUrl())
	                            );
	                        return $('<li>').addClass('mw-list-item').append($a,$p);
                        } else if (vector) {
                        	return $('<div>').addClass('rc-sidebar-item').append(
                            	$('<a>')
                            		.addClass('rc-sidebar-page')
                            		.text(' ' + rc.title)
                            		.attr('href', new mw.Title(rc.title).getUrl()),
                            	$('<p>')
                            		.addClass('rc-sidebar-user')
                            		.text(Time)
                            		.append(
                            			$('<a>')
                                			.text(rc.user)
                                			.attr('href', new mw.Title(rc.user, 2).getUrl())
                            		)
                            )
                        }
                    })
                } else {
                    $recentChangesDOM = $('<p>').text('No recent changes.')
                }
                if (vector) {
                	$final = $rcContainer;
                }
                $final.append($recentChangesDOM)
                var $showMore
				$showMore = $('<div>')
                	.addClass('rc-sidebar-item rc-sidebar-more')
                	.append(
                		$('<a>')
                		.addClass('rc-sidebar-page')
                		.text('See more...')
                		.attr('href', '/wiki/Special:RecentChanges')
                )
                $final.append($showMore)
            })
            .fail(function(_, data) {
                alert(data.error.info)
            });
    }

    mw.loader.using(['mediawiki.util', 'mediawiki.api'], function() {
        $(init)
    })
}(jQuery, mediaWiki));