mirror of
				https://github.com/Investigamer/cardconjurer.git
				synced 2025-10-25 20:30:34 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			778 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			778 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html5>
 | |
| <html>
 | |
| <head>
 | |
| 	<title>Card Conjurer</title>
 | |
| 	<!-- Favicon craziness! -->
 | |
| 	<link rel="apple-touch-icon" sizes="180x180" href="favicons/apple-touch-icon.png">
 | |
| 	<link rel="icon" type="image/png" sizes="32x32" href="favicons/favicon-32x32.png">
 | |
| 	<link rel="icon" type="image/png" sizes="16x16" href="favicons/favicon-16x16.png">
 | |
| 	<link rel="manifest" href="favicons/site.webmanifest">
 | |
| 	<link rel="mask-icon" href="favicons/safari-pinned-tab.svg" color="#64ca2f">
 | |
| 	<link rel="shortcut icon" type="image/x-icon" href="favicons/favicon.ico">
 | |
| 	<meta name="msapplication-TileColor" content="#00a300">
 | |
| 	<meta name="msapplication-config" content="favicons/browserconfig.xml">
 | |
| 	<meta name="theme-color" content="#64ca2f">
 | |
| 	<!-- Other things -->
 | |
| 	<meta charset="UTF-8">
 | |
| 	<meta id="pageViewport" name="viewport" content="user-scalable=no,width=800">
 | |
| 	<PageMap>
 | |
|     	<DataObject type="thumbnail">
 | |
|       		<Attribute name="src" value="https://imkyle4815.github.io/cardconjurer/sampleCards/sample-card-6.png"/>
 | |
|       		<Attribute name="width" value="86"/>
 | |
|       		<Attribute name="height" value="120"/>
 | |
|    		</DataObject>
 | |
|   	</PageMap>
 | |
| 	<meta name="thumbnail" content="https://imkyle4815.github.io/cardconjurer/sampleCards/sample-card-6.png">
 | |
| 	<script>
 | |
| 		window.onload = function() {
 | |
| 		    if (screen.width > 800) {
 | |
| 		        var myViewPort = document.getElementById("pageViewport");
 | |
| 		        myViewPort.setAttribute("content", "width=device-width, initial-scale=1");
 | |
| 		    }
 | |
| 		}
 | |
| 	</script>
 | |
| 	<!-- Here is the stuff that does things? -->
 | |
| 	<script type='application/ld+json'>
 | |
| 	{
 | |
| 		"@context": "http://schema.org/",
 | |
| 		"@type": "WebPage",
 | |
| 		"creator": "Kyle Burton",
 | |
| 		"dateCreated": "July 2018",
 | |
| 		"inLanguage": {
 | |
| 			"@type": "Language",
 | |
| 			"name": "English"
 | |
| 		},
 | |
| 		"keywords": [
 | |
| 			"MTG",
 | |
| 			"Magic",
 | |
| 			"card",
 | |
| 			"custom",
 | |
| 			"creator"
 | |
| 		],
 | |
| 		"typicalAgeRange": "All ages",
 | |
| 		"description": "Card Conjurer: A free online tool that creates custom Magic: The Gathering Cards. Fast, easy, and offers a wide variety of card frames and other customizations. Planar cards, Ixalan maps, Planeswalkers, and more!",
 | |
| 		"image": "https://imkyle4815.github.io/cardconjurer/sampleCards/sample-card-6.png",
 | |
| 		"mainEntityOfPage": "https://imkyle4815.github.io/cardconjurer/",
 | |
| 		"name": "Card Conjurer"
 | |
| 	}
 | |
| 	</script>
 | |
| </head>
 | |
| <body>
 | |
| 	<div class="title"><img src="images/title.png"></div>
 | |
| 	<div class="grid mainGrid">
 | |
| 		<div class="canvasContainer">
 | |
| 			<canvas id="cardCanvas"></canvas>
 | |
| 		</div>
 | |
| 		<div class="cmmArea">
 | |
| 			<div class="grid selectionGrid">
 | |
| 				<div onclick="toggleView('frame', 'cmm')">Frame</div>
 | |
| 				<div onclick="toggleView('text', 'cmm')">Text</div>
 | |
| 				<div onclick="toggleView('info', 'cmm')">Info</div>
 | |
| 				<div onclick="toggleView('art', 'cmm')">Art</div>
 | |
| 				<div onclick="toggleView('set', 'cmm')">Set Symbol</div>
 | |
| 				<div onclick="toggleView('watermark', 'cmm')">Watermark</div>
 | |
| 				<div onclick="toggleView('advanced', 'cmm')">Advanced</div>
 | |
| 				<div onclick="toggleView('download', 'cmm')">Download</div>
 | |
| 				<div onclick="toggleView('planeswalker', 'cmm')" style="font-size: 85%; display: none;" id="cmmPlaneswalker">Planeswalker</div>
 | |
| 				<!-- <div onclick="toggleView('color', 'cmm')">Color</div>
 | |
| 				<div onclick="toggleView('general', 'cmm')">General</div>
 | |
| 				<div onclick="toggleView('text', 'cmm')">Text</div>
 | |
| 				<div onclick="toggleView('art', 'cmm')">Art</div>
 | |
| 				<div onclick="toggleView('info', 'cmm')">Info</div>
 | |
| 				<div onclick="toggleView('set', 'cmm')">Set</div>
 | |
| 				<div onclick="toggleView('watermark', 'cmm')">Watermark</div>
 | |
| 				<div onclick="toggleView('advanced', 'cmm')">Advanced</div>
 | |
| 				<div onclick="toggleView('download', 'cmm')">Download</div>
 | |
| 				<div onclick="toggleView('vanguard', 'cmm')" style="display: none;" id="cmmVanguard">Vanguard</div>
 | |
| 				<div onclick="toggleView('planeswalker', 'cmm')" style="font-size: 85%; display: none;" id="cmmPlaneswalker">Planeswalker</div> -->
 | |
| 			</div>
 | |
| 			<div class="cardManipulationMenu">
 | |
| 				<div class="cmm shown" id="cmm-frame">
 | |
| 					Border
 | |
| 					<span class="dropdown">
 | |
| 						<select onchange="backToDefault(this.value)" id="inputCardVersion">
 | |
| 							<option value="m15">M15</option>
 | |
| 							<option value="planeswalker">Planeswalker (M15)</option>
 | |
| 							<option value="fullArtLandM15">Full Art Land (M15)</option>
 | |
| 							<option value="fullArtLandUnstable">Full Art Land (Unstable)</option>
 | |
| 						</select>
 | |
| 					</span>
 | |
| 					<br><br>
 | |
| 					Frame
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesFrame" onchange="imgFrame.load(this.value + 'frame.png')" id="inputFrameColor"></select>
 | |
| 					</span>
 | |
| 					<br>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxFrameRight" onchange="sectionFrameFunction()" class="changesFrame">
 | |
| 						<label for="inputCheckboxFrameRight"/>
 | |
| 						<div>Frame (right)</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesFrame" onchange="imgFrameRight.load(this.value + 'frame.png')"></select>
 | |
| 					</span>
 | |
| 					<br><br>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxTitleTypeBoxes" onchange="sectionFrameFunction()" class="changesTitleType">
 | |
| 						<label for="inputCheckboxTitleTypeBoxes"/>
 | |
| 						<div>Title and Type Boxes</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesTitleType" onchange="imgTitleTypeBoxes.load(this.value + 'frame.png')"></select>
 | |
| 					</span>
 | |
| 					<br>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxTitleTypeBoxesRight" onchange="sectionFrameFunction()" class="changesTitleType">
 | |
| 						<label for="inputCheckboxTitleTypeBoxesRight"/>
 | |
| 						<div>Title and Type Boxes (right)</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesTitleType" onchange="imgTitleTypeBoxesRight.load(this.value + 'frame.png')"></select>
 | |
| 					</span>
 | |
| 					<br><br>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxRulesBox" onchange="sectionFrameFunction()" class="changesRulesBox">
 | |
| 						<label for="inputCheckboxRulesBox"/>
 | |
| 						<div>Rules Box</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesRulesBox" onchange="imgRulesBox.load(this.value + 'frame.png')"></select>
 | |
| 					</span>
 | |
| 					<br>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxRulesBoxRight" onchange="sectionFrameFunction()" class="changesRulesBox">
 | |
| 						<label for="inputCheckboxRulesBoxRight"/>
 | |
| 						<div>Rules Box (right)</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesRulesBox" onchange="imgRulesBoxRight.load(this.value + 'frame.png')"></select>
 | |
| 					</span>
 | |
| 					<br><br>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxPinline" onchange="sectionFrameFunction()" class="changesPinline">
 | |
| 						<label for="inputCheckboxPinline"/>
 | |
| 						<div>Pinline</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesPinline" onchange="imgPinline.load(this.value + 'frame.png')"></select>
 | |
| 					</span>
 | |
| 					<br>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxPinlineRight" onchange="sectionFrameFunction()" class="changesPinline">
 | |
| 						<label for="inputCheckboxPinlineRight"/>
 | |
| 						<div>Pinline (right)</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor changesPinline" onchange="imgPinlineRight.load(this.value + 'frame.png')"></select>
 | |
| 					</span>
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-advanced">
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxLegendary" onchange="loadLegendaryImages()" />
 | |
| 						<label for="inputCheckboxLegendary" />
 | |
| 						<div>Legendary</div>
 | |
| 					</div>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxRareStamp" onchange="loadRareStampImages()" />
 | |
| 						<label for="inputCheckboxRareStamp" />
 | |
| 						<div>Rare Stamp</div>
 | |
| 					</div>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxNyx" onchange="loadNyxImages()" />
 | |
| 						<label for="inputCheckboxNyx" />
 | |
| 						<div>Nyx</div>
 | |
| 					</div>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxMiracle" onchange="loadMiracleImages()" />
 | |
| 						<label for="inputCheckboxMiracle" />
 | |
| 						<div>Miracle</div>
 | |
| 					</div>
 | |
| 					<br>
 | |
| 					Frame Opacity
 | |
| 					<input id="inputFrameOpacity" type="number" class="input" min="0" max="100" value="100" step="1" oninput="sectionFrameFunction()">
 | |
| 					<br>
 | |
| 					Title/Type Opacity
 | |
| 					<input id="inputTitleTypeOpacity" type="number" class="input" min="0" max="100" value="100" step="1" oninput="sectionFrameFunction()">
 | |
| 					<br>
 | |
| 					Rules Box Opacity
 | |
| 					<input id="inputRulesBoxOpacity" type="number" class="input" min="0" max="100" value="100" step="1" oninput="sectionFrameFunction()">
 | |
| 					<br>
 | |
| 					Pinline Opacity
 | |
| 					<input id="inputPinlineOpacity" type="number" class="input" min="0" max="100" value="100" step="1" oninput="sectionFrameFunction()">
 | |
| 					<br><br>
 | |
| 					Title Color <input type="color" id="inputTitleColor" value="#000000" class="fontColor" onchange="sectionTextFunction()"> Outline <input type="color" id="inputTitleOutlineColor" value="#000000" class="fontColor" onchange="sectionTextFunction()">
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxTitleOutline" onchange="sectionTextFunction()">
 | |
| 						<label for="inputCheckboxTitleOutline" />
 | |
| 						<div>Title Outline</div>
 | |
| 					</div>
 | |
| 					Type Color <input type="color" id="inputTypeColor" value="#000000" class="fontColor" onchange="sectionTextFunction()"> Outline <input type="color" id="inputTypeOutlineColor" value="#000000" class="fontColor" onchange="sectionTextFunction()">
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxTypeOutline" onchange="sectionTextFunction()">
 | |
| 						<label for="inputCheckboxTypeOutline" />
 | |
| 						<div>Type Outline</div>
 | |
| 					</div>
 | |
| 					Rules Color <input type="color" id="inputRulesColor" value="#000000" class="fontColor" onchange="sectionTextFunction()"> Outline <input type="color" id="inputRulesOutlineColor" value="#000000" class="fontColor" onchange="sectionTextFunction()">
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxRulesOutline" onchange="sectionTextFunction()">
 | |
| 						<label for="inputCheckboxRulesOutline" />
 | |
| 						<div>Rules Outline</div>
 | |
| 					</div>
 | |
| 					<input type="color" id="inputCreatureColor" value="#000000" onchange="sectionTextFunction()"> Power/Toughness Color
 | |
| 					<br><br>
 | |
| 					<input type="color" id="inputBorderColor" value="#000000" onchange="sectionFrameFunction()"> Border Color
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-text">
 | |
| 					Name
 | |
| 					<input id="inputName" type="text" class="input" value="" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Mana Cost
 | |
| 					<input id="inputCost" type="text" class="input" value="" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Type
 | |
| 					<input id="inputType" type="text" class="input" value="" oninput="sectionTextFunction()">
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxPowerToughness" onchange="sectionTextFunction()">
 | |
| 						<label for="inputCheckboxPowerToughness" />
 | |
| 						<div>Power/Toughness</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select class="selectColor" onchange="imgPowerToughness.load(this.value + 'pt.png')"></select>
 | |
| 					</span>
 | |
| 					<input id="inputPowerToughness" class="input" type="text" oninput="sectionTextFunction()">
 | |
| 					<br><br>
 | |
| 					Rules Text
 | |
| 					<br>
 | |
| 					<textarea id="inputText" class="input" rows="5" cols="40" style="width: 100%; resize: none; height: 200px" placeholder="Remember to include curly brackets ('{' and '}') around each code. To skip to the next line use {line}. See 'Mana Symbols' and 'Other Codes' (below) for more information." oninput="sectionTextFunction()"></textarea>
 | |
| 					<br>
 | |
| 					Rules Text Font Size
 | |
| 					<input id="inputTextSize" type="number" class="input" min="0" value="37" step="0.5" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Pixels Between Paragraphs
 | |
| 					<input id="inputTextShift" type="number" class="input" min="0" value="13" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Shift All Text Down
 | |
| 					<input id="inputTextDown" type="number" class="input" value="0" oninput="sectionTextFunction()">
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-info">
 | |
| 					Collector's Number
 | |
| 					<input id="inputInfoNumber" type="text" class="input" value="001/001" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Rarity
 | |
| 					<input id="inputInfoRarity" type="text" class="input" value="S" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Set Abbreviation
 | |
| 					<input id="inputInfoSet" type="text" class="input" value="MTG" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Language
 | |
| 					<input id="inputInfoLanguage" type="text" class="input" value="EN" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Artist Credit
 | |
| 					<input id="inputInfoArtist" type="text" class="input" value="" oninput="sectionTextFunction()">
 | |
| 					<br>
 | |
| 					Other Information
 | |
| 					<input id="inputInfoCopyright" type="text" class="input" value="Not a Real Card" oninput="sectionTextFunction()">
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-art">
 | |
| 					Upload an Image
 | |
| 					<input type="text" class="input" placeholder="Via URL" onchange="imageURL(this.value, imgCardArt, 'none')">
 | |
| 					<input id="inputCardArtName" onchange="inputCardArtName(this.value)" class="input" type="text" placeholder="Via Card Name"></input>
 | |
| 					<input type="file" name="inputCardArt" class="input" accept="image/*" onchange="loadImage(event, imgCardArt)" id="inputPicture" placeholder="Via File Upload">
 | |
| 					<br>
 | |
| 					Card Name Result:
 | |
| 					<input id="inputCardArtNameNumber" onchange="inputCardArtNameNumber(this.value)" class="input" type="number" value="1" min="1" max="3">
 | |
| 					<br>
 | |
| 					Image Zoom
 | |
| 					<input id="inputCardArtZoom" type="number" class="input" value="100" step="0.1" oninput="drawCard()">
 | |
| 					<br>
 | |
| 					Image X
 | |
| 					<input id="inputCardArtX" type="number" class="input" value="0" step="1" oninput="drawCard()">
 | |
| 					<br>
 | |
| 					Image Y
 | |
| 					<input id="inputCardArtY" type="number" class="input" value="0" step="1" oninput="drawCard()">
 | |
| 					<br>
 | |
| 					<!-- Image Rotation
 | |
| 					<input id="inputCardArtRotation" type="number" class="input" value="0" step="1" min="0" max="360" oninput="drawCard()"> -->
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-set">
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxSetSymbol" checked="true" onchange="sectionOtherFunction()" />
 | |
| 						<label for="inputCheckboxSetSymbol" />
 | |
| 						<div>Set Symbol</div>
 | |
| 					</div>
 | |
| 					Set Code
 | |
| 					<input id="inputSetSymbolCode" type="text" class="input" onchange='imageURL("http://gatherer.wizards.com/Handlers/Image.ashx?type=symbol&set=" + document.getElementById("inputSetSymbolCode").value.toUpperCase() + "&size=large&rarity=" + document.getElementById("inputSetSymbolRarity").value.toUpperCase(), imgSetSymbol, "needsCrop")' value="LRW">
 | |
| 					Rarity
 | |
| 					<input id="inputSetSymbolRarity" type="text" class="input" onchange='imageURL("http://gatherer.wizards.com/Handlers/Image.ashx?type=symbol&set=" + document.getElementById("inputSetSymbolCode").value.toUpperCase() + "&size=large&rarity=" + document.getElementById("inputSetSymbolRarity").value.toUpperCase(), imgSetSymbol, "needsCrop")' value="U">
 | |
| 					Or Upload an Image
 | |
| 					<input type="text" class="input" placeholder="Via URL" onchange="imageURL(this.value, imgSetSymbol, 'needsCrop')">
 | |
| 					<input type="file" name="inputCardArt" class="input" accept="image/*" onchange="loadImage(event, imgSetSymbol)" id="inputPicture" placeholder="Via File Upload">
 | |
| 					<br>
 | |
| 					Scale Set Symbol
 | |
| 					<input id="inputSetSymbolScale" type="number" class="input" min="0" value="100" step="0.1" oninput="sectionOtherFunction()">
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-watermark">
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxWatermark" checked="true" onchange="sectionOtherFunction()" />
 | |
| 						<label for="inputCheckboxWatermark" />
 | |
| 						<div>Watermark</div>
 | |
| 					</div>
 | |
| 					Watermark Opacity
 | |
| 					<input id="inputWatermarkOpacity" type="number" class="input" min="0" max="100" value="40" step="1" oninput="sectionOtherFunction()">
 | |
| 					<br>
 | |
| 					Set Code
 | |
| 					<input id="inputWatermarkCode" type="text" class="input" onchange='imageURL("http://gatherer.wizards.com/Handlers/Image.ashx?type=symbol&set=" + this.value.toUpperCase() + "&size=large&rarity=C", imgWatermark, "needsBoth")'>
 | |
| 					Or Upload an Image
 | |
| 					<input type="text" class="input" placeholder="Via URL" onchange="imageURL(this.value, imgWatermark, 'needsBoth')">
 | |
| 					<input type="file" name="inputCardArt" class="input" accept="image/*" onchange="loadImage(event, imgWatermark)" id="inputPicture" placeholder="Via File Upload">
 | |
| 					<br>
 | |
| 					Watermark Color
 | |
| 					<span class="dropdown">
 | |
| 						<select onchange="sectionOtherFunction()" id="inputWatermarkColor">
 | |
| 							<option value="none">default</option>
 | |
| 							<option value="#afa360">White</option>
 | |
| 							<option value="#04527c">Blue</option>
 | |
| 							<option value="#494949">Black</option>
 | |
| 							<option value="#a3280d">Red</option>
 | |
| 							<option value="#0f4f14">Green</option>
 | |
| 							<option value="#7f5f00">Gold</option>
 | |
| 							<option value="#616b72">Artifact/Colorless</option>
 | |
| 						</select>
 | |
| 					</span>
 | |
| 					<div class="checkbox">
 | |
| 						<input type="checkbox" id="inputCheckboxSecondWatermark" onchange="sectionOtherFunction()" />
 | |
| 						<label for="inputCheckboxSecondWatermark" />
 | |
| 						<div>Second WatermarkColor</div>
 | |
| 					</div>
 | |
| 					<span class="dropdown">
 | |
| 						<select onchange="sectionOtherFunction()" id="inputSecondWatermarkColor">
 | |
| 							<option value="none">default</option>
 | |
| 							<option value="#afa360">White</option>
 | |
| 							<option value="#04527c">Blue</option>
 | |
| 							<option value="#494949">Black</option>
 | |
| 							<option value="#a3280d">Red</option>
 | |
| 							<option value="#0f4f14">Green</option>
 | |
| 							<option value="#7f5f00">Gold</option>
 | |
| 							<option value="#616b72">Artifact/Colorless</option>
 | |
| 						</select>
 | |
| 					</span>
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-download">
 | |
| 					<a onclick="downloadCardImage(this)" id="downloadCardImage" href="" target="_blank" download="card.png">Download</a><br>
 | |
| 				</div>
 | |
| 				<div class="cmm" id="cmm-planeswalker">
 | |
| 					Planeswalker Ability Line Height
 | |
| 					<input type="number" id="inputAbilityLine1" value="102" min="0" oninput="planeswalkerAbilityLines()">
 | |
| 					<input type="number" id="inputAbilityLine2" value="96" min="0" oninput="planeswalkerAbilityLines()">
 | |
| 					<input type="number" id="inputAbilityLine3" value="80" min="0" oninput="planeswalkerAbilityLines()">
 | |
| 					<input type="number" id="inputAbilityLine4" value="0" min="0" oninput="planeswalkerAbilityLines()">
 | |
| 					Planeswalker Ability Values
 | |
| 					<input type="text" id="inputAbilityValue0" value="+1" oninput="planeswalkerAbilityIcons()">
 | |
| 					<input type="text" id="inputAbilityValue1" value="0" oninput="planeswalkerAbilityIcons()">
 | |
| 					<input type="text" id="inputAbilityValue2" value="-1" oninput="planeswalkerAbilityIcons()">
 | |
| 					<input type="text" id="inputAbilityValue3" value="" oninput="planeswalkerAbilityIcons()">
 | |
| 				</div>
 | |
| 			</div>
 | |
| 		</div>
 | |
| 		<div class="tutorialArea">
 | |
| 			<div class="grid selectionGrid">
 | |
| 				<div onclick="toggleView('about', 'extras')">About</div>
 | |
| 				<div onclick="toggleView('tutorial', 'extras')">Tutorial</div>
 | |
| 				<div onclick="toggleView('symbolList', 'extras')">Mana Symbols</div>
 | |
| 				<div onclick="toggleView('codes', 'extras')">Other Codes</div>
 | |
| 				<div onclick="toggleView('set', 'extras')">Set Codes</div>
 | |
| 			</div>
 | |
| 			<div class="extrasMenu">
 | |
| 				<div class="extras shown" id="extras-about">
 | |
| 					<div class="text">
 | |
| 						Welcome to Card Conjurer! 
 | |
| 					</div>
 | |
| 					<div class="paragraph">
 | |
| 						Card Conjurer is a program that creates custom Magic: The Gathering cards. There are already plenty of Magic card makers, but what sets Card Conjurer apart from the rest is its live-edit capabilities. Users can immediately see the effects of any change they make, which makes card customization easier and more enjoyable. Additionally, Card Conjurer offers more borders than any other website, including flip cards, planar cards, Ixalan maps, and so much more.
 | |
| 					</div>
 | |
| 					<br>
 | |
| 					<div class="text">
 | |
| 						About Me
 | |
| 					</div>
 | |
| 					<div class="paragraph">
 | |
| 						My name is Kyle Burton and I am currently a high school student. I used to play Pokemon, but when a friend introduced me to Magic in 2013 I sold my pocket monsters and bought an M14 Intro Pack. Ever since that day Magic has been my all time favorite game. In addition to playing games, I've always <a href="https://www.youtube.com/watch?v=ERCzN91JicA" target="blank">loved technology.</a> During the 2017-18 school year I tought myself how to code Javascript, and a little bit of HTML and CSS. The following summer I created Kyle's Card Imager. (<a href="https://scryfall.com/card/5dn/134/krark-clan-ironworks" target="blank">KCI</a>) It was pretty simple but I soon began to add more border images like Miracle or Nyx. After a few months I decided to share my creation, so I renamed it Card Conjurer and uploaded it to Github.
 | |
| 					</div>
 | |
| 					<br>
 | |
| 					<div class="text">
 | |
| 						Donate?
 | |
| 					</div>
 | |
| 					<div class="paragraph">
 | |
| 						I hope that you found Card Conjurer useful! If you did, you can help me out tremendously by making a small donation or using a referral link... Or you can check out my friend's youtube channel: Izzet Right?
 | |
| 					</div><br>
 | |
| 					<div class="grid donateGrid selectionGrid">
 | |
| 						<div onclick="window.open('https://www.paypal.me/kyleburtondonate', '_blank');" style="color:rgb(0,37,134);">PayPal<img src="images/paypal.png"></img></div>
 | |
| 						<!-- <div onclick="window.open('https://www.patreon.com/KyleBurton', '_blank');" style="color:rgb(255,89,0);">Patreon<img src="images/patreon.png"></img></div> -->
 | |
| 						<div onclick="window.open('https://pucatrade.com/invite/gift/186748', '_blank');" style="color:rgb(61,33,58);">PucaTrade<img src="images/pucatrade.png"></img></div>
 | |
| 						<div onclick="window.open('https://twitter.com/ImKyle4815', '_blank');" style="color:rgb(0,174,239);">Twitter<img src="images/twitter.png"></img></div>
 | |
| 						<div onclick="window.open('https://www.massdrop.com/?referer=LNWNLL', '_blank');" style="color:rgb(255,255,255);">Massdrop<img src="images/massdrop.png"></img></div>
 | |
| 						<div onclick="window.open('https://www.youtube.com/channel/UC95Pd8lc8UWEkI96Nq_THvw', '_blank');" style="color:rgb(255,0,0);">Izzet Right?<img src="images/izzetright.png"></img></div>
 | |
| 					</div>
 | |
| 				</div>
 | |
| 				<div class="extras" id="extras-symbolList">
 | |
| 					Each of the following codes must include '{' before each code and '}' after.
 | |
| 					<div class="symbolGrid grid" id="symbolList">
 | |
| 						
 | |
| 					</div>
 | |
| 				</div>
 | |
| 				<div class="extras" id="extras-codes">
 | |
| 					• {line} → Skips to the next line<br>
 | |
| 					• {bar} → Just like line, except adds the bar that usually seperates flavor text<br>
 | |
| 					• {lineNoSpace} → Just like line, except stays closer to the previous line<br>
 | |
| 					• {i} → Text is italicized<br>
 | |
| 					• {/i} → Text returns to normal<br>
 | |
| 					• {left} → Text aligns to the left<br>
 | |
| 					• {center} → Text aligns to the center<br>
 | |
| 					• {right} → Text aligns to the right<br>
 | |
| 					• {upX} → Shifts the following text X pixels up<br>
 | |
| 					• {downX} → Shifts the following text X pixels down<br>
 | |
| 					• {leftX} → Shifts the following text X pixels left<br>
 | |
| 					• {rightX} → Shifts the following text X pixels right<br>
 | |
| 				</div>
 | |
| 				<div class="extras" id="extras-set">
 | |
| 					Every set in Magic: The Gathering has an associated 2-3 letter code. For example, Homelands is HM and Innistrad is ISD. This program uses the codes from <a href="http://gatherer.wizards.com" target="_blank">The Gatherer</a>, the official Magic card database. A handy list of all sets and their codes can be found on <a href="https://en.wikipedia.org/wiki/List_of_Magic:_The_Gathering_sets" target="_blank">Wikipedia</a>.
 | |
| 				</div>
 | |
| 				<div class="extras" id="extras-tutorial">
 | |
| 					Card Conjurer has gone under some major changes since the making of this video, but it can still help to give a general idea of how to use the program:
 | |
| 					<br><br>
 | |
| 					<iframe src="https://www.youtube.com/embed/Uh9Qr35u49I" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen style="width: calc(100vw - 94px); height: calc((100vw - 94px) * 9/16)"></iframe>
 | |
| 				</div>
 | |
| 			</div>
 | |
| 		</div>
 | |
| 		<div class="sampleGrid grid text">
 | |
| 			Check out some samples<br>
 | |
| 			<div class="noBorder">
 | |
| 				<img id="sampleCardA" class="sampleCard"></img>
 | |
| 				<img id="sampleCardB" class="sampleCard"></img>
 | |
| 				<img id="sampleCardC" class="sampleCard"></img>
 | |
| 			</div>
 | |
| 		</div>
 | |
| 	</div>
 | |
| </body>
 | |
| <footer class="info"><a href="https://imkyle4815.github.io/cardconjurer/TermsOfUse.txt" target="_blank">Terms of Use</a> • <a href="https://imkyle4815.github.io/cardconjurer/Disclaimer.txt" target="_blank">Disclaimer</a> • <a href="https://github.com/ImKyle4815/CardConjurer" target="_blank">Github page</a> • <a href="https://mail.google.com/mail/u/0/?view=cm&fs=1&to=CardConjurerMTG@gmail.com&su=Card%20Conjurer&tf=1" target="_blank">Contact</a></footer>
 | |
| 
 | |
| <!--CSS-->
 | |
| <style>
 | |
| /*fonts*/
 | |
| @font-face {
 | |
| 	font-family: relaymedium;
 | |
| 	src: url("data/fonts/relay-medium.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: gothammedium;
 | |
| 	src: url("data/fonts/gotham-medium.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: belerenb;
 | |
| 	src: url("data/fonts/beleren-b.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: belerenbsc;
 | |
| 	src: url("data/fonts/beleren-bsc.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: matrix;
 | |
| 	src: url("data/fonts/matrix.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: matrixb;
 | |
| 	src: url("data/fonts/matrix-b.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: matrixbsc;
 | |
| 	src: url("data/fonts/matrix-bsc.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: mplantin;
 | |
| 	src: url("data/fonts/mplantin.ttf");
 | |
| }
 | |
| @font-face {
 | |
| 	font-family: mplantini;
 | |
| 	src: url("data/fonts/mplantin-i.ttf");
 | |
| }
 | |
| 
 | |
| /*Color Palette*/
 | |
| :root {
 | |
| 	/*Regular*/
 | |
| 	--color-hover-grid: #0b6b00;
 | |
| 	--color-border-selection-grid: #0f820040;
 | |
| 	--color-gray: #00000088;
 | |
| 	--color-border-main: #073c00;
 | |
| 	--color-input: #073c00;
 | |
| }
 | |
| 
 | |
| /*Page-wide styling*/
 | |
| * {
 | |
| 	font-family: belerenb;
 | |
| 	font-size: 6vw;
 | |
| 	user-select: none;
 | |
| 	color: #eee;
 | |
| 	-webkit-transition: 0.5s;
 | |
|   	transition: 0.5s;
 | |
| }
 | |
| html {
 | |
| 	background: url("images/background.png") no-repeat center center fixed;
 | |
|   	-webkit-background-size: cover;
 | |
|   	-moz-background-size: cover;
 | |
|  	-o-background-size: cover;
 | |
|  	background-size: cover;
 | |
| }
 | |
| body {
 | |
| 	margin: 0;
 | |
| }
 | |
| 
 | |
| /*Grid styling*/
 | |
| .grid {
 | |
| 	display: grid;
 | |
| 	grid-gap: 4px;
 | |
| }
 | |
| .mainGrid {
 | |
| 	grid-gap: 0px 0px;
 | |
| }
 | |
| .mainGrid > div, body, footer, .title {
 | |
| 	border: 3px solid var(--color-border-main);
 | |
| }
 | |
| .canvasContainer {
 | |
| 	text-align: center;
 | |
| 	background-color: none !important;
 | |
| 	width: calc(100% - 14px);
 | |
| }
 | |
| .selectionGrid {
 | |
| 	grid-template-columns: repeat(auto-fit, minmax(6em, 1fr));
 | |
| 	text-align: center;
 | |
| }
 | |
| .grid > div {
 | |
| 	padding: 4px;
 | |
| }
 | |
| .grid > div:not(.noBorder) {
 | |
| 	background: var(--color-gray);
 | |
| }
 | |
| 
 | |
| /*Card manipulation menu grid*/
 | |
| .selectionGrid > div {
 | |
| 	font-family: belerenbsc;
 | |
| 	cursor: pointer;
 | |
| 	border-radius: 36px;
 | |
| 	border: 4px solid var(--color-border-selection-grid);
 | |
| 	/*background-color: #0008 !important;*/
 | |
| }
 | |
| .selectionGrid > div:hover {
 | |
| 	border-color: var(--color-hover-grid);
 | |
| }
 | |
| .cardManipulationMenu, .extrasMenu {
 | |
| 	margin-top: 4px;
 | |
| 	padding: 24px;
 | |
| 	border-radius: 36px;
 | |
| 	border: 4px solid var(--color-border-selection-grid);
 | |
| 	background-color: var(--color-gray);
 | |
| }
 | |
| .cmm, .extras {
 | |
| 	display: none;
 | |
| }
 | |
| .shown {
 | |
| 	display: block;
 | |
| }
 | |
| .sampleCard {
 | |
| 	width: 100%;
 | |
| }
 | |
| 
 | |
| /*Inputs and more*/
 | |
| /*dropdown*/
 | |
| .dropdown {
 | |
| 	position: relative;
 | |
| 	display: inline-block;
 | |
| 	width: 100%;
 | |
| }
 | |
| .dropdown select {
 | |
| 	border-radius: 0.25em;
 | |
| 	padding-left: 0.25em;
 | |
| 	width: inherit;
 | |
| 	background-color: var(--color-input);
 | |
| 	border: none;
 | |
| 	cursor: pointer;
 | |
| 	-moz-appearance: none;
 | |
| 	-webkit-appearance:none;
 | |
| 	appearance: none;
 | |
| }
 | |
| .dropdown select option {
 | |
| 	/*nothing for now :)*/
 | |
| }
 | |
| .dropdown::after {
 | |
| 	content: "\25BC";
 | |
| 	font-size: 0.6em;
 | |
| 	position: absolute;
 | |
| 	pointer-events: none;
 | |
| 	right: 0.6em;
 | |
| 	top: 0.6em;
 | |
| }
 | |
| /*checkbox*/
 | |
| .checkbox {
 | |
| 	height: 1em;
 | |
| 	margin: 5px 0px;
 | |
| 	position: relative;
 | |
| }
 | |
| .checkbox label {
 | |
| 	display: inline-block;
 | |
| 	width: 1em;
 | |
| 	height: 1em;
 | |
| 	border-radius: 0.25em;
 | |
| 	position: absolute;
 | |
| 	top: 0px;
 | |
| 	left: 0px;
 | |
| 	background: var(--color-input);
 | |
| 	cursor: pointer;
 | |
| }
 | |
| .checkbox input:checked ~ label:after {
 | |
| 	display: block;
 | |
| }
 | |
| .checkbox label:after {
 | |
| 	content: "\2718";
 | |
|     position: absolute;
 | |
|     display: none;
 | |
|     left: 0.1em;
 | |
|     top: -0.25em;
 | |
| }
 | |
| .checkbox input {
 | |
| 	opacity: 0;
 | |
| }
 | |
| .checkbox div {
 | |
| 	white-space: pre;
 | |
| 	position: relative;
 | |
| 	top: -0.1em;
 | |
| 	left: 1.1em;
 | |
| }
 | |
| /*other inputs*/
 | |
| input[type="text"], input[type="number"], textarea, input[type="file"] {
 | |
| 	width: 100%;
 | |
| 	border: none;
 | |
| 	background: var(--color-input);
 | |
| 	border-radius: 0.25em;
 | |
| 	padding-left: 0.25em;
 | |
| }
 | |
| /*color selector*/
 | |
| input[type="color"] {
 | |
| 	padding: 0px;
 | |
| 	border: none;
 | |
| 	background: var(--color-input);
 | |
| }
 | |
| 
 | |
| /*Hyperlinks*/
 | |
| a:link, a:visited {
 | |
| 	color: #fff;
 | |
| }
 | |
| a:hover, a:active {
 | |
| 	color: #999;
 | |
| }
 | |
| 
 | |
| /*Desktop*/
 | |
| @media only screen and (min-width: 1130px) {
 | |
| 	.canvasContainer {
 | |
| 		width: auto;
 | |
| 	}
 | |
| 	.mainGrid:not(.plane) {
 | |
| 		grid-template-columns: calc(749px + 0.7em) auto;
 | |
| 	}
 | |
| 	.tutorialArea {
 | |
| 		grid-column: 1 / span 2;
 | |
| 	}
 | |
| 	.sampleGrid {
 | |
| 		grid-column: 1 / span 2;
 | |
| 	}
 | |
| 	.mainGrid.plane > .cmmArea {
 | |
| 		grid-column: 1 / span 2;
 | |
| 	}
 | |
| 	.mainGrid.plane > .canvasContainer {
 | |
| 		grid-column: 1 / span 2;
 | |
| 	}
 | |
| }
 | |
| @media only screen and (min-width: 1455px) {
 | |
| 	.mainGrid.plane {
 | |
| 		grid-template-columns: calc(1074px + 0.7em) auto;
 | |
| 	}
 | |
| }
 | |
| @media only screen and (orientation: landscape) {
 | |
| 	.sampleCard {
 | |
| 		width: 32.8%;
 | |
| 	}
 | |
| }
 | |
| @media only screen and (min-width: 801px) {
 | |
| 	html {
 | |
| 		/*background*/
 | |
| 	}
 | |
| 	* {
 | |
| 		font-size: 24px;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| /*Text and stuff :)*/
 | |
| .info > * {
 | |
| 	font-size: inherit;
 | |
| }
 | |
| .info {
 | |
| 	font-size: 0.75em;
 | |
| }
 | |
| 
 | |
| /*Title*/
 | |
| .title > img {
 | |
| 	max-height: 80px;
 | |
| 	width: auto;
 | |
| }
 | |
| .title, .info {
 | |
| 	text-align: center;
 | |
| 	background-color: black;
 | |
| 	padding: 10px;
 | |
| }
 | |
| 
 | |
| /*symbol grid*/
 | |
| .manaSymbol > img {
 | |
| 	position: relative;
 | |
| 	height: 1em;
 | |
| }
 | |
| .symbolGrid {
 | |
| 	margin-top: 8px;
 | |
| 	grid-template-columns: repeat(auto-fit, minmax(3.5em, 1fr));
 | |
| 	text-align: center;
 | |
| }
 | |
| .symbolGrid > div {
 | |
| 	border: 4px solid var(--color-border-main);
 | |
| 	border-radius: 36px;
 | |
| 	background-color: var(--color-border-selection-grid) !important;
 | |
| }
 | |
| 
 | |
| /*Sitewide text (bottom of the page)*/
 | |
| .text {
 | |
| 	text-align: center;
 | |
| }
 | |
| .paragraph {
 | |
| 	text-indent: 2em;
 | |
| }
 | |
| /*Donation buttons!*/
 | |
| .donateGrid {
 | |
| 	grid-template-columns: repeat(auto-fit, minmax(13em, 1fr));
 | |
| }
 | |
| .donateGrid.grid > div {
 | |
| 	font-size: 1.7em;
 | |
| 	padding: 0px;
 | |
| }
 | |
| .donateGrid > div > img {
 | |
| 	position: relative;
 | |
| 	top: 0.25em;
 | |
| 	left: 0.5em;
 | |
| 	height: 1.7em;
 | |
| }
 | |
| 
 | |
| </style>
 | |
| <script src="data/main.js"></script>
 | |
| <html>
 | |
| <!--
 | |
| References 
 | |
| 
 | |
| <div class="cmm" id="cmm-targetId">
 | |
| 	...
 | |
| </div>
 | |
| 
 | |
| --> | 
