mirror of
				https://github.com/Investigamer/cardconjurer.git
				synced 2025-10-25 20:30:34 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			78 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| $title = 'Print Page Setup';
 | |
| $desc = 'Upload card images and download a fully prepared page for printing';
 | |
| include('../globalHTML/header-1.php');
 | |
| ?>
 | |
|     <h2 class='readable-background header-extension title center margin-bottom-large'>Printing Tool</h2>
 | |
|     <div class='readable-background padding layer margin-bottom-large'>
 | |
| 		<h4 class='collapsible collapsed center padding margin-bottom' onclick='toggleCollapse(event);'>Configure Page Settings</h4>
 | |
|         <div>
 | |
|     		<h5 class='margin-bottom padding input-description'>Select your paper size</h5>
 | |
|     		<select onchange='setPageSize(this.value.split(","));' class='input margin-bottom'>
 | |
|     			<option value='8.5,11'>Letter (8.5 by 11)</option>
 | |
|     			<option value='8.2667,11.6934'>A4</option>
 | |
|     		</select>
 | |
|             <h5 class='margin-bottom padding input-description'>Toggle the paper orientation (Portrait / Landscape)</h5>
 | |
|             <button onclick='changeOrientation();' class='input margin-bottom'>Toggle orientation</button>
 | |
|             <h5 class='margin-bottom padding input-description'>Select a default card size</h5>
 | |
|             <select onchange='setCardSize(this.value.split(","));' class='input margin-bottom'>
 | |
|                 <option value='2.5,3.5'>2.5 x 3.5 Inches</option>
 | |
|                 <option value='2.48031,3.46457'>63 x 88 mm</option>
 | |
|             </select>
 | |
|             <h5 class='margin-bottom padding input-description'>Or enter your own card size</h5>
 | |
|             <div class='margin-bottom split-grid'>
 | |
|                 <input type='number' id='cardWidth' class='input' value='1500' onchange='setCardSize();'>
 | |
|                 <input type='number' id='cardHeight' class='input' value='2100' onchange='setCardSize();'>
 | |
|             </div>
 | |
|             <h5 class='margin-bottom padding input-description'>Enter your bleed edge thickness (in pixels)</h5>
 | |
|             <input type='number' id='cardPadding' class='input margin-bottom' value='0' min='0' onchange='setPaddingSize(this.value);'>
 | |
|     		<h5 class='margin-bottom padding input-description'>Enter the distance between cards (in pixels)</h5>
 | |
|             <input type='number' id='cardMargin' class='input margin-bottom' value='30' min='0' onchange='setMarginSize(this.value);'>
 | |
|             <h5 class='margin-bottom padding input-description'>Set PPI (pixels per inch)</h5>
 | |
|             <input type='number' id='cardPPI' class='input margin-bottom' value='600' min='1' max='2400' onchange='setPPI(this.value);'>
 | |
|             <h5 class='margin-bottom padding input-description'>Include cutting aids (colored marks to help guide cuts; may not be visible in preview)</h5>
 | |
|             <label class='checkbox-container input margin-bottom'>Cutting aids
 | |
|                 <input id='cuttingAidsCheckbox' type='checkbox' onchange='setCuttingAids(this.checked);'>
 | |
|                 <span class='checkmark'></span>
 | |
|             </label>
 | |
|             <h5 class='margin-bottom padding input-description'>Images already include bleed edge</h5>
 | |
|             <label class='checkbox-container input margin-bottom'>Bleed edge included
 | |
|                 <input id='bleedEdgeCheckbox' type='checkbox' onchange='setBleedEdge(this.checked);' checked>
 | |
|                 <span class='checkmark'></span>
 | |
|             </label>
 | |
|             <h5 class='margin-bottom padding input-description'>Bleed Edge Color</h5>
 | |
|             <input id='bleedEdgeColor' type='color' class='input margin-bottom' onchange='setBleedEdgeColor(this.value);'>
 | |
|             <h5 class='margin-bottom padding input-description'>Save your current configurations as default</h5>
 | |
|             <button onclick='saveDefaults();' class='input margin-bottom'>Save configuration</button>
 | |
|         </div>
 | |
| 	</div>
 | |
|     <div class="layer margin-bottom-large">
 | |
|         <div class="drop-area" style="padding: 1rem">
 | |
|             <div class='padding margin-bottom-large readable-background'>
 | |
|                 <h5 class='margin-bottom padding input-description'>Upload the images that you'd like to print, or drag-and-drop them</h5>
 | |
|                 <input type='file' multiple accept='.png, .svg, .jpg, .jpeg, .bmp' placeholder='File Upload' class='input' oninput='uploadFiles(event.target.files, uploadCard, "filename");' data-dropFunction='uploadCard' data-otherParams='filename'>
 | |
|             </div>
 | |
|             <div class="center">
 | |
|                 <canvas style='height: auto; max-width:850px; width: 100%; background: #fff;'></canvas>
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
|     <div class='readable-background padding layer margin-bottom-large'>
 | |
| 		<h3 class='download padding' onclick='downloadCanvas();'>Download your Sheet (PNG)</h3>
 | |
| 		<h4 class='padding center'>(Can take a few seconds)</h4>
 | |
| 	</div>
 | |
| 	<div class='readable-background padding layer margin-bottom-large'>
 | |
| 		<h3 class='download padding' onclick='downloadPDF();'>Download your Sheet (PDF)</h3>
 | |
| 		<h4 class='padding center'>(WARNING: This can take around 15 seconds...)</h4>
 | |
| 	</div>
 | |
|     <div class="readable-background layer margin-bottom-large">
 | |
|         <h3 class='padding margin-bottom center'>
 | |
|             Want to see your custom cards on the kitchen table?
 | |
|         </h3>
 | |
|         <h4 class='padding'>
 | |
|         	Upload up to nine images, and they will automatically arrange themselves on an 8.5" by 11" sheet, so you can print them at home at up to 600PPI.
 | |
|         </h4>
 | |
|     </div>
 | |
| 	<script defer src='https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.5/jspdf.debug.js'></script>
 | |
|     <script defer src="/print/print.js"></script>
 | |
| <?php include('../globalHTML/footer.php'); ?>
 | 
