mirror of
				https://github.com/Investigamer/cardconjurer.git
				synced 2025-10-26 12:50:37 -05:00 
			
		
		
		
	frame search
This commit is contained in:
		| @@ -114,7 +114,7 @@ include('../globalHTML/header-1.php'); | |||||||
| 					<div id='creator-menu-frame'> | 					<div id='creator-menu-frame'> | ||||||
| 						<div class='readable-background margin-bottom padding'> | 						<div class='readable-background margin-bottom padding'> | ||||||
| 							<h5 class='margin-bottom padding input-description'> | 							<h5 class='margin-bottom padding input-description'> | ||||||
| 								Select a Frame Group and a Frame Pack, then you may Load the selected Frame Version (loading the frame version configures text placement, art size, etc...)</h5> | 								Select a Frame Group and a Frame Pack, or type to search. Then you may Load the selected Frame Version (loading the frame version configures text placement, art size, etc...)</h5> | ||||||
| 							<div class='input-grid margin-bottom'> | 							<div class='input-grid margin-bottom'> | ||||||
| 								<select id='selectFrameGroup' onchange='loadScript("/js/frames/group" + this.value + ".js")' class='input'> | 								<select id='selectFrameGroup' onchange='loadScript("/js/frames/group" + this.value + ".js")' class='input'> | ||||||
| 									<option disabled>Standard Frames</option> | 									<option disabled>Standard Frames</option> | ||||||
| @@ -136,6 +136,7 @@ include('../globalHTML/header-1.php'); | |||||||
| 									<option value='FleshAndBlood'>Flesh and Blood</option> | 									<option value='FleshAndBlood'>Flesh and Blood</option> | ||||||
| 								</select> | 								</select> | ||||||
| 								<select id='selectFramePack' onchange='loadScript("/js/frames/pack" + this.value + ".js")' class='input'></select> | 								<select id='selectFramePack' onchange='loadScript("/js/frames/pack" + this.value + ".js")' class='input'></select> | ||||||
|  | 								<div class="autocomplete"><input id='frameSearch' onchange="frameSearch(this.value)" type='text' class='input' placeholder='Search Frames...'></div> | ||||||
| 							</div> | 							</div> | ||||||
| 							<div class='input-grid margin-bottom'> | 							<div class='input-grid margin-bottom'> | ||||||
| 								<button id='loadFrameVersion' class='input'>Load Frame Version</button> | 								<button id='loadFrameVersion' class='input'>Load Frame Version</button> | ||||||
| @@ -741,4 +742,5 @@ include('../globalHTML/header-1.php'); | |||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
| 	<script defer src='/js/creator-23.js'></script> | 	<script defer src='/js/creator-23.js'></script> | ||||||
|  | 	<script defer src='/js/frameSearch.js'></script> | ||||||
| <?php include('../globalHTML/footer.php'); ?> | <?php include('../globalHTML/footer.php'); ?> | ||||||
|   | |||||||
| @@ -697,6 +697,33 @@ textarea.input { | |||||||
| 	grid-gap: 0.25rem; | 	grid-gap: 0.25rem; | ||||||
| 	user-select: none; | 	user-select: none; | ||||||
| } | } | ||||||
|  | /* Frame Search */ | ||||||
|  | .autocomplete { | ||||||
|  | 	position: relative; | ||||||
|  | } | ||||||
|  | .autocomplete-items { | ||||||
|  |   	position: absolute; | ||||||
|  |   	border: 1px solid black; | ||||||
|  |   	border-bottom: none; | ||||||
|  |   	top: 100%; | ||||||
|  |   	left: 0; | ||||||
|  |   	right: 0; | ||||||
|  |   	z-index: 99; | ||||||
|  |   	max-height: 8rem; | ||||||
|  |   	height: auto; | ||||||
|  |   	overflow-y: scroll; | ||||||
|  | } | ||||||
|  | .autocomplete-items div { | ||||||
|  |   	border-bottom: 1px solid black !important; | ||||||
|  |   	z-index: 99; | ||||||
|  | } | ||||||
|  | .autocomplete-items div:hover { | ||||||
|  | 	background-color: var(--input-background-selected); | ||||||
|  | } | ||||||
|  | .autocomplete-active { | ||||||
|  |   	background-color: var(--color-highlight) !important; | ||||||
|  |   	color: black; | ||||||
|  | } | ||||||
| /*Frame/Mask-Pickers*/ | /*Frame/Mask-Pickers*/ | ||||||
| .frame-picker, .mask-picker { | .frame-picker, .mask-picker { | ||||||
| 	display: grid; | 	display: grid; | ||||||
|   | |||||||
							
								
								
									
										247
									
								
								js/frameSearch.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										247
									
								
								js/frameSearch.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,247 @@ | |||||||
|  | const frameNames = new Map ([ | ||||||
|  | 	//standard | ||||||
|  | 	['Regular Frames', 'M15Regular-1'], | ||||||
|  | 	['Legend Crowns', 'M15LegendCrowns'], | ||||||
|  | 	['Floating Legend Crowns', 'M15LegendCrownsFloating'], | ||||||
|  | 	['Inner Crowns', 'M15InnerCrowns'], | ||||||
|  | 	['Miracle', 'M15Miracle'], | ||||||
|  | 	['Holo Stamps', 'M15HoloStamps'], | ||||||
|  | 	['Dark Power/Toughness', 'M15DarkPT'], | ||||||
|  | 	['Colored Borders', 'M15Borders'], | ||||||
|  | 	['Color Identity Pips', 'M15CIPips'], | ||||||
|  | 	['"The List" Stamp', 'TheList'], | ||||||
|  | 	['Lands', 'M15Lands'], | ||||||
|  | 	['Class (D&D)', 'Class'], | ||||||
|  | 	['Snow (Kaldheim)', 'M15Snow'], | ||||||
|  | 	['Mutate (Ikoria)', 'M15Mutate'], | ||||||
|  | 	['Nyx (Theros)', 'M15Nyx'], | ||||||
|  | 	['Adventures (Eldraine)', 'Adventure'], | ||||||
|  | 	['Devoid (Zendikar)', 'M15Devoid'], | ||||||
|  | 	['Aftermath (Amonkhet)', 'Aftermath'], | ||||||
|  | 	['Flip (Kamigawa)', 'Flip'], | ||||||
|  | 	['Levelers (Zendikar)', 'Levelers'], | ||||||
|  | 	['Split Cards', 'Split'], | ||||||
|  | 	['Fuse Cards', 'Fuse'], | ||||||
|  | 	['Conspiracies (Draft Matters)', 'Conspiracy'], | ||||||
|  | 	['Colorshifted (Planar Chaos)', 'Colorshifted'], | ||||||
|  | 	['Brawl Legend Crowns', 'Brawl'], | ||||||
|  | 	//planeswalker | ||||||
|  | 	['Planeswalker', 'PlaneswalkerRegular'], | ||||||
|  | 	['Planeswalker Borderless', 'PlaneswalkerBorderless'], | ||||||
|  | 	['Planeswalker Extended Art', 'PlaneswalkerBoxTopper'], | ||||||
|  | 	['Planeswalker Tall', 'PlaneswalkerTall'], | ||||||
|  | 	['Planeswalker Tall Borderless', 'PlaneswalkerTallBorderless'], | ||||||
|  | 	['Planeswalker Holo Stamps', 'PlaneswalkerHoloStamps'], | ||||||
|  | 	['Planeswalker Nickname', 'PlaneswalkerNickname'], | ||||||
|  | 	['Planeswalker Blackout (SDCC15)', 'PlaneswalkerSDCC15'], | ||||||
|  | 	['Planeswalker MDFC', 'PlaneswalkerMDFC'], | ||||||
|  | 	['Planeswalker Transform (Front)', 'PlaneswalkerTransformFront'], | ||||||
|  | 	['Planeswalker Transform (Back)', 'PlaneswalkerTransformBack'], | ||||||
|  | 	['Planeswalker Transform Icons', 'PlaneswalkerTransformIcons'], | ||||||
|  | 	//saga | ||||||
|  | 	['Sagas', 'SagaRegular'], | ||||||
|  | 	//dfc | ||||||
|  | 	['Transform (Front)', 'M15TransformFront'], | ||||||
|  | 	['Transform (Back)', 'M15TransformBack'], | ||||||
|  | 	['Color Identity Pips', 'M15CIPips'], | ||||||
|  | 	['Transform Icons', 'M15TransformTypes'], | ||||||
|  | 	['Sagas (Front)', 'SagaDFC'], | ||||||
|  | 	['Borderless (Front)', 'TransformBorderlessFront'], | ||||||
|  | 	['Borderless (Back)', 'TransformBorderlessBack'], | ||||||
|  | 	['Extended Art (Front)', 'TransformExtendedFront'], | ||||||
|  | 	['Extended Art (Back)', 'TransformExtendedBack'], | ||||||
|  | 	['SDCC15 (Blackout)', 'TransformSDCC15'], | ||||||
|  | 	['DFC Legend Crowns', 'TransformLegendCrowns'], | ||||||
|  | 	['DFC Floating Legend Crowns', 'TransformLegendCrownsFloating'], | ||||||
|  | 	//modal | ||||||
|  | 	['Modal DFC', 'ModalRegular'], | ||||||
|  | 	['Modal DFC Borderless', 'ModalBorderless'], | ||||||
|  | 	['Modal DFC Extended Art', 'ModalExtended'], | ||||||
|  | 	['Modal DFC Nickname', 'ModalNickname'], | ||||||
|  | 	['Modal DFC Short', 'ModalShort'], | ||||||
|  | 	['Modal DFC Short-Nickname', 'ModalShortNickname'], | ||||||
|  | 	['Modal DFC Legend Crowns', 'ModalLegendCrowns'], | ||||||
|  | 	['Modal DFC Floating Legend Crowns', 'ModalLegendCrownsFloating'], | ||||||
|  | 	['Modal DFC Nickname Legend Crowns', 'ModalLegendCrownsNickname'], | ||||||
|  | 	['Modal DFC Brawl Legend Crowns', 'ModalLegendCrownsBrawl'], | ||||||
|  | 	['DFC Helper Cards', 'ModalHelper'], | ||||||
|  | 	//token | ||||||
|  | 	['Regular Tokens', 'TokenRegular-1'], | ||||||
|  | 	['Textless Tokens', 'TokenTextless-1'], | ||||||
|  | 	['Tall Tokens', 'TokenTall-1'], | ||||||
|  | 	['Day/Night Marker', 'TokenDayNight'], | ||||||
|  | 	['Jumpstart Front Cards', 'JMPFront'], | ||||||
|  | 	['Planeswalker Emblems', 'Emblem'], | ||||||
|  | 	['Regular Tokens (Bordered M15)', 'TokenRegularM15'], | ||||||
|  | 	['Textless Tokens (Bordered M15)', 'TokenTextlessM15'], | ||||||
|  | 	['Original Tokens (Old Bordered)', 'TokenOld'], | ||||||
|  | 	['Unglued Tokens', 'TokenUnglued'], | ||||||
|  | 	//showcase | ||||||
|  | 	['Ninja (Neo)', 'NeoNinja'], | ||||||
|  | 	['Samurai (Neo)', 'NeoSamurai'], | ||||||
|  | 	['Neon (Neo)', 'NeoNeon'], | ||||||
|  | 	['Fang (VOW)', 'Fang'], | ||||||
|  | 	['Equinox (MID)', 'Equinox'], | ||||||
|  | 	['Eternal Night (MID)', 'EternalNight'], | ||||||
|  | 	['D&D Sourcebook (AFR)', 'DNDSourcebook'], | ||||||
|  | 	['D&D Module (AFR)', 'DNDModule'], | ||||||
|  | 	['Sketch Cards (MH2)', 'MH2'], | ||||||
|  | 	['Mystical Archive (STA)', 'MysticalArchive'], | ||||||
|  | 	['Japanese Mystical Archive (STA)', 'MysticalArchiveJP'], | ||||||
|  | 	['Praetors (KHM)', 'Praetors'], | ||||||
|  | 	['Kaldheim (KHM)', 'Kaldheim-2'], | ||||||
|  | 	['Nonlegendary Kaldheim (KHM)', 'KaldheimNonleg'], | ||||||
|  | 	['Commander Legends (CMR)', 'CommanderLegends'], | ||||||
|  | 	['Zendikar Rising (ZNR)', 'ZendikarRising'], | ||||||
|  | 	['M21 Signature Spellbooks (M21)', 'M21'], | ||||||
|  | 	['Theros Beyond Death (THB)', 'M15NyxShowcase'], | ||||||
|  | 	['Eldraine Storybooks (ELD)', 'Storybook'], | ||||||
|  | 	['Borderless', 'GenericShowcase'], | ||||||
|  | 	['Fullart', 'M15ClearTextboxes'], | ||||||
|  | 	['Nickname ("Godzilla")', 'M15Nickname'], | ||||||
|  | 	['Extended Art (Regular)', 'M15BoxTopper'], | ||||||
|  | 	['Extended Art (Shorter Textbox)', 'M15ExtendedArtShort'], | ||||||
|  | 	['FNM Promo (Inverted Promos)', 'FNM'], | ||||||
|  | 	['Universes Beyond', 'UB'], | ||||||
|  | 	['Full Text', 'FullText'], | ||||||
|  | 	['ZNR Expeditions (2020)', 'ExpeditionZNR-1'], | ||||||
|  | 	['Signature Spellbook (Jace/Gideon)', 'SignatureSpellbook'], | ||||||
|  | 	['Ixalan Maps', 'Ixalan'], | ||||||
|  | 	['Amonkhet Invocations (u/Smyris)', 'Invocation'], | ||||||
|  | 	['Kaladesh Inventions', 'Invention'], | ||||||
|  | 	['BFZ Expeditions (2015)', 'ExpeditionBFZ-1'], | ||||||
|  | 	['SDCC15 (Blackout)', 'SDCC15'], | ||||||
|  | 	['Future Shifted', 'FutureRegular'], | ||||||
|  | 	//misc | ||||||
|  | 	['Future Shifted', 'FutureRegular'], | ||||||
|  | 	['Colorshifted', '8thColorshifted'], | ||||||
|  | 	['8th Edition', '8th'], | ||||||
|  | 	['Seventh Edition', 'Seventh'], | ||||||
|  | 	['Fifth Edition', 'SeventhButFifth'], | ||||||
|  | 	['Fourth Edition', 'Fourth'], | ||||||
|  | 	['Legends Multicolored', 'Legends'], | ||||||
|  | 	['Alpha/Beta/Unlimited', 'ABU'], | ||||||
|  | 	['Playtest Cards', 'Playtest'], | ||||||
|  | 	['Dungeon (AFR)', 'Dungeon'], | ||||||
|  | 	['Planechase', 'Planechase'], | ||||||
|  | 	['Vanguard', 'Vanguard'], | ||||||
|  | 	['Cardback', 'Cardback'], | ||||||
|  | 	//promo | ||||||
|  | 	['Promos', 'PromoOpenHouse'], | ||||||
|  | 	['Promo Borderless Frames', 'PromoRegular-1'], | ||||||
|  | 	['Promo Borderless Frames (Extra Short)', 'IkoShort'], | ||||||
|  | 	['Promo Extended Art Frames', 'PromoExtended'], | ||||||
|  | 	['Promo Nickname Frames', 'PromoNickname'], | ||||||
|  | 	['Promo Generic Showcase', 'PromoGenericShowcase'], | ||||||
|  | 	//textless | ||||||
|  | 	['Kamigawa Basics (NEO)', 'NeoBasics'], | ||||||
|  | 	['Fullart Basics (THB)', 'TextlessBasics'], | ||||||
|  | 	['Fullart Basics (ZEN)', 'ZendikarBasic-1'], | ||||||
|  | 	['Fullart Snow Basics', 'FullartBasicRoundBottom'], | ||||||
|  | 	['Unstable Basics (UST)', 'Unstable'], | ||||||
|  | 	['Unhinged Basics (UNH)', 'Unhinged'], | ||||||
|  | 	['Generic Showcase', 'TextlessGenericShowcase'], | ||||||
|  | 	['Magic Fest Promos', 'MagicFest'], | ||||||
|  | 	['Textless Inventions', 'TextlessInvention'], | ||||||
|  | 	['Textless Seventh', 'SeventhTextless'], | ||||||
|  | 	//custom | ||||||
|  | 	['Misc Custom Frames', 'MiscCustom'], | ||||||
|  | 	['Deck Covers', 'CustomDeckCover'], | ||||||
|  | 	['Simple Inventions', 'SimpleInventions'], | ||||||
|  | 	['Tapped (Horizontal M15)', 'Tapped'], | ||||||
|  | 	['Textless Duals', 'CustomDualLands'], | ||||||
|  | 	['Seventh Edition Planeswalkers', 'PlaneswalkerSeventh'], | ||||||
|  | 	['Floating Old Border', 'OldFloating'], | ||||||
|  | 	['Floating Old Border (Short)', 'OldFloatingShort'], | ||||||
|  | 	['Classicshifted', 'Classicshifted'], | ||||||
|  | 	['Classicshifted Lands', 'ClassicshiftedLands'], | ||||||
|  | 	['Classicshifted Planeswalkers', 'ClassicshiftedPlaneswalker'], | ||||||
|  | 	['Classicshifted Sagas', 'ClassicshiftedSaga'], | ||||||
|  | 	['Classicshifted MDFC Addons', 'ClassicshiftedDFC'], | ||||||
|  | 	['Classicshifted Color Identity Pips', 'ClassicshiftedCIPips'], | ||||||
|  | 	['Textless Equinox (MID)', 'EquinoxTextless'], | ||||||
|  | 	['Horizontal Japanese Mystical Archive (STA)', 'MysticalArchiveJPHorizontal'], | ||||||
|  | 	['Brawl Legend Crowns', 'Brawl'], | ||||||
|  | 	['Cartoony - Sheepwave', 'Cartoony'], | ||||||
|  | 	['Neon - Elry', 'CustomNeon'], | ||||||
|  | 	['Ixalan - @feuer_ameise', 'FeuerAmeiseIxalan'], | ||||||
|  | 	['Kaldheim, Fullart - @feuer_ameise', 'FeuerAmeiseKaldheim'], | ||||||
|  | 	['Celid\'s Asap', 'CustomCelidAsap'], | ||||||
|  | ]); | ||||||
|  |  | ||||||
|  | frameSearch = (str) => { | ||||||
|  | 	if (frameNames.has(str)) loadScript("/js/frames/pack" + frameNames.get(str) + ".js"); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | //Thank you to w3schools for providing the following quick-and-easy autocomplete code :) | ||||||
|  | //(some modifications made) | ||||||
|  |  | ||||||
|  | autocomplete(document.getElementById("frameSearch"), Array.from(frameNames.keys())); | ||||||
|  |  | ||||||
|  | function autocomplete(inp, arr) { | ||||||
|  | 	var currentFocus; | ||||||
|  | 	inp.addEventListener("input", function(e) { | ||||||
|  | 		var a, b, i, val = this.value; | ||||||
|  | 		closeAllLists(); | ||||||
|  | 		if (!val) { return false;} | ||||||
|  | 		currentFocus = -1; | ||||||
|  | 		a = document.createElement("DIV"); | ||||||
|  | 		a.setAttribute("id", this.id + "autocomplete-list"); | ||||||
|  | 		a.setAttribute("class", "autocomplete-items"); | ||||||
|  | 		this.parentNode.appendChild(a); | ||||||
|  | 		for (i = 0; i < arr.length; i++) { | ||||||
|  | 			if (arr[i].toUpperCase().includes(val.toUpperCase())) { | ||||||
|  | 				b = document.createElement("DIV"); | ||||||
|  | 				b.setAttribute("class", "input") | ||||||
|  | 				b.innerHTML = arr[i]; | ||||||
|  | 				b.addEventListener("click", function(e) { | ||||||
|  | 					inp.value = this.innerHTML; | ||||||
|  | 					frameSearch(inp.value); | ||||||
|  |               		closeAllLists(); | ||||||
|  |           		}); | ||||||
|  | 				a.appendChild(b); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}); | ||||||
|  | 	inp.addEventListener("keydown", function(e) { | ||||||
|  | 		var x = document.getElementById(this.id + "autocomplete-list"); | ||||||
|  | 		if (x) x = x.getElementsByTagName("div"); | ||||||
|  | 		if (e.keyCode == 40) { | ||||||
|  |         	currentFocus++; | ||||||
|  |         	addActive(x); | ||||||
|  |       	} else if (e.keyCode == 38) { | ||||||
|  |         	currentFocus--; | ||||||
|  |         	addActive(x); | ||||||
|  |     	} else if (e.keyCode == 13) { | ||||||
|  |     		e.preventDefault(); | ||||||
|  |     		if (currentFocus > -1) { | ||||||
|  |     			if (x) x[currentFocus].click(); | ||||||
|  |     		} | ||||||
|  |     	} else if (e.keyCode == 27) { | ||||||
|  |     		closeAllLists(); | ||||||
|  |     	} | ||||||
|  | 	}); | ||||||
|  | 	function addActive(x) { | ||||||
|  | 		if (!x) return false; | ||||||
|  | 		removeActive(x); | ||||||
|  | 		if (currentFocus >= x.length) currentFocus = 0; | ||||||
|  | 		if (currentFocus < 0) currentFocus = (x.length - 1); | ||||||
|  | 		x[currentFocus].classList.add("autocomplete-active"); | ||||||
|  | 	} | ||||||
|  | 	function removeActive(x) { | ||||||
|  | 		for (var i = 0; i < x.length; i++) { | ||||||
|  | 			x[i].classList.remove("autocomplete-active"); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	function closeAllLists(elmnt) { | ||||||
|  |     	var x = document.getElementsByClassName("autocomplete-items"); | ||||||
|  |     	for (var i = 0; i < x.length; i++) { | ||||||
|  |     		if (elmnt != x[i] && elmnt != inp) { | ||||||
|  |     			x[i].parentNode.removeChild(x[i]); | ||||||
|  |     		} | ||||||
|  | 	    } | ||||||
|  | 	} | ||||||
|  | 	document.addEventListener("click", function (e) { | ||||||
|  | 		closeAllLists(e.target); | ||||||
|  | 	}); | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	 Kyle
					Kyle