-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
82 lines (72 loc) · 2.31 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
document.addEventListener("DOMContentLoaded", function () {
// Object to store DOM elements
const domElements = {
promptInput: document.querySelector("#promptInput"),
generateButton: document.querySelector("#generate"),
loadingMessage: document.querySelector("#loadingMessage"),
resultImage: document.querySelector("#resultImage"),
};
domElements.promptInput.value = '';
// Initial state of the page
let isLoading = false;
let imageLoaded = false;
// Function to handle submission
function submitPrompt() {
isLoading = true;
domElements.promptInput.style.display = 'none';
domElements.generateButton.style.display = 'none';
domElements.loadingMessage.style.display = 'block';
// Fetch request
fetch('http://localhost:3000/dream', {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({
prompt: domElements.promptInput.value
})
})
.then(response => response.json())
.then(data => {
displayImage(data.image);
})
.catch(error => {
console.error('Error:', error);
resetPage();
});
}
// Function to display image
function displayImage(url) {
isLoading = false;
imageLoaded = true;
domElements.loadingMessage.style.display = 'none';
domElements.resultImage.src = url;
domElements.resultImage.style.display = 'block';
domElements.generateButton.innerText = 'Submit another response';
domElements.generateButton.style.display = 'block';
}
// Function to reset page
function resetPage() {
imageLoaded = false;
domElements.promptInput.style.display = 'block';
domElements.generateButton.style.display = 'block';
domElements.generateButton.innerText = 'Generate';
domElements.resultImage.style.display = 'none';
domElements.loadingMessage.style.display = 'none';
domElements.promptInput.value = '';
}
// Event Listener for the Generate Button
domElements.generateButton.addEventListener('click', function () {
if (isLoading || imageLoaded) {
location.reload();
} else {
submitPrompt();
}
});
// Event Listener for the Enter Key
domElements.promptInput.addEventListener('keyup', function (event) {
if (event.key === 'Enter') {
submitPrompt();
}
});
});