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) {
|
2024-09-17 12:39:45 +00:00
|
|
|
const url = `https://cloud.sparksammy.com/yaps.php?targetUrl=https://ollama-api.nodemixaholic.com/api/generate`; // 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>
|