| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  | <!-- templates/add_account.html --> | 
					
						
							|  |  |  | <!DOCTYPE html> | 
					
						
							|  |  |  | <html lang="en"> | 
					
						
							|  |  |  | <head> | 
					
						
							|  |  |  |     <meta charset="UTF-8"> | 
					
						
							|  |  |  |     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | 
					
						
							|  |  |  |     <title>Add Account - KTVManager</title> | 
					
						
							|  |  |  |     <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css"> | 
					
						
							|  |  |  |     <link rel="stylesheet" href="{{ url_for('static', filename='styles.css') }}" /> | 
					
						
							| 
									
										
										
										
											2025-07-15 09:26:43 +01:00
										 |  |  |     <link rel="manifest" href="{{ url_for('static', filename='site.webmanifest') }}?v={{ version }}" /> | 
					
						
							| 
									
										
										
										
											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> | 
					
						
							|  |  |  | </head> | 
					
						
							|  |  |  | <body> | 
					
						
							|  |  |  |     <!-- Navbar --> | 
					
						
							|  |  |  |     <nav class="navbar navbar-expand-lg navbar-dark bg-dark"> | 
					
						
							|  |  |  |         <a class="navbar-brand" href="/">KTVManager</a> | 
					
						
							|  |  |  |         <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation"> | 
					
						
							|  |  |  |             <span class="navbar-toggler-icon"></span> | 
					
						
							|  |  |  |         </button> | 
					
						
							|  |  |  |         <div class="collapse navbar-collapse" id="navbarNav"> | 
					
						
							|  |  |  |             <ul class="navbar-nav ml-auto"> | 
					
						
							|  |  |  |                 <li class="nav-item"> | 
					
						
							|  |  |  |                     <a class="nav-link" href="/">Home</a> | 
					
						
							|  |  |  |                 </li> | 
					
						
							|  |  |  |                 <li class="nav-item"> | 
					
						
							|  |  |  |                     <a class="nav-link" href="/accounts">Accounts</a> | 
					
						
							|  |  |  |                 </li> | 
					
						
							|  |  |  |                 <li class="nav-item"> | 
					
						
							|  |  |  |                     <a class="nav-link" href="/urls">URLs</a> | 
					
						
							|  |  |  |                 </li> | 
					
						
							|  |  |  |             </ul> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |     </nav> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <!-- 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> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <!-- Main Content --> | 
					
						
							|  |  |  |     <main class="container mt-5"> | 
					
						
							|  |  |  |         <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> | 
					
						
							| 
									
										
										
										
											2025-07-09 11:19:43 +01:00
										 |  |  |                 <input type="text" class="form-control" id="stream" name="stream" required> | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |             </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> | 
					
						
							| 
									
										
										
										
											2025-07-14 11:22:24 +01:00
										 |  |  |         {% if ocr_enabled %} | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |         <hr> | 
					
						
							| 
									
										
										
										
											2025-07-13 16:00:52 +01:00
										 |  |  |         <h2>Load Details Via OCR</h2> | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |             <form action="/OCRupload" method="POST" enctype="multipart/form-data" onsubmit="showLoadingOCR()"> | 
					
						
							|  |  |  |                 <div class="form-group"> | 
					
						
							|  |  |  |                     <label for="image">Select Image</label> | 
					
						
							|  |  |  |                     <input type="file" class="form-control-file" id="image" name="image" accept="image/*" required> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |                 <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> | 
					
						
							|  |  |  |                 </button> | 
					
						
							|  |  |  |             </form> | 
					
						
							| 
									
										
										
										
											2025-07-14 11:22:24 +01:00
										 |  |  |         {% endif %} | 
					
						
							| 
									
										
										
										
											2025-07-14 11:45:08 +01:00
										 |  |  |         {% if text_input_enabled %} | 
					
						
							|  |  |  |         <hr> | 
					
						
							|  |  |  |         <h2>Load Details Via Text</h2> | 
					
						
							|  |  |  |         <div class="form-group"> | 
					
						
							|  |  |  |             <label for="accountDetails">Paste Account Details</label> | 
					
						
							|  |  |  |             <textarea class="form-control" id="accountDetails" rows="4"></textarea> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         {% endif %} | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |      | 
					
						
							|  |  |  |     </main> | 
					
						
							|  |  |  |     <footer class="bg-dark text-white text-center py-3 mt-5"> | 
					
						
							|  |  |  |         <p></p> | 
					
						
							|  |  |  |     </footer> | 
					
						
							| 
									
										
										
										
											2025-07-15 10:11:12 +01:00
										 |  |  |     <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.1/dist/umd/popper.min.js"></script> | 
					
						
							| 
									
										
										
										
											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-05 10:57:19 +01:00
										 |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2025-07-15 08:02:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             const sharedTextJson = '{{ shared_text|tojson|safe }}'; | 
					
						
							|  |  |  |             const sharedText = JSON.parse(sharedTextJson); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (sharedText) { | 
					
						
							|  |  |  |                 const accountDetailsTextarea = document.getElementById('accountDetails'); | 
					
						
							|  |  |  |                 if (accountDetailsTextarea) { | 
					
						
							|  |  |  |                     accountDetailsTextarea.value = sharedText; | 
					
						
							|  |  |  |                     const event = new Event('input', { | 
					
						
							|  |  |  |                         bubbles: true, | 
					
						
							|  |  |  |                         cancelable: true, | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                     accountDetailsTextarea.dispatchEvent(event); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2025-07-05 10:57:19 +01:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2025-05-09 16:31:14 +01:00
										 |  |  |     </script> | 
					
						
							|  |  |  | </body> | 
					
						
							|  |  |  | </html> |