sneedpage/index.html

97 lines
2.7 KiB
HTML
Raw Normal View History

2024-09-17 12:06:06 +00:00
<!DOCTYPE html>
<html>
<head>
<title>SneedPage</title>
2024-09-17 12:08:30 +00:00
<style>
#preview {
width: 100%;
height: 400px; /* Adjust height as needed */
border: 1px solid #ccc;
}
</style>
2024-09-17 12:06:06 +00:00
</head>
<body>
<textarea id="prompt" rows="10" cols="50"></textarea>
2024-09-17 12:08:30 +00:00
<button onclick="generateWebsite()">Generate</button>
<iframe id="preview"></iframe>
2024-09-17 12:06:06 +00:00
<button onclick="saveHTML()">Save HTML</button>
<script>
2024-09-17 12:08:30 +00:00
let currentHTML = '';
2024-09-17 12:06:06 +00:00
function generateWebsite() {
const prompt = document.getElementById("prompt").value;
const generatedHTML = generateHTMLFromPrompt(prompt);
// Load the generated HTML into the iframe
const iframe = document.getElementById("preview");
2024-09-17 12:08:30 +00:00
const iframeDoc = iframe.contentWindow.document;
iframeDoc.open();
iframeDoc.write(generatedHTML);
iframeDoc.close();
2024-09-17 12:06:06 +00:00
}
function saveHTML() {
2024-09-17 12:08:30 +00:00
if (!currentHTML) {
alert("No HTML to save. Generate content first.");
return;
}
const blob = new Blob([currentHTML], { type: "text/html" });
2024-09-17 12:06:06 +00:00
const a = document.createElement("a");
a.href = URL.createObjectURL(blob);
a.download = "generated_website.html";
a.click();
}
function generateHTMLFromPrompt(prompt) {
const url = "https://ollama-api.nodemixaholic.com/api/generate";
2024-09-17 12:08:30 +00:00
const answerCount = 0; // Assuming you want this to start at 0
if (answerCount < 1) {
2024-09-17 12:06:06 +00:00
prompt += `
Create this in HTML, CSS, and Javascript as a single-page application with dynamically loading content.
2024-09-17 12:08:30 +00:00
Do NOT use external libraries.`;
} else {
prompt += `
2024-09-17 12:06:06 +00:00
See that? Yeah do that to the following website code:
2024-09-17 12:09:53 +00:00
"
2024-09-17 12:06:06 +00:00
${currentHTML}
2024-09-17 12:09:53 +00:00
"
2024-09-17 12:06:06 +00:00
Be sure to use HTML, CSS, and Javascript and make it a single-page application with dynamically loading content.
Do NOT use external libraries.
2024-09-17 12:08:30 +00:00
Fix any bugs as well.`;
}
const body = JSON.stringify({
model: "starcoder2:7b",
prompt: prompt // User's prompt from the text area
});
2024-09-17 12:06:06 +00:00
2024-09-17 12:08:30 +00:00
return fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json"
},
body: body
})
.then(response => response.json())
.then(data => {
// Update the currentHTML and display it in the iframe
currentHTML = data.response;
document.getElementById("preview").contentWindow.document.open();
document.getElementById("preview").contentWindow.document.write(currentHTML);
document.getElementById("preview").contentWindow.document.close();
return data.response;
})
.catch(error => {
console.error('Error:', error);
// Handle API errors and display an error message to the user
});
2024-09-17 12:06:06 +00:00
}
</script>
</body>
</html>