MediaWiki:Common.js: Difference between revisions

MediaWiki interface page
No edit summary
Tag: Manual revert
No edit summary
Tag: Reverted
Line 29: Line 29:
});
});
});
});
// on page load we want to run this:
// ------------------------------------------------------------
var containers = document.getElementsByClassName("ts-inner");
// check if we have anything set in session
var sessionToggleWidth = sessionStorage.getItem("setToggleWidth");
// if we do have session width then we want to apply it to all containers
if(sessionToggleWidth) {
    for (let container of containers) {
      container.style.maxWidth = sessionToggleWidth;
  }
}

Revision as of 15:46, 14 July 2023

mw.hook('wikipage.content').add(function($content) {
	var $bandcamp = $content.find( '.bandcamp:not(.loaded)' );
    if ( !$bandcamp.length ) return;
 
	$bandcamp.each( function() {
		var elem = $( this );
 
		var width = elem.attr( 'data-width' ),
			height = elem.attr( 'data-height' ),
			data_src = elem.attr( 'data-src' );
 
		if ( !/^https?:\/\/bandcamp\.com\//.test( data_src ) ) return;
		elem.empty();
		var is_px = [ true, true ]; // width, height
 
		if ( /%/.test( width ) || !/\d+/.test( width ) ) is_px[ 0 ] = false;
		if ( /%/.test( height ) ) is_px[ 1 ] = false;

		var frame_width = parseFloat( width, 10 ) || 100;
			frame_height = height ? ( parseFloat( height, 10 ) || 'auto' ) : '';
 
		$( '<iframe />', {
			style: 'border: 0',
			width: frame_width + ( is_px[ 0 ] ? 'px' : '%' ),
			height: frame_height + ( frame_height ? ( is_px[ 1 ] ? 'px': '%' ) : '' ),
			src: data_src
		}).appendTo( elem );
            elem.addClass( 'loaded' );
	});
});

// on page load we want to run this:
// ------------------------------------------------------------
var containers = document.getElementsByClassName("ts-inner");
// check if we have anything set in session
var sessionToggleWidth = sessionStorage.getItem("setToggleWidth");
// if we do have session width then we want to apply it to all containers
if(sessionToggleWidth) {
    for (let container of containers) {
      container.style.maxWidth = sessionToggleWidth; 
   }
}