mirror of
				https://github.com/Investigamer/cardconjurer.git
				synced 2025-10-26 04:40:41 -05:00 
			
		
		
		
	 432bdc998b
			
		
	
	432bdc998b
	
	
	
		
			
			- Moving to HTMX integration - Improving links for local use - File structure - Hiding clutter
		
			
				
	
	
		
			232 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			232 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!-- START OF CONTENT -->
 | |
| 	<h2 class='readable-background header-extension title center'>Available Frames</h2>
 | |
| 	<h4 class='readable-background header-extension center'>What they're called, and where to find them</h4>
 | |
| 	<div class='layer'>
 | |
| 		<h3 class='center galleryGridTitle'>Showcase Frames</h3>
 | |
| 		<div class='galleryGrid' id="showcaseGrid"></div>
 | |
| 	</div>
 | |
| 	<div class='layer'>
 | |
| 		<h3 class='center galleryGridTitle'>Promo Frames</h3>
 | |
| 		<div class='galleryGrid' id="promoGrid"></div>
 | |
| 	</div>
 | |
| 	<div class='layer'>
 | |
| 		<h3 class='center galleryGridTitle'>Textless Frames</h3>
 | |
| 		<div class='galleryGrid' id="textlessGrid"></div>
 | |
| 	</div>
 | |
| 	<div class='layer'>
 | |
| 		<h3 class='center galleryGridTitle'>Custom Frames</h3>
 | |
| 		<div class='galleryGrid' id="customGrid"></div>
 | |
| 	</div>
 | |
| 	<div class='layer'>
 | |
| 		<h3 class='center galleryGridTitle'>Regular Frames</h3>
 | |
| 		<div class='galleryGrid' id="regularGrid"></div>
 | |
| 	</div>
 | |
| 	<div class='layer'>
 | |
| 		<h3 class='center galleryGridTitle'>Token Frames</h3>
 | |
| 		<div class='galleryGrid' id="tokenGrid"></div>
 | |
| 	</div>
 | |
| 	<!-- <div class='layer'>
 | |
| 		<h3 class='center galleryGridTitle'>Other Frames</h3>
 | |
| 		<div class='galleryGrid' id="otherGrid"></div>
 | |
| 	</div> -->
 | |
| 	<style>
 | |
| 		.galleryGridTitle {
 | |
| 			margin-bottom: 4rem;
 | |
| 		}
 | |
| 		.galleryGrid {
 | |
| 			display: grid;
 | |
| 			grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
 | |
| 			grid-gap: 0.5rem;
 | |
| 			margin-bottom: 0.5rem;
 | |
| 			grid-gap: 2rem;
 | |
| 			padding-top: 0;
 | |
| 			align-content: start;
 | |
| 		}
 | |
| 		.galleryGridItem {
 | |
| 			max-width: 80vw;
 | |
| 			width: 20rem;
 | |
| 			height: auto;
 | |
| 			margin: auto;
 | |
| 			border-radius: 1rem;
 | |
| 			padding: 0.5rem;
 | |
| 		}
 | |
| 		.galleryGridItem > img {
 | |
| 			width: 100%;
 | |
| 			aspect-ratio: 5 / 7;
 | |
| 		}
 | |
| 		.galleryGridItem > h4 {
 | |
| 			padding: 0.25rem;
 | |
| 		}
 | |
| 		.galleryGridItem > p {
 | |
| 			padding: 0.125rem;
 | |
| 		}
 | |
| 	</style>
 | |
| 	<script>
 | |
| 		//template data
 | |
| 		//REGULAR FRAMES
 | |
| 		const regularTemplates = [
 | |
| 			{name: "Regular", location: "Regular > Regular Frames", image: "regular.png"},
 | |
| 			{name: "Lands", location: "Regular > Lands", image: "land.png"},
 | |
| 			{name: "Class", location: "Regular > Class (D&D)", image: "class.png"},
 | |
| 			{name: "Snow", location: "Regular > Snow (Kaldheim)", image: "snow.png"},
 | |
| 			{name: "Mutate", location: "Regular > Mutate (Ikoria)", image: "mutate.png"},
 | |
| 			{name: "Nyx", location: "Regular > Nyx (Theros)", image: "nyx.png"},
 | |
| 			{name: "Adventures", location: "Regular > Adventures (Eldraine)", image: "adventure.png"},
 | |
| 			{name: "Devoid", location: "Regular > Devoid (Zendikar)", image: "devoid.png"},
 | |
| 			{name: "Aftermath", location: "Regular > Aftermath (Amonkhet)", image: "aftermath.png"},
 | |
| 			{name: "Flip", location: "Regular > Flip (Kamigawa)", image: "flip.png"},
 | |
| 			{name: "Levelers", location: "Regular > Levelers (Zendikar)", image: "levelers.png"},
 | |
| 			{name: "Split", location: "Regular > Split Cards", image: "split.png"},
 | |
| 			{name: "Fuse", location: "Regular > Fuse Cards", image: "fuse.png"},
 | |
| 			{name: "Conspiracies", location: "Regular > Conspiracies (Draft Matters)", image: "conspiracy.png"},
 | |
| 			{name: "Colorshifted", location: "Regular > Colorshifted (Planar Chaos)", image: "colorshifted.png"},
 | |
| 		];
 | |
| 		//TOKEN FRAMES
 | |
| 		const tokenTemplates = [
 | |
| 			{name: "Regular Token", location: "Token > Regular", image: "tokenRegular.png"},
 | |
| 			{name: "Textless Token", location: "Token > Textless", image: "tokenTextless.png"},
 | |
| 			{name: "Tall Token", location: "Token > Tall", image: "tokenTall.png"},
 | |
| 			{name: "Monarch Token", location: "Token > Monarch Token", image: "tokenMonarch.png"},
 | |
| 			{name: "Day/Night Marker", location: "Token > Day/Night Marker", image: "tokenDayNight.png"},
 | |
| 			{name: "Jumpstart Front Cards", location: "Token > Jumpstart Front Cards", image: "tokenJumpstart.png"},
 | |
| 			{name: "Planeswalker Emblems", location: "Token > Planeswalker Emblems", image: "emblem.png"},
 | |
| 			{name: "Regular Token (Old)", location: "Token > Regular Token (Bordered M15)", image: "tokenOldRegular.png"},
 | |
| 			{name: "Textless Token (Old)", location: "Token > Textless Token (Bordered M15)", image: "tokenOldTextless.png"},
 | |
| 			{name: "Original Token", location: "Token > Original (Old Bordered)", image: "tokenOriginal.png"},
 | |
| 			{name: "Unglued Token", location: "Token > Unglued", image: "tokenUnglued.png"},
 | |
| 		];
 | |
| 		//OTHER FRAMES
 | |
| 		const otherTemplates = [
 | |
| 			// {name: "TEMPLATENAME", location: "Token > DISPLAYNAME", image: "IMAGENAME.png"},
 | |
| 		];
 | |
| 		//SHOWCASE FRAMES
 | |
| 		const showcaseTemplates = [
 | |
| 			{name: "Golden Age (SNC)", location: "Showcase Frames > Golden Age (SNC)", image: "sncGilded.png"},
 | |
| 			{name: "Art Deco (SNC)", location: "Showcase Frames > Art Deco (SNC)", image: "sncArtDeco.png"},
 | |
| 			{name: "Skyscraper (SNC)", location: "Showcase Frames > Skyscraper (SNC)", image: "sncSkyscraper.png"},
 | |
| 			{name: "Ninja (NEO)", location: "Showcase Frames > Ninja (NEO)", image: "neoNinja.png"},
 | |
| 			{name: "Samurai (NEO)", location: "Showcase Frames > Samurai (NEO)", image: "neoSamurai.png"},
 | |
| 			{name: "Neon (NEO)", location: "Showcase Frames > Neon (NEO)", image: "neoNeon.png"},
 | |
| 			{name: "Fang (VOW)", location: "Showcase Frames > Fang (VOW)", image: "vowFang.png"},
 | |
| 			{name: "Equinox (Mid)", location: "Showcase Frames > Equinox (Mid)", image: "midEquinox.png"},
 | |
| 			{name: "Eternal Night (Mid)", location: "Showcase Frames > Eternal Night (Mid)", image: "midEternalNight.png"},
 | |
| 			{name: "D&D Sourcebook (AFR)", location: "Showcase Frames > D&D Sourcebook (AFR)", image: "afrSourcebook.png"},
 | |
| 			{name: "D&D Module (AFR)", location: "Showcase Frames > D&D Module (AFR)", image: "afrModule.png"},
 | |
| 			{name: "Sketch Cards (MH2)", location: "Showcase Frames > Sketch Cards (MH2)", image: "mh2Sketch.png"},
 | |
| 			{name: "Mystical Archive (STA)", location: "Showcase Frames > Mystical Archive (STA)", image: "staMysticalArchive.png"},
 | |
| 			{name: "Japanese Mystical Archive (STA)", location: "Showcase Frames > Japanese Mystical Archive (STA)", image: "staMysticalArchiveJP.png"},
 | |
| 			{name: "Phyrexian (KHM)", location: "Showcase Frames > Praetors (KHM)", image: "khmPraetors.png"},
 | |
| 			{name: "Viking (KHM)", location: "Showcase Frames > Kaldheim (KHM)", image: "khm.png"},
 | |
| 			{name: "Nonlegendary Viking (KHM)", location: "Showcase Frames > Nonlegendary Kaldheim (KHM)", image: "khmNonlegendary.png"},
 | |
| 			{name: "Etched Foils (CMR)", location: "Showcase Frames > Commander Legends (CMR)", image: "cmrEtched.png"},
 | |
| 			{name: "Basri Ket (M21)", location: "Showcase Frames > M21 Signature Spellbooks (M21)", image: "m21BasriKet.png"},
 | |
| 			{name: "Teferi (M21)", location: "Showcase Frames > M21 Signature Spellbooks (M21)", image: "m21Teferi.png"},
 | |
| 			{name: "Liliana (M21)", location: "Showcase Frames > M21 Signature Spellbooks (M21)", image: "m21Liliana.png"},
 | |
| 			{name: "Chandra (M21)", location: "Showcase Frames > M21 Signature Spellbooks (M21)", image: "m21Chandra.png"},
 | |
| 			{name: "Garruk (M21)", location: "Showcase Frames > M21 Signature Spellbooks (M21)", image: "m21Garruk.png"},
 | |
| 			{name: "Nyxtouched (THB)", location: "Showcase Frames > Theros Beyond Death (THB)", image: "thb.png"},
 | |
| 			{name: "Storybooks (ELD)", location: "Showcase Frames > Eldraine Storybooks (ELD)", image: "eld.png"},
 | |
| 			{name: "Borderless", location: "Showcase Frames > Borderless", image: "borderless.png"},
 | |
| 			{name: "Fullart", location: "Showcase Frames > Fullart", image: "fullart.png"},
 | |
| 			{name: "Nickname", location: "Showcase Frames > Nickname (\"Godzilla\")", image: "ikoNickname.png"},
 | |
| 			{name: "Extended Art", location: "Showcase Frames > Extended Art (Regular)", image: "extended.png"},
 | |
| 			{name: "FNM Inverted Promo", location: "Showcase Frames > FNM Promo (Inverted Promos)", image: "inverted.png"},
 | |
| 			{name: "Universes Beyond", location: "Showcase Frames > Universes Beyond", image: "universesBeyond.png"},
 | |
| 			{name: "Full Text", location: "Showcase Frames > Full Text", image: "fullText.png"},
 | |
| 			{name: "Etched", location: "Showcase Frames > Etched (Commander Precons)", image: "etched.png"},
 | |
| 			{name: "Expeditions (ZNR)", location: "Showcase Frames > ZNR Expeditions (2020)", image: "znrExpedition.png"},
 | |
| 			{name: "Jace", location: "Showcase Frames > Signature Spellbook (Jace/Gideon)", image: "jace.png"},
 | |
| 			{name: "Gideon", location: "Showcase Frames > Signature Spellbook (Jace/Gideon)", image: "gideon.png"},
 | |
| 			{name: "Gideon (Artifact)", location: "Showcase Frames > Signature Spellbook (Jace/Gideon)", image: "gideonArtifact.png"},
 | |
| 			{name: "Ixalan Maps (XLN)", location: "Showcase Frames > Ixalan Maps", image: "xlnMap.png"},
 | |
| 			{name: "Invocations (AKH)", location: "Showcase Frames > Amonkhet Invocations (u/Smyris)", image: "akhInvocation.png"},
 | |
| 			{name: "Expeditions (BFZ)", location: "Showcase Frames > BFZ Expeditions (2015)", image: "bfzExpedition.png"},
 | |
| 			{name: "Future Shifted (FUT)", location: "Showcase Frames > Future Shifted", image: "futFutureshifted.png"},
 | |
| 			{name: "Brawl Legend Crowns", location: "Showcase Frames > Brawl Legend Crowns", image: "brawlCrown.png"},
 | |
| 		];
 | |
| 		//PROMO FRAMES
 | |
| 		const promoTemplates = [
 | |
| 			{name: "Regular Promo", location: "Promos (Tall Art) > Regular Frames", image: "promoRegular.png"},
 | |
| 			{name: "Borderless Promo", location: "Promos (Tall Art) > Borderless Frames", image: "promoBorderless.png"},
 | |
| 			{name: "Borderless Promo (Extra Short)", location: "Promos (Tall Art) > Borderless Frames (Extra Short)", image: "promoBorderlessShort.png"},
 | |
| 			{name: "Extended Art Promo", location: "Promos (Tall Art) > Extended Art Frames", image: "promoExtended.png"},
 | |
| 			{name: "Nickname Promo", location: "Promos (Tall Art) > Nickname Frames", image: "promoNickname.png"},
 | |
| 			{name: "Generic Showcase Promo", location: "Promos (Tall Art) > Generic Showcase", image: "promoGenericShowcase.png"},
 | |
| 		];
 | |
| 		//TEXTLESS FRAMES
 | |
| 		const textlessTemplates = [
 | |
| 			{name: "Kamigawa Basics", location: "Textless/Fullart > Kamigawa Basics", image: "basicNEO.png"},
 | |
| 			{name: "Fullart Basics (THB)", location: "Textless/Fullart > Fullart Basics (THB)", image: "basicTHB.png"},
 | |
| 			{name: "Fullart Basics (ZEN)", location: "Textless/Fullart > Fullart Basics (ZEN)", image: "basicZEN.png"},
 | |
| 			{name: "Fullart Snow Basics", location: "Textless/Fullart > Fullart Snow Basics", image: "basicSnow.png"},
 | |
| 			{name: "Unstable Basics (UST)", location: "Textless/Fullart > Unstable Basics (UST)", image: "basicUST.png"},
 | |
| 			{name: "Unhinged Basics (UNH)", location: "Textless/Fullart > Unhinged Basics (UNH)", image: "basicUNH.png"},
 | |
| 			{name: "Textless Generic Showcase", location: "Textless/Fullart > Generic Showcase", image: "textlessGenericShowcase.png"},
 | |
| 			{name: "Magic Fest Promos", location: "Textless/Fullart > Regular", image: "magicFest.png"},
 | |
| 		];
 | |
| 		//CUSTOM FRAMES
 | |
| 		const customTemplates = [
 | |
| 			{name: "Deck Covers", location: "Custom > Deck Covers", image: "deckCover.png"},
 | |
| 			{name: "Simple Invention", location: "Custom > Simple Inventiosn", image: "inventionSimple.png"},
 | |
| 			{name: "Tapped (Horizontal M15)", location: "Custom > Tapped (Horizontal M15)", image: "tapped.png"},
 | |
| 			{name: "Textless Duals", location: "Custom > Textless Duals", image: "textlessDual.png"},
 | |
| 			{name: "Seventh Edition Planeswalkers", location: "Custom > Seventh Edition Planeswalkers", image: "seventhPlaneswalker.png"},
 | |
| 			{name: "Textless Seventh Edition", location: "Custom > Textless Seventh Edition", image: "seventhTextless.png"},
 | |
| 			{name: "Floating Old Border", location: "Custom > Floating Old Border", image: "floatingOldBorder.png"},
 | |
| 			{name: "Floating Old Border (Short)", location: "Custom > Floating Old Border (Short)", image: "floatingOldBorderShort.png"},
 | |
| 			{name: "Classicshifted", location: "Custom > Classicshifted", image: "classicshifted.png"},
 | |
| 			{name: "Classichshifted Lands", location: "Custom > Classichshifted Lands", image: "classicshiftedLand.png"},
 | |
| 			{name: "Classichshifted Planeswalkers", location: "Custom > Classichshifted Planeswalkers", image: "classicshiftedPlaneswalker.png"},
 | |
| 			{name: "Classichshifted Sagas", location: "Custom > Classichshifted Sagas", image: "classicshiftedSaga.png"},
 | |
| 			{name: "Colored Golden Age (SNC)", location: "Custom > Colored Golden Age (SNC)", image: "gildedColored.png"},
 | |
| 			{name: "Textless Golden Age (SNC)", location: "Custom > Textless Golden Age (SNC)", image: "gildedTextless.png"},
 | |
| 			{name: "Textless Equinox (MID)", location: "Custom > Textless Equinox (MID)", image: "equinoxTextless.png"},
 | |
| 			{name: "Horizontal Japanese Mystical Archive (STA)", location: "Showcase Frames > Horizontal Japanese Mystical Archive (STA)", image: "staMysticalArchiveJPHorizontal.png"},
 | |
| 			{name: "Textless Inventions (KLD)", location: "Custom > Textless Inventions (KLD)", image: "inventionTextless.png"},
 | |
| 			{name: "Cartoony - Sheepwave", location: "Custom > Cartoony - Sheepwave", image: "sheepwaveCartoony.png"},
 | |
| 			{name: "Neon - Elry", location: "Custom > Neon - Elry", image: "elryNeon.png"},
 | |
| 			{name: "Ixalan - @feuer_ameise", location: "Custom > Ixalan - @feuer_ameise", image: "feuerIxalan.png"},
 | |
| 			{name: "Kaldheim, Fullart - @feuer_ameise", location: "Custom > Kaldheim, Fullart - @feuer_ameise", image: "feuerKaldheim.png"},
 | |
| 			{name: "Celid's Asap", location: "Custom > Celid's Asap", image: "celidAsap.png"},
 | |
| 			{name: "Magrao's Kaldheim", location: "Custom > Magrao's Kaldheim", image: "magraoKaldheim.png"},
 | |
| 		];
 | |
| 		//functions
 | |
| 		getURL = (imageName) => {
 | |
| 			return "https://raw.githubusercontent.com/ImKyle4815/cardconjurer/master/gallery/img/" + imageName;
 | |
| 		}
 | |
| 		templateSample = (name, location, image) => {
 | |
| 			const shell = document.createElement("div");
 | |
| 			shell.classList.add("galleryGridItem");
 | |
| 			shell.classList.add("readable-background");
 | |
| 			const img = document.createElement("img");
 | |
| 			img.src = getURL("loading.jpg");
 | |
| 			shell.appendChild(img);
 | |
| 			const actualImage = new Image();
 | |
| 			actualImage.onload = () => {
 | |
| 				img.src = getURL(image);
 | |
| 			}
 | |
| 			actualImage.src = getURL(image);
 | |
| 			const title = document.createElement("h4");
 | |
| 			title.innerHTML = name;
 | |
| 			shell.appendChild(title);
 | |
| 			const loc = document.createElement("p");
 | |
| 			loc.innerHTML = location;
 | |
| 			shell.appendChild(loc);
 | |
| 			return shell;
 | |
| 		}
 | |
| 		populateGroup = (elementID, templates) => {
 | |
| 			const elem = document.getElementById(elementID);
 | |
| 			for (t of templates) {
 | |
| 				elem.appendChild(templateSample(t.name, t.location, t.image));
 | |
| 			}
 | |
| 		}
 | |
| 		//Populate everything
 | |
| 		populateGroup("showcaseGrid", showcaseTemplates);
 | |
| 		populateGroup("promoGrid", promoTemplates);
 | |
| 		populateGroup("textlessGrid", textlessTemplates);
 | |
| 		populateGroup("customGrid", customTemplates);
 | |
| 		populateGroup("regularGrid", regularTemplates);
 | |
| 		populateGroup("tokenGrid", tokenTemplates);
 | |
| 		// populateGroup("otherGrid", otherTemplates);
 | |
| 	</script>
 | |
| <!-- END OF CONTENT --> |