| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  | {% extends "base.html" %} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {% block title %}Add Account - KTVManager{% endblock %} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {% block head_content %} | 
					
						
							| 
									
										
										
										
											2025-07-05 10:57:19 +01:00
										 |  |  |     <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/awesomplete/1.1.5/awesomplete.min.css" /> | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |     <style> | 
					
						
							|  |  |  |         /* Hide the spinner by default */ | 
					
						
							|  |  |  |         #loadingSpinner, | 
					
						
							|  |  |  |         #ocrLoadingSpinner { | 
					
						
							|  |  |  |             display: none; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     </style> | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  | {% endblock %} | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  | {% block sub_nav %} | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |     <!-- Sub-navigation for Accounts --> | 
					
						
							|  |  |  |     <div class="bg-light py-2"> | 
					
						
							|  |  |  |         <div class="container"> | 
					
						
							|  |  |  |             <ul class="nav nav-pills"> | 
					
						
							|  |  |  |                 <li class="nav-item"> | 
					
						
							|  |  |  |                     <a class="nav-link" href="/accounts">List Accounts</a> | 
					
						
							|  |  |  |                 </li> | 
					
						
							|  |  |  |                 <li class="nav-item"> | 
					
						
							|  |  |  |                     <a class="nav-link active" href="/accounts/add">Add Account</a> | 
					
						
							|  |  |  |                 </li> | 
					
						
							|  |  |  |             </ul> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  | {% endblock %} | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  | {% block content %} | 
					
						
							|  |  |  |     <h1>Add Account</h1> | 
					
						
							|  |  |  |     <div> | 
					
						
							|  |  |  |     <form action="/accounts/add" method="POST" onsubmit="showLoading()"> | 
					
						
							|  |  |  |         <div class="form-group"> | 
					
						
							|  |  |  |             <label for="username">Username</label> | 
					
						
							|  |  |  |             <input type="text" class="form-control" id="username" name="username" value="{{ username }}" required> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         <div class="form-group"> | 
					
						
							|  |  |  |             <label for="password">Password</label> | 
					
						
							|  |  |  |             <input type="text" class="form-control" id="password" name="password" value="{{ password }}"  required> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         <div class="form-group"> | 
					
						
							|  |  |  |             <label for="stream">Stream Name</label> | 
					
						
							|  |  |  |             <input type="text" class="form-control" id="stream" name="stream" required> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         <button type="submit" class="btn btn-primary" id="submitButton"> | 
					
						
							|  |  |  |             <span class="spinner-border spinner-border-sm" id="loadingSpinner" role="status" aria-hidden="true"></span> | 
					
						
							|  |  |  |             <span id="buttonText">Add Account</span> | 
					
						
							|  |  |  |         </button> | 
					
						
							|  |  |  |     </form> | 
					
						
							|  |  |  |     {% if ocr_enabled %} | 
					
						
							|  |  |  |     <hr> | 
					
						
							|  |  |  |     <h2>Load Details Via OCR</h2> | 
					
						
							|  |  |  |         <form action="/OCRupload" method="POST" enctype="multipart/form-data" onsubmit="showLoadingOCR()"> | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |             <div class="form-group"> | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  |                 <label for="image">Select Image</label> | 
					
						
							|  |  |  |                 <input type="file" class="form-control-file" id="image" name="image" accept="image/*" required> | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |             </div> | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  |             <button type="submit" class="btn btn-success" id="ocrButton"> | 
					
						
							|  |  |  |                 <span class="spinner-border spinner-border-sm" id="ocrLoadingSpinner" role="status" aria-hidden="true"></span> | 
					
						
							|  |  |  |                 <span id="ocrButtonText">Load Details</span> | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |             </button> | 
					
						
							|  |  |  |         </form> | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  |     {% endif %} | 
					
						
							|  |  |  |     {% if text_input_enabled %} | 
					
						
							|  |  |  |     <hr> | 
					
						
							|  |  |  |     <h2>Load Details Via Text</h2> | 
					
						
							|  |  |  |     <div class="form-group"> | 
					
						
							|  |  |  |         <label for="accountDetails">Paste Account Details</label> | 
					
						
							| 
									
										
										
										
											2025-07-17 11:21:22 +01:00
										 |  |  |         <textarea class="form-control" id="accountDetails" rows="4" data-shared-text="{{ shared_text }}"></textarea> | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  |     </div> | 
					
						
							|  |  |  |     {% endif %} | 
					
						
							|  |  |  | {% endblock %} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {% block scripts %} | 
					
						
							| 
									
										
										
										
											2025-07-05 10:57:19 +01:00
										 |  |  |     <script src="https://cdnjs.cloudflare.com/ajax/libs/awesomplete/1.1.5/awesomplete.min.js"></script> | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |     <script> | 
					
						
							|  |  |  |         function showLoading() { | 
					
						
							|  |  |  |             document.getElementById("submitButton").disabled = true; | 
					
						
							|  |  |  |             document.getElementById("loadingSpinner").style.display = "inline-block"; | 
					
						
							|  |  |  |             document.getElementById("buttonText").textContent = "Working..."; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         function showLoadingOCR() { | 
					
						
							|  |  |  |             document.getElementById("ocrButton").disabled = true; | 
					
						
							|  |  |  |             document.getElementById("ocrLoadingSpinner").style.display = "inline-block"; | 
					
						
							|  |  |  |             document.getElementById("ocrButtonText").textContent = "Processing..."; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-07-05 10:57:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         document.addEventListener("DOMContentLoaded", function() { | 
					
						
							|  |  |  |             var streamInput = document.getElementById("stream"); | 
					
						
							| 
									
										
										
										
											2025-07-14 11:45:08 +01:00
										 |  |  |             var awesomplete; | 
					
						
							| 
									
										
										
										
											2025-07-05 10:57:19 +01:00
										 |  |  |             fetch('/get_stream_names') | 
					
						
							|  |  |  |                 .then(response => response.json()) | 
					
						
							|  |  |  |                 .then(data => { | 
					
						
							| 
									
										
										
										
											2025-07-14 11:45:08 +01:00
										 |  |  |                     awesomplete = new Awesomplete(streamInput, { | 
					
						
							| 
									
										
										
										
											2025-07-13 16:00:52 +01:00
										 |  |  |                         list: data | 
					
						
							| 
									
										
										
										
											2025-07-09 10:39:12 +01:00
										 |  |  |                     }); | 
					
						
							| 
									
										
										
										
											2025-07-14 11:45:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-14 12:47:35 +01:00
										 |  |  |                     streamInput.addEventListener('awesomplete-selectcomplete', function(event) { | 
					
						
							|  |  |  |                         this.value = event.text.value; | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-14 11:45:08 +01:00
										 |  |  |                     const accountDetailsTextarea = document.getElementById('accountDetails'); | 
					
						
							|  |  |  |                     if (accountDetailsTextarea) { | 
					
						
							|  |  |  |                         accountDetailsTextarea.addEventListener('input', function() { | 
					
						
							|  |  |  |                             const text = this.value; | 
					
						
							|  |  |  |                             const lines = text.split('\n'); | 
					
						
							|  |  |  |                              | 
					
						
							|  |  |  |                             const streamName = lines[0] ? lines[0].trim() : ''; | 
					
						
							|  |  |  |                             const usernameLine = lines.find(line => line.toUpperCase().startsWith('USER:')); | 
					
						
							|  |  |  |                             const passwordLine = lines.find(line => line.toUpperCase().startsWith('PASS:')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                             if (usernameLine) { | 
					
						
							|  |  |  |                                 document.getElementById('username').value = usernameLine.substring(5).trim(); | 
					
						
							|  |  |  |                             } | 
					
						
							|  |  |  |                             if (passwordLine) { | 
					
						
							|  |  |  |                                 document.getElementById('password').value = passwordLine.substring(5).trim(); | 
					
						
							|  |  |  |                             } | 
					
						
							|  |  |  |                              | 
					
						
							| 
									
										
										
										
											2025-07-14 12:47:35 +01:00
										 |  |  |                             if (streamName) { | 
					
						
							| 
									
										
										
										
											2025-07-14 11:45:08 +01:00
										 |  |  |                                 streamInput.value = streamName; | 
					
						
							| 
									
										
										
										
											2025-07-14 12:47:35 +01:00
										 |  |  |                                 awesomplete.evaluate(); | 
					
						
							| 
									
										
										
										
											2025-07-14 12:52:42 +01:00
										 |  |  |                                 if (awesomplete.ul.children.length > 0) { | 
					
						
							|  |  |  |                                     awesomplete.goto(0); | 
					
						
							|  |  |  |                                     awesomplete.select(); | 
					
						
							|  |  |  |                                 } | 
					
						
							| 
									
										
										
										
											2025-07-14 11:45:08 +01:00
										 |  |  |                             } | 
					
						
							|  |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2025-07-15 08:02:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-17 15:23:55 +01:00
										 |  |  |                         const sharedText = accountDetailsTextarea.dataset.sharedText; | 
					
						
							| 
									
										
										
										
											2025-07-15 08:02:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-17 15:23:55 +01:00
										 |  |  |                         if (sharedText && sharedText !== 'None') { | 
					
						
							|  |  |  |                             accountDetailsTextarea.value = sharedText; | 
					
						
							|  |  |  |                             const event = new Event('input', { | 
					
						
							|  |  |  |                                 bubbles: true, | 
					
						
							|  |  |  |                                 cancelable: true, | 
					
						
							|  |  |  |                             }); | 
					
						
							|  |  |  |                             accountDetailsTextarea.dispatchEvent(event); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2025-07-17 11:21:22 +01:00
										 |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2025-07-05 10:57:19 +01:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |     </script> | 
					
						
							| 
									
										
										
										
											2025-07-15 11:43:28 +01:00
										 |  |  | {% endblock %} |