Toggle menu
Toggle preferences menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

MediaWiki:Common.js: Difference between revisions

MediaWiki interface page
LightSwitch (talk | contribs)
No edit summary
NekoPillow (talk | contribs)
No edit summary
Line 3: Line 3:
     var __public = {};
     var __public = {};
     var realTime, localTime;
     var realTime, localTime;
     var dstRangeStart, dstRangeEnd, tzOffset, dstOffset, tzOffsetFinal, isDST;
     var eventObject;
      
      
     // - clock_sync() - Sync the clock with the server and get timezone info
     // - clock_sync() - Sync the clock with the server and get timezone info
     function clock_sync() {
     function clock_sync() {
         jQuery.get("//worldtimeapi.org/api/timezone/America/New_York", function(a) {
         jQuery.get("//gt.tommyhub.com/api/v1/event", function(a) {
        eventObject = a;
             localTime = +new Date();
             localTime = +new Date();
             realTime = +new Date(a.utc_datetime);
             realTime = +new Date(a.time.timestamp);
            dstRangeStart = +new Date(a.dst_from);
            dstRangeEnd = +new Date(a.dst_until);
             tzOffset = a.raw_offset;
             tzOffset = a.raw_offset;
            dstOffset = a.dst_offset;
            isDST = a.dst;
             clock_tick();
             clock_tick();
         });
         });
Line 28: Line 25:
             realTime += _diffTime;
             realTime += _diffTime;
              
              
             if(!isDST && realTime>=dstRangeStart && realTime<dstRangeEnd) isDST = true;
             clock_update(realTime);
            else if(isDST && realTime>=dstRangeEnd) isDST = false;
              
              
            tzOffsetFinal = tzOffset*1000;
             if(realTime>=a.time.next_transition) clock_sync()
             if(isDST) tzOffsetFinal += dstOffset*1000;
else setTimeout(clock_tick, 1000-realTime%1000);
           
            clock_update(realTime);
setTimeout(clock_tick, 1000-realTime%1000);
         }
         }
     }
     }
Line 46: Line 39:
     // + this.format() - Print the date in specified format
     // + this.format() - Print the date in specified format
     __public.format = function(format) {
     __public.format = function(format) {
         var clock = new Date(realTime+tzOffsetFinal);
         var clock = new Date(realTime+eventObject.time.offset*1000);
          
          
         var month_short_arr = ["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];
         var month_short_arr = ["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];

Revision as of 13:58, 18 December 2020

//----- [ Home Clock ] -----//
function clock_init(clock_update) {
    var __public = {};
    var realTime, localTime;
    var eventObject;
    
    // - clock_sync() - Sync the clock with the server and get timezone info
    function clock_sync() {
        jQuery.get("//gt.tommyhub.com/api/v1/event", function(a) {
        	eventObject = a;
            localTime = +new Date();
            realTime = +new Date(a.time.timestamp);
            tzOffset = a.raw_offset;
            clock_tick();
        });
    }
    // - clock_tick() - Updating the clock
    function clock_tick() {
        var _currentTime = +new Date();
        var _diffTime = _currentTime-localTime;
        localTime = _currentTime;
        
        if(Math.abs(_diffTime)>2000) clock_sync();
        else {
            realTime += _diffTime;
            
            clock_update(realTime);
            
            if(realTime>=a.time.next_transition) clock_sync()
			else setTimeout(clock_tick, 1000-realTime%1000);
        }
    }
    // - clock_pad() - Pad Zero in front of the number
    function clock_pad(str) {
		return ("0"+str).substr(-2);
	}
    clock_sync();

    // + this.format() - Print the date in specified format
    __public.format = function(format) {
        var clock = new Date(realTime+eventObject.time.offset*1000);
        
        var month_short_arr = ["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];
        
		var get = "getUTC";
		// Year
		format = format.replace(/(?<!%)%Y/g,clock[get+"FullYear"]());				// Y - 4 digits | 2020
		// Month
		format = format.replace(/(?<!%)%m/g,clock_pad(clock[get+"Month"]()+1));		// m - padding 0 | 01
		format = format.replace(/(?<!%)%n/g,clock[get+"Month"]()+1);				// n - no padding | 1
		format = format.replace(/(?<!%)%M/g,month_short_arr[clock[get+"Month"]()]); // M - Short textual | Jan
		// Day
		format = format.replace(/(?<!%)%d/g,clock_pad(clock[get+"Date"]()));		// d - padding 0 | 01
		format = format.replace(/(?<!%)%j/g,clock[get+"Date"]());					// j - no padding | 1
		// Hour
		format = format.replace(/(?<!%)%H/g,clock_pad(clock[get+"Hours"]()));		// H - 24-h | padding 0 | 01 13
		format = format.replace(/(?<!%)%G/g,clock[get+"Hours"]());					// G - 24-h | no padding | 1 13
		// Minutes
		format = format.replace(/(?<!%)%i/g,clock_pad(clock[get+"Minutes"]()));		// i - padding 0 | 01
		// Seconds
		format = format.replace(/(?<!%)%s/g,clock_pad(clock[get+"Seconds"]()));		// s - padding 0 | 01
		
		return format.replace("%%","%");
	}
	return __public;
}

//----- [ jQuery onLoad ] -----//
$(function() {
    var _pagename = mw.config.get('wgPageName');
    
    if(_pagename == "Growtopia_Wiki") {
        var _clock = clock_init(function(time) {
            $("#gtw-clock #c-time").html(_clock.format("%H:%i:%s"));
            $("#gtw-clock #c-date").html(_clock.format("%j %M %Y"));
        });
    }

	// ----- [ Tab View Remaster.JS - COPYRIGHTED BY NEKOPILLOW ] -----//
	$(".gtw-tabview").on("click","a", function() {
		var $parent = $(this).parents(".gtw-tabview");
		var $href = $(this).attr("href");
		if(!/^\/wiki\//.test($href)) return true; // Only allow wiki interlink for security reason
		$parent.find("a").removeClass("active");
		$(this).addClass("active");
		$parent.next(".gtw-tabpage").remove();
		$.get($href, function(a) {
			$parent.next(".gtw-tabpage").remove();
			$("<div>",{class:"gtw-tabpage"}).insertAfter($parent).html($(a).find("#mw-content-text .mw-parser-output").html());
		});
	    return false;
	}).each(function(){
		var $default = $(this).attr("data-default");
		if($default != undefined) {
			$(this).find("a[href$="+$default+"]").click();
		}
	});
});