ai-frame-image-server/templates/create_image.html

198 lines
5.3 KiB
HTML
Raw Normal View History

2025-05-15 09:16:09 +01:00
<!DOCTYPE html>
<html lang="en">
2025-06-06 11:21:32 +01:00
2025-05-15 09:16:09 +01:00
<head>
2025-05-18 21:16:11 +01:00
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
2025-05-15 09:16:09 +01:00
<title>Create An Image</title>
<style>
2025-05-18 21:16:11 +01:00
/* ---------- reset ---------- */
2025-06-06 11:21:32 +01:00
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
2025-05-18 21:16:11 +01:00
/* ---------- layout ---------- */
2025-05-15 09:16:09 +01:00
body {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
height: 100vh;
background: black;
color: white;
font-family: Arial, sans-serif;
padding: 20px;
}
2025-06-06 11:21:32 +01:00
2025-05-15 09:16:09 +01:00
textarea {
width: 80vw;
height: 200px;
border-radius: 10px;
padding: 15px;
font-size: 16px;
font-family: monospace;
resize: none;
margin-bottom: 20px;
background: #111;
color: #eee;
border: 1px solid #333;
}
2025-06-06 11:21:32 +01:00
2025-05-15 09:16:09 +01:00
.button-group {
display: flex;
gap: 20px;
2025-05-18 21:16:11 +01:00
align-items: center;
2025-05-15 09:16:09 +01:00
}
2025-06-06 11:21:32 +01:00
button,
select {
2025-05-15 09:16:09 +01:00
background: #333;
color: white;
border: none;
padding: 10px 20px;
border-radius: 8px;
font-size: 16px;
cursor: pointer;
transition: background 0.3s;
}
2025-06-06 11:21:32 +01:00
2025-05-18 21:16:11 +01:00
button:hover,
2025-06-06 11:21:32 +01:00
select:hover {
background: #555;
}
2025-05-18 14:46:48 +01:00
/* ---------- spinner ---------- */
#spinner-overlay {
position: fixed;
inset: 0;
display: flex;
align-items: center;
justify-content: center;
background: rgba(0, 0, 0, 0.6);
2025-05-18 21:16:11 +01:00
visibility: hidden;
2025-05-18 14:46:48 +01:00
z-index: 1000;
}
2025-06-06 11:21:32 +01:00
2025-05-18 14:46:48 +01:00
.spinner {
width: 50px;
height: 50px;
border: 6px solid #555;
border-top-color: white;
border-radius: 50%;
animation: spin 0.8s linear infinite;
}
2025-06-06 11:21:32 +01:00
@keyframes spin {
to {
transform: rotate(360deg);
}
}
@media (max-width: 600px) {
body {
min-height: 100dvh;
height: auto;
justify-content: flex-start;
padding-top: 40px;
}
.button-group {
flex-direction: column;
align-items: stretch;
width: 100%;
}
button,
select {
width: 100%;
}
textarea {
height: 150px;
}
}
2025-05-15 09:16:09 +01:00
</style>
</head>
2025-06-06 11:21:32 +01:00
2025-05-15 09:16:09 +01:00
<body>
<h1 style="margin-bottom: 20px;">Create An Image</h1>
2025-05-18 21:16:11 +01:00
2025-05-15 09:16:09 +01:00
<textarea id="prompt-box" placeholder="Enter your custom prompt here..."></textarea>
2025-05-18 21:16:11 +01:00
2025-05-15 09:16:09 +01:00
<div class="button-group">
2025-05-18 14:46:48 +01:00
<button onclick="showSpinner(); location.href='/'">Back</button>
2025-05-18 21:16:11 +01:00
2025-05-15 09:16:09 +01:00
<button onclick="sendPrompt()">Send Prompt</button>
2025-05-18 21:16:11 +01:00
<button onclick="randomPrompt()">Random Prompt</button>
<!-- new model selector -->
<select id="model-select">
{% for m in models %}
2025-06-06 12:39:11 +01:00
<option value="{{ m }}">{{ m.rsplit('.', 1)[0] }}</option>
2025-05-18 21:16:11 +01:00
{% endfor %}
2025-06-06 11:21:32 +01:00
</select>
2025-05-18 21:16:11 +01:00
2025-05-18 14:46:48 +01:00
</div>
<!-- waiting overlay -->
<div id="spinner-overlay">
<div class="spinner"></div>
2025-05-15 09:16:09 +01:00
</div>
<script>
2025-05-18 14:46:48 +01:00
const overlay = document.getElementById('spinner-overlay');
2025-05-18 21:16:11 +01:00
function showSpinner() { overlay.style.visibility = 'visible'; }
2025-05-18 14:46:48 +01:00
2025-05-15 09:16:09 +01:00
function sendPrompt() {
2025-05-18 14:46:48 +01:00
showSpinner();
2025-05-15 09:16:09 +01:00
const prompt = document.getElementById('prompt-box').value;
2025-06-06 11:21:32 +01:00
const model = document.getElementById('model-select').value;
2025-05-18 21:16:11 +01:00
2025-05-15 09:16:09 +01:00
const formData = new URLSearchParams();
formData.append('prompt', prompt);
2025-05-18 21:16:11 +01:00
formData.append('model', model);
2025-05-15 09:16:09 +01:00
fetch('/create', {
method: 'POST',
2025-05-18 14:46:48 +01:00
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
2025-05-15 09:16:09 +01:00
body: formData.toString()
2025-05-18 14:46:48 +01:00
})
2025-06-06 11:21:32 +01:00
.then(response => {
window.location.href = response.redirected ? response.url : '/create';
})
.catch(error => {
overlay.style.visibility = 'hidden';
alert("Error sending prompt: " + error);
});
2025-05-15 09:16:09 +01:00
}
2025-05-18 21:16:11 +01:00
// wrapper for Random Prompt button so it also sends the model
function randomPrompt() {
showSpinner();
const model = document.getElementById('model-select').value;
const formData = new URLSearchParams();
formData.append('model', model);
fetch('/create', {
method: 'POST',
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
body: formData.toString()
})
2025-06-06 11:21:32 +01:00
.then(response => {
window.location.href = response.redirected ? response.url : '/create';
})
.catch(error => {
overlay.style.visibility = 'hidden';
alert("Error requesting random prompt: " + error);
});
2025-05-18 21:16:11 +01:00
}
2025-05-15 09:16:09 +01:00
</script>
</body>
2025-06-06 11:21:32 +01:00
</html>