mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| window.addEventListener('load', () => {
 | |
|     const gameInfo = document.getElementById('game-info');
 | |
|     new Promise((resolve, reject) => {
 | |
|         const ajax = new XMLHttpRequest();
 | |
|         ajax.onreadystatechange = () => {
 | |
|             if (ajax.readyState !== 4) { return; }
 | |
|             if (ajax.status === 404) {
 | |
|                 reject("Sorry, this game's info page is not available in that language yet.");
 | |
|                 return;
 | |
|             }
 | |
|             if (ajax.status !== 200) {
 | |
|                 reject("Something went wrong while loading the info page.");
 | |
|                 return;
 | |
|             }
 | |
|             resolve(ajax.responseText);
 | |
|         };
 | |
|         ajax.open('GET', `${window.location.origin}/static/generated/docs/${gameInfo.getAttribute('data-game')}/` +
 | |
|           `${gameInfo.getAttribute('data-lang')}_${gameInfo.getAttribute('data-game')}.md`, true);
 | |
|         ajax.send();
 | |
|     }).then((results) => {
 | |
|         // Populate page with HTML generated from markdown
 | |
|         showdown.setOption('tables', true);
 | |
|         showdown.setOption('strikethrough', true);
 | |
|         showdown.setOption('literalMidWordUnderscores', true);
 | |
|         gameInfo.innerHTML += (new showdown.Converter()).makeHtml(results);
 | |
| 
 | |
|         // Reset the id of all header divs to something nicer
 | |
|         for (const header of document.querySelectorAll('h1, h2, h3, h4, h5, h6')) {
 | |
|             const headerId = header.innerText.replace(/\s+/g, '-').toLowerCase();
 | |
|             header.setAttribute('id', headerId);
 | |
|             header.addEventListener('click', () => {
 | |
|                 window.location.hash = `#${headerId}`;
 | |
|                 header.scrollIntoView();
 | |
|             });
 | |
|         }
 | |
| 
 | |
|         // Manually scroll the user to the appropriate header if anchor navigation is used
 | |
|         document.fonts.ready.finally(() => {
 | |
|             if (window.location.hash) {
 | |
|                 const scrollTarget = document.getElementById(window.location.hash.substring(1));
 | |
|                 scrollTarget?.scrollIntoView();
 | |
|             }
 | |
|         });
 | |
|     });
 | |
| });
 | 
