No edit summary
No edit summary
Line 22: Line 22:
}
}


function advanceSequenceImage(infoboxImageRow, infoboxImageCount) {
function advanceInfoboxImage(infoboxImageRow, infoboxImageCount) {
var transformStyle = infoboxImageRow.style.transform;
var transformStyle = infoboxImageRow.style.transform;
var offset = 0;
var offset = 0;
Line 39: Line 39:
var infoboxImageCount = infoboxImageRow.getElementsByClassName('image').length;
var infoboxImageCount = infoboxImageRow.getElementsByClassName('image').length;
if (infoboxImageCount > 1) {
if (infoboxImageCount > 1) {
advanceSequenceImage(infoboxImageRow, infoboxImageCount);
advanceInfoboxImage(infoboxImageRow, infoboxImageCount);
setInterval(advanceSequenceImage, 1500, infoboxImageRow, infoboxImageCount);
setInterval(advanceInfoboxImage, 1500, infoboxImageRow, infoboxImageCount);
}
}
}
}
Line 52: Line 52:
     document.documentElement.setAttribute('theme', 'light');
     document.documentElement.setAttribute('theme', 'light');
}
}
}
function advanceSequenceImage(rowContainer, imageRowCount, width) {
var transformStyle = infoboxImageRow.style.transform;
var offset = 0;
if (transformStyle) {
var currentOffset = parseInt(transformStyle.replace('translateX(','').replace('px)',''));
offset = (currentOffset <= (infoboxImageCount - 1) * -width) ? 0 : (currentOffset - width);
}
infoboxImageRow.style.transform = 'translateX(' + offset + '%)';
}
}


Line 59: Line 69:
for (var i = 0; i < elements.length; i++) {
for (var i = 0; i < elements.length; i++) {
var element = elements[i];
var element = elements[i];
var styleAttribute = element.getAttribute('style');
var rowContainer = element.querySelector('p');
var rowContainer = element.querySelector('p');


if (rowContainer) {
var width = null;
if (styleAttribute) {
var widthStyle = styleAttribute.match(/width\s*:\s*([^;]+);?/i);
if (widthStyle) {
width = widthStyle[1].trim();
}
}
 
if (width && rowContainer) {
var imageRowCount = rowContainer.querySelectorAll(':scope > a').length;
var imageRowCount = rowContainer.querySelectorAll(':scope > a').length;
if (imageRowCount > 1) {
if (imageRowCount > 1) {
advanceSequenceImage(rowContainer, imageRowCount);
advanceSequenceImage(rowContainer, imageRowCount, width);
setInterval(advanceSequenceImage, 1500, rowContainer, imageRowCount);
setInterval(advanceSequenceImage, 1500, rowContainer, imageRowCount, width);
}
}
}
}

Revision as of 01:49, 23 November 2025

function overrideSourceEdit() {
	var sourceEdit = document.getElementById('ca-edit');
	if (sourceEdit) {
	 var url = sourceEdit.getAttribute('href');
	 sourceEdit.setAttribute('href', url.split('&section')[0]);
	}
}

function getDarkModePreference() {
	return window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
}

function applyDarkMode() {
	var body = document.querySelector('body');
	if (getDarkModePreference()) {
		if (!body.classList.contains('dark-mode')) { body.classList.add('dark-mode'); }
		document.documentElement.setAttribute('theme', 'dark');
	} else {
		if (body.classList.contains('dark-mode')) { body.classList.remove('dark-mode'); }
    	document.documentElement.setAttribute('theme', 'light');
	}
}

function advanceInfoboxImage(infoboxImageRow, infoboxImageCount) {
	var transformStyle = infoboxImageRow.style.transform;
	var offset = 0;
	if (transformStyle) {
		var currentOffset = parseInt(transformStyle.replace('translateX(','').replace('%)',''));
		offset = (currentOffset <= (infoboxImageCount - 1) * -100) ? 0 : (currentOffset - 100);
	}
	infoboxImageRow.style.transform = 'translateX(' + offset + '%)';
}

function startInfoboxImageScroll() {
	var elements = document.getElementsByClassName('infobox-image-row');
	if (elements.length > 0) {
		for (var i = 0; i < elements.length; i++) {
			var infoboxImageRow = elements[i];
			var infoboxImageCount = infoboxImageRow.getElementsByClassName('image').length;
			if (infoboxImageCount > 1) {
				advanceInfoboxImage(infoboxImageRow, infoboxImageCount);
				setInterval(advanceInfoboxImage, 1500, infoboxImageRow, infoboxImageCount);
			}
		}
	}
	var body = document.querySelector('body');
	if (getDarkModePreference()) {
		if (!body.classList.contains('dark-mode')) { body.classList.add('dark-mode'); }
		document.documentElement.setAttribute('theme', 'dark');
	} else {
		if (body.classList.contains('dark-mode')) { body.classList.remove('dark-mode'); }
    	document.documentElement.setAttribute('theme', 'light');
	}
}

function advanceSequenceImage(rowContainer, imageRowCount, width) {
	var transformStyle = infoboxImageRow.style.transform;
	var offset = 0;
	if (transformStyle) {
		var currentOffset = parseInt(transformStyle.replace('translateX(','').replace('px)',''));
		offset = (currentOffset <= (infoboxImageCount - 1) * -width) ? 0 : (currentOffset - width);
	}
	infoboxImageRow.style.transform = 'translateX(' + offset + '%)';
}

function startSequenceImageScroll() {
	var elements = document.getElementsByClassName('image-sequence');
	if (elements.length > 0) {
		for (var i = 0; i < elements.length; i++) {
			var element = elements[i];
			var styleAttribute = element.getAttribute('style');
			var rowContainer = element.querySelector('p');

			var width = null;
			if (styleAttribute) {
				var widthStyle = styleAttribute.match(/width\s*:\s*([^;]+);?/i);
				if (widthStyle) {
					width = widthStyle[1].trim();
				}
			}

			if (width && rowContainer) {
				var imageRowCount = rowContainer.querySelectorAll(':scope > a').length;
				if (imageRowCount > 1) {
					advanceSequenceImage(rowContainer, imageRowCount, width);
					setInterval(advanceSequenceImage, 1500, rowContainer, imageRowCount, width);
				}
			}
		}
	}
}

// applyDarkMode();
overrideSourceEdit();
startInfoboxImageScroll();
startSequenceImageScroll();