File size: 1,858 Bytes
bd98b76
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
document.addEventListener("DOMContentLoaded", () => {
  // Instantiate Hint for API token
  const apiTokenHint = new Hint("hint-icon", "hint-content");

  // Instantiate Hint for Model Info
  const modelInfoHint = new Hint("model-hint-icon", "model-hint-content");

  chooseModel.addEventListener("change", updateModelInfo);

  togglePassword.addEventListener("click", () => {
    const type =
      token.getAttribute("type") === "password" ? "text" : "password";
    token.setAttribute("type", type);

    togglePassword.querySelector("i").classList.toggle("fa-eye-slash");
    togglePassword.querySelector("i").classList.toggle("fa-eye");
  });

  btn.addEventListener("click", async () => {
    //form validations
    if (text.value.trim() === "") {
      notificationInstance.show("error", "Please enter some text.");
      return;
    }

    if (token.value.trim() === "") {
      notificationInstance.show("error", "Please enter your API token.");

      return;
    }

    loader.classList.remove("hidden");
    img.src = ""; // Clear the current image
    downloadBtn.classList.add("hidden");

    try {
      const response = await query(chooseModel.value, token.value);
      const objectUrl = URL.createObjectURL(response);
      img.src = objectUrl;
      downloadBtn.classList.remove("hidden");
      imageHistoryInstance.addToHistory(objectUrl);
    } catch (error) {
      notificationInstance.show(
        "error",
        "Sorry, the model is currently unavailable. Please try again later."
      );
    } finally {
      loader.classList.add("hidden");
    }
  });

  downloadBtn.addEventListener("click", () => {
    const link = document.createElement("a");
    link.href = img.src;
    link.download = "generated_image.png";
    link.click();
  });
}); //END OF EVENT LISTENER