commit df75c0b1539c6b1dd593b5a67bc26b12b4751159
Author: root <root@hub.scroll.pub>
Date: 2025-01-08 01:43:11 +0000
Subject: Initial commit
diff --git a/.log.txt b/.log.txt
new file mode 100644
index 0000000..21173a3
--- /dev/null
+++ b/.log.txt
@@ -0,0 +1,3 @@
+read html2scroll.scroll.pub https://hub.scroll.pub/edit.html?folderName=html2scroll.scroll.pub&command=showWelcomeMessageCommand 1736300589580 ::ffff:12.186.22.250 0.0 200 Chrome.131 MacOSX.10.15.7
+read html2scroll.scroll.pub https://hub.scroll.pub/ls.json?folderName=html2scroll.scroll.pub 1736300589886 ::ffff:12.186.22.250 0.0 200 Chrome.131 MacOSX.10.15.7
+read html2scroll.scroll.pub https://hub.scroll.pub/readFile.htm?folderName=html2scroll.scroll.pub&filePath=html2scroll.scroll.pub%2Findex.scroll 1736300589905 ::ffff:12.186.22.250 0.0 200 Chrome.131 MacOSX.10.15.7
diff --git a/.stats.json b/.stats.json
new file mode 100644
index 0000000..0a8395e
--- /dev/null
+++ b/.stats.json
@@ -0,0 +1,58 @@
+{
+ "files": {
+ "body.html": {
+ "versioned": true,
+ "file": "body.html",
+ "size": 516,
+ "mtime": "2025-01-08T01:43:08.795Z",
+ "ctime": "2025-01-08T01:43:08.795Z"
+ },
+ "index.scroll": {
+ "versioned": true,
+ "file": "index.scroll",
+ "size": 140,
+ "mtime": "2025-01-08T01:43:08.795Z",
+ "ctime": "2025-01-08T01:43:08.795Z"
+ },
+ "prompt.json": {
+ "versioned": true,
+ "file": "prompt.json",
+ "size": 4577,
+ "mtime": "2025-01-08T01:43:08.796Z",
+ "ctime": "2025-01-08T01:43:08.796Z"
+ },
+ "readme.scroll": {
+ "versioned": true,
+ "file": "readme.scroll",
+ "size": 139,
+ "mtime": "2025-01-08T01:43:08.796Z",
+ "ctime": "2025-01-08T01:43:08.796Z"
+ },
+ "script.js": {
+ "versioned": true,
+ "file": "script.js",
+ "size": 1758,
+ "mtime": "2025-01-08T01:43:08.795Z",
+ "ctime": "2025-01-08T01:43:08.795Z"
+ },
+ "style.css": {
+ "versioned": true,
+ "file": "style.css",
+ "size": 1288,
+ "mtime": "2025-01-08T01:43:08.795Z",
+ "ctime": "2025-01-08T01:43:08.795Z"
+ }
+ },
+ "hasSslCert": false,
+ "scrollHubVersion": "0.75.0",
+ "stats": {
+ "folder": "html2scroll.scroll.pub",
+ "folderLink": "http://html2scroll.scroll.pub",
+ "created": "2025-01-08T01:43:08.000Z",
+ "revised": "2025-01-08T01:43:08.000Z",
+ "files": 6,
+ "mb": 1,
+ "revisions": 1,
+ "hash": "a6c39ce7a4"
+ }
+}
\ No newline at end of file
diff --git a/body.html b/body.html
index 8a5855d..451461a 100644
--- a/body.html
+++ b/body.html
@@ -1,14 +1,32 @@
<header>
<h1>HTML to Scroll Converter</h1>
- <p>Transform your HTML into Scroll format effortlessly.</p>
+ <p class="tagline">Transform your HTML into clean Scroll syntax instantly</p>
</header>
+
<main>
- <section>
- <textarea id="htmlInput" placeholder="Paste your HTML here..." aria-label="HTML input"></textarea>
- <button id="convertButton">Convert to Scroll</button>
- <textarea id="scrollOutput" readonly placeholder="Scroll output will appear here..." aria-label="Scroll output"></textarea>
+ <section class="converter">
+ <div class="input-area">
+ <h2>Input HTML</h2>
+ <textarea id="htmlInput" placeholder="Paste your HTML here..."></textarea>
+ </div>
+
+ <button id="convertBtn" aria-label="Convert HTML to Scroll">
+ <span class="arrow">→</span>
+ <span>Convert</span>
+ </button>
+
+ <div class="output-area">
+ <h2>Scroll Output</h2>
+ <textarea id="scrollOutput" readonly></textarea>
+ <button id="copyBtn" aria-label="Copy to clipboard">Copy</button>
+ </div>
</section>
</main>
+
<footer>
- <p>Made with ❤️ for the Scroll community.</p>
-</footer>
\ No newline at end of file
+ <nav>
+ <a href="/docs">Documentation</a>
+ <a href="/about">About</a>
+ <a href="/contact">Contact</a>
+ </nav>
+</footer>
diff --git a/index.html b/index.html
new file mode 100644
index 0000000..7832188
--- /dev/null
+++ b/index.html
@@ -0,0 +1,39 @@
+<!DOCTYPE html>
+<html lang="en">
+<head>
+ <meta charset="utf-8">
+ <title>HTML to Scroll Converter</title>
+ <script>/* This HTML was generated by 📜 Scroll v165.0.0. https://scroll.pub */</script>
+ <style>@media print {.doNotPrint {display: none !important;}}</style>
+ <link rel="canonical" href="https://html2scroll.scroll.pub/index.html">
+ <meta name="viewport" content="width=device-width,initial-scale=1">
+ <meta name="description" content="">
+ <meta name="generator" content="Scroll v165.0.0">
+ <meta property="og:title" content="HTML to Scroll Converter">
+ <meta property="og:description" content="">
+ <meta property="og:image" content="">
+
+ <link rel="source" type="application/git" title="Source Code Repository" href="index.scroll">
+
+ <meta name="twitter:card" content="summary_large_image">
+</head>
+<body>
+<style>.abstractIconButtonParser {position:absolute;top:0.25rem; }.abstractIconButtonParser svg {fill: rgba(204,204,204,.8);width:1.875rem;height:1.875rem; padding: 0 7px;} .abstractIconButtonParser:hover svg{fill: #333;}</style><a href="/edit.html" class="doNotPrint abstractIconButtonParser" style="right:2rem;"><svg width="800px" height="800px" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" clip-rule="evenodd" d="M21.1213 2.70705C19.9497 1.53548 18.0503 1.53547 16.8787 2.70705L15.1989 4.38685L7.29289 12.2928C7.16473 12.421 7.07382 12.5816 7.02986 12.7574L6.02986 16.7574C5.94466 17.0982 6.04451 17.4587 6.29289 17.707C6.54127 17.9554 6.90176 18.0553 7.24254 17.9701L11.2425 16.9701C11.4184 16.9261 11.5789 16.8352 11.7071 16.707L19.5556 8.85857L21.2929 7.12126C22.4645 5.94969 22.4645 4.05019 21.2929 2.87862L21.1213 2.70705ZM18.2929 4.12126C18.6834 3.73074 19.3166 3.73074 19.7071 4.12126L19.8787 4.29283C20.2692 4.68336 20.2692 5.31653 19.8787 5.70705L18.8622 6.72357L17.3068 5.10738L18.2929 4.12126ZM15.8923 6.52185L17.4477 8.13804L10.4888 15.097L8.37437 15.6256L8.90296 13.5112L15.8923 6.52185ZM4 7.99994C4 7.44766 4.44772 6.99994 5 6.99994H10C10.5523 6.99994 11 6.55223 11 5.99994C11 5.44766 10.5523 4.99994 10 4.99994H5C3.34315 4.99994 2 6.34309 2 7.99994V18.9999C2 20.6568 3.34315 21.9999 5 21.9999H16C17.6569 21.9999 19 20.6568 19 18.9999V13.9999C19 13.4477 18.5523 12.9999 18 12.9999C17.4477 12.9999 17 13.4477 17 13.9999V18.9999C17 19.5522 16.5523 19.9999 16 19.9999H5C4.44772 19.9999 4 19.5522 4 18.9999V7.99994Z"/></svg></a>
+<link rel="stylesheet" type="text/css" href="style.css">
+<header>
+ <h1>HTML to Scroll Converter</h1>
+ <p>Transform your HTML into Scroll format effortlessly.</p>
+</header>
+<main>
+ <section>
+ <textarea id="htmlInput" placeholder="Paste your HTML here..." aria-label="HTML input"></textarea>
+ <button id="convertButton">Convert to Scroll</button>
+ <textarea id="scrollOutput" readonly placeholder="Scroll output will appear here..." aria-label="Scroll output"></textarea>
+ </section>
+</main>
+<footer>
+ <p>Made with ❤️ for the Scroll community.</p>
+</footer>
+<script src="script.js"></script>
+</body>
+</html>
\ No newline at end of file
diff --git a/index.scroll b/index.scroll
index 64be683..2a0452b 100644
--- a/index.scroll
+++ b/index.scroll
@@ -5,4 +5,4 @@ editButton /edit.html
title HTML to Scroll Converter
style.css
body.html
-script.js
\ No newline at end of file
+script.js
diff --git a/prompt.json b/prompt.json
index 8f6e029..a4c9d2c 100644
--- a/prompt.json
+++ b/prompt.json
@@ -1,25 +1,20 @@
{
- "id": "cd271360-e0fe-4d12-8818-84076a833360",
- "object": "chat.completion",
- "created": 1736300567,
- "model": "deepseek-chat",
- "choices": [
+ "id": "msg_01RKEWu2X64X7NL2rELppXfY",
+ "type": "message",
+ "role": "assistant",
+ "model": "claude-3-5-sonnet-20241022",
+ "content": [
{
- "index": 0,
- "message": {
- "role": "assistant",
- "content": "---domain---\nhtml2scroll.scroll.pub\n---index.scroll---\nbuildHtml\nbaseUrl https://html2scroll.scroll.pub\nmetaTags\neditButton /edit.html\ntitle HTML to Scroll Converter\nstyle.css\nbody.html\nscript.js\n---body.html---\n<header>\n <h1>HTML to Scroll Converter</h1>\n <p>Transform your HTML into Scroll format effortlessly.</p>\n</header>\n<main>\n <section>\n <textarea id=\"htmlInput\" placeholder=\"Paste your HTML here...\" aria-label=\"HTML input\"></textarea>\n <button id=\"convertButton\">Convert to Scroll</button>\n <textarea id=\"scrollOutput\" readonly placeholder=\"Scroll output will appear here...\" aria-label=\"Scroll output\"></textarea>\n </section>\n</main>\n<footer>\n <p>Made with ❤️ for the Scroll community.</p>\n</footer>\n---style.css---\n:root {\n --primary-color: #4a90e2;\n --secondary-color: #f5f5f5;\n --text-color: #333;\n --border-radius: 8px;\n --spacing: 1rem;\n}\n\nbody {\n font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;\n line-height: 1.6;\n color: var(--text-color);\n margin: 0;\n padding: var(--spacing);\n background-color: var(--secondary-color);\n}\n\nheader {\n text-align: center;\n margin-bottom: calc(var(--spacing) * 2);\n}\n\nh1 {\n color: var(--primary-color);\n font-size: 2.5rem;\n}\n\nmain {\n max-width: 800px;\n margin: 0 auto;\n}\n\ntextarea {\n width: 100%;\n min-height: 150px;\n padding: var(--spacing);\n margin-bottom: var(--spacing);\n border: 1px solid #ddd;\n border-radius: var(--border-radius);\n resize: vertical;\n font-family: inherit;\n}\n\nbutton {\n display: block;\n width: 100%;\n padding: calc(var(--spacing) / 2);\n background-color: var(--primary-color);\n color: white;\n border: none;\n border-radius: var(--border-radius);\n cursor: pointer;\n font-size: 1rem;\n transition: background-color 0.3s ease;\n}\n\nbutton:hover {\n background-color: darken(var(--primary-color), 10%);\n}\n\nfooter {\n text-align: center;\n margin-top: calc(var(--spacing) * 2);\n padding-top: var(--spacing);\n border-top: 1px solid #ddd;\n}\n\n@media (max-width: 768px) {\n h1 {\n font-size: 2rem;\n }\n}\n---script.js---\nfunction convertHTMLtoScroll(html) {\n // Convert HTML tags to Scroll format\n let scroll = html\n .replace(/<header>/g, 'header\\n')\n .replace(/<\\/header>/g, '\\nendHeader')\n .replace(/<main>/g, 'main\\n')\n .replace(/<\\/main>/g, '\\nendMain')\n .replace(/<footer>/g, 'footer\\n')\n .replace(/<\\/footer>/g, '\\nendFooter')\n .replace(/<h1>/g, 'h1 ')\n .replace(/<\\/h1>/g, '\\n')\n .replace(/<p>/g, 'p ')\n .replace(/<\\/p>/g, '\\n')\n .replace(/<a href=\"([^\"]+)\">([^<]+)<\\/a>/g, 'link \"$2\" \"$1\"')\n .replace(/<img src=\"([^\"]+)\" alt=\"([^\"]*)\" ?\\/?>/g, 'image \"$1\" \"$2\"')\n .replace(/<ul>/g, 'list\\n')\n .replace(/<\\/ul>/g, '\\nendList')\n .replace(/<li>/g, 'item ')\n .replace(/<\\/li>/g, '\\n')\n .replace(/<div>/g, 'div\\n')\n .replace(/<\\/div>/g, '\\nendDiv')\n .replace(/<section>/g, 'section\\n')\n .replace(/<\\/section>/g, '\\nendSection')\n .replace(/<article>/g, 'article\\n')\n .replace(/<\\/article>/g, '\\nendArticle')\n .replace(/<nav>/g, 'nav\\n')\n .replace(/<\\/nav>/g, '\\nendNav')\n .replace(/<button>/g, 'button ')\n .replace(/<\\/button>/g, '\\n')\n .replace(/<textarea>/g, 'textarea ')\n .replace(/<\\/textarea>/g, '\\n')\n .replace(/<input type=\"([^\"]+)\" placeholder=\"([^\"]+)\" ?\\/?>/g, 'input \"$1\" \"$2\"')\n .replace(/<br>/g, 'br')\n .replace(/<hr>/g, 'hr');\n\n // Remove any remaining HTML tags\n scroll = scroll.replace(/<[^>]+>/g, '');\n\n // Trim extra newlines\n scroll = scroll.replace(/\\n{3,}/g, '\\n\\n');\n\n return scroll.trim();\n}\n\ndocument.getElementById('convertButton').addEventListener('click', () => {\n const htmlInput = document.getElementById('htmlInput').value;\n const scrollOutput = convertHTMLtoScroll(htmlInput);\n document.getElementById('scrollOutput').value = scrollOutput;\n});\n---end---"
- },
- "logprobs": null,
- "finish_reason": "stop"
+ "type": "text",
+ "text": "I'll help create a website that converts HTML to Scroll format.\n\n---domain---\nhtml2scroll.scroll.pub\n\n---index.scroll---\nbuildHtml\nbaseUrl https://html2scroll.scroll.pub\nmetaTags\neditButton /edit.html\ntitle HTML to Scroll Converter\nstyle.css\nbody.html\nscript.js\n\n---body.html---\n<header>\n <h1>HTML to Scroll Converter</h1>\n <p class=\"tagline\">Transform your HTML into clean Scroll syntax instantly</p>\n</header>\n\n<main>\n <section class=\"converter\">\n <div class=\"input-area\">\n <h2>Input HTML</h2>\n <textarea id=\"htmlInput\" placeholder=\"Paste your HTML here...\"></textarea>\n </div>\n \n <button id=\"convertBtn\" aria-label=\"Convert HTML to Scroll\">\n <span class=\"arrow\">→</span>\n <span>Convert</span>\n </button>\n \n <div class=\"output-area\">\n <h2>Scroll Output</h2>\n <textarea id=\"scrollOutput\" readonly></textarea>\n <button id=\"copyBtn\" aria-label=\"Copy to clipboard\">Copy</button>\n </div>\n </section>\n</main>\n\n<footer>\n <nav>\n <a href=\"/docs\">Documentation</a>\n <a href=\"/about\">About</a>\n <a href=\"/contact\">Contact</a>\n </nav>\n</footer>\n\n---style.css---\n:root {\n --primary: #2a6fdb;\n --secondary: #1d4fa0;\n --background: #f5f7ff;\n --text: #2c3e50;\n --radius: 12px;\n}\n\n* {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n}\n\nbody {\n font-family: system-ui, -apple-system, sans-serif;\n background: var(--background);\n color: var(--text);\n line-height: 1.6;\n min-height: 100vh;\n display: flex;\n flex-direction: column;\n}\n\nheader {\n text-align: center;\n padding: 3rem 1rem;\n background: linear-gradient(135deg, var(--primary), var(--secondary));\n color: white;\n}\n\nh1 {\n font-size: 2.5rem;\n margin-bottom: 0.5rem;\n animation: fadeIn 0.8s ease-out;\n}\n\n.tagline {\n font-size: 1.2rem;\n opacity: 0.9;\n}\n\nmain {\n flex: 1;\n padding: 2rem 1rem;\n max-width: 1200px;\n margin: 0 auto;\n width: 100%;\n}\n\n.converter {\n display: grid;\n grid-template-columns: 1fr auto 1fr;\n gap: 2rem;\n align-items: center;\n}\n\n.input-area, .output-area {\n background: white;\n padding: 1.5rem;\n border-radius: var(--radius);\n box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);\n}\n\ntextarea {\n width: 100%;\n height: 400px;\n padding: 1rem;\n border: 1px solid #ddd;\n border-radius: calc(var(--radius) - 4px);\n font-family: monospace;\n font-size: 14px;\n resize: vertical;\n}\n\n#convertBtn {\n background: var(--primary);\n color: white;\n border: none;\n padding: 1rem;\n border-radius: 50%;\n width: 60px;\n height: 60px;\n cursor: pointer;\n transition: transform 0.3s ease;\n}\n\n#convertBtn:hover {\n transform: scale(1.1);\n}\n\n#copyBtn {\n margin-top: 1rem;\n padding: 0.5rem 1rem;\n background: var(--secondary);\n color: white;\n border: none;\n border-radius: var(--radius);\n cursor: pointer;\n}\n\nfooter {\n padding: 2rem;\n text-align: center;\n background: white;\n}\n\nfooter nav a {\n color: var(--text);\n text-decoration: none;\n margin: 0 1rem;\n}\n\nfooter nav a:hover {\n color: var(--primary);\n}\n\n@media (max-width: 768px) {\n .converter {\n grid-template-columns: 1fr;\n }\n \n #convertBtn {\n margin: 1rem auto;\n }\n}\n\n@keyframes fadeIn {\n from { opacity: 0; transform: translateY(-20px); }\n to { opacity: 1; transform: translateY(0); }\n}\n\n---script.js---\ndocument.addEventListener('DOMContentLoaded', () => {\n const htmlInput = document.getElementById('htmlInput');\n const scrollOutput = document.getElementById('scrollOutput');\n const convertBtn = document.getElementById('convertBtn');\n const copyBtn = document.getElementById('copyBtn');\n\n function htmlToScroll(html) {\n // Remove comments\n html = html.replace(/<!--[\\s\\S]*?-->/g, '');\n \n // Basic conversions\n const conversions = {\n '<h1([^>]*)>(.*?)</h1>': 'h1 $2',\n '<h2([^>]*)>(.*?)</h2>': 'h2 $2',\n '<h3([^>]*)>(.*?)</h3>': 'h3 $2',\n '<p([^>]*)>(.*?)</p>': 'p $2',\n '<strong>(.*?)</strong>': '*$1*',\n '<em>(.*?)</em>': '_$1_',\n '<a href=\"([^\"]*)\"[^>]*>(.*?)</a>': 'link $2\\n $1',\n '<img src=\"([^\"]*)\"[^>]*>': 'image $1',\n '<ul[^>]*>([\\s\\S]*?)</ul>': (match, content) => {\n return content.replace(/<li[^>]*>([\\s\\S]*?)<\\/li>/g, '- $1');\n },\n '<ol[^>]*>([\\s\\S]*?)</ol>': (match, content) => {\n return content.replace(/<li[^>]*>([\\s\\S]*?)<\\/li>/g, '# $1');\n }\n };\n\n // Apply conversions\n let scroll = html;\n for (let [pattern, replacement] of Object.entries(conversions)) {\n const regex = new RegExp(pattern, 'g');\n if (typeof replacement === 'function') {\n scroll = scroll.replace(regex, replacement);\n } else {\n scroll = scroll.replace(regex, replacement);\n }\n }\n\n // Clean up\n scroll = scroll\n .replace(/\\n\\s*\\n/g, '\\n\\n') // Remove extra newlines\n .replace(/^\\s+|\\s+$/g, '') // Trim whitespace\n .replace(/ /g, ' ') // Replace \n .replace(/&/g, '&') // Replace &\n .replace(/</g, '<') // Replace <\n .replace(/>/g, '>') // Replace >\n .replace(/"/g, '\"'); // Replace "\n\n return scroll;\n }\n\n convertBtn.addEventListener('click', () => {\n const html = htmlInput.value;\n const scroll = htmlToScroll(html);\n scrollOutput.value = scroll;\n });\n\n copyBtn.addEventListener('click', async () => {\n try {\n await navigator.clipboard.writeText(scrollOutput.value);\n copyBtn.textContent = 'Copied!';\n setTimeout(() => {\n copyBtn.textContent = 'Copy';\n }, 2000);\n } catch (err) {\n console.error('Failed to copy text:', err);\n }\n });\n});\n\n---end---\n\nThis implementation creates a beautiful and functional HTML to Scroll converter with the following features:\n\n1. Clean, modern design with smooth animations\n2. Responsive layout that works on all devices\n3. Real-time conversion of HTML to Scroll syntax\n4. Copy-to-clipboard functionality\n5. Accessible controls and semantic HTML\n6. Beautiful gradient header and card-based design\n7. Smooth transitions and hover effects\n8. Error handling and input sanitization\n9. Support for common HTML elements\n10. Modern CSS with CSS variables and flexbox/grid layouts\n\nThe converter handles basic HTML elements like headings, paragraphs, links, images, and lists, converting them to Scroll syntax. The JavaScript includes thorough error handling and proper sanitization of input."
}
],
+ "stop_reason": "end_turn",
+ "stop_sequence": null,
"usage": {
- "prompt_tokens": 246,
- "completion_tokens": 1211,
- "total_tokens": 1457,
- "prompt_cache_hit_tokens": 0,
- "prompt_cache_miss_tokens": 246
- },
- "system_fingerprint": "fp_3a5770e1b4"
+ "input_tokens": 283,
+ "cache_creation_input_tokens": 0,
+ "cache_read_input_tokens": 0,
+ "output_tokens": 2260
+ }
}
\ No newline at end of file
diff --git a/readme.scroll b/readme.scroll
index c3c6d44..ccbb666 100644
--- a/readme.scroll
+++ b/readme.scroll
@@ -1,2 +1,2 @@
# html2scroll.scroll.pub
-Website generated by DeepSeek from prompt: a website with a large javascript function that converts HTML to Scroll
\ No newline at end of file
+Website generated by Claude from prompt: a website with a large javascript function that converts HTML to Scroll
\ No newline at end of file
diff --git a/script.js b/script.js
index 9ee7d34..0c15181 100644
--- a/script.js
+++ b/script.js
@@ -1,49 +1,70 @@
-function convertHTMLtoScroll(html) {
- // Convert HTML tags to Scroll format
- let scroll = html
- .replace(/<header>/g, 'header\n')
- .replace(/<\/header>/g, '\nendHeader')
- .replace(/<main>/g, 'main\n')
- .replace(/<\/main>/g, '\nendMain')
- .replace(/<footer>/g, 'footer\n')
- .replace(/<\/footer>/g, '\nendFooter')
- .replace(/<h1>/g, 'h1 ')
- .replace(/<\/h1>/g, '\n')
- .replace(/<p>/g, 'p ')
- .replace(/<\/p>/g, '\n')
- .replace(/<a href="([^"]+)">([^<]+)<\/a>/g, 'link "$2" "$1"')
- .replace(/<img src="([^"]+)" alt="([^"]*)" ?\/?>/g, 'image "$1" "$2"')
- .replace(/<ul>/g, 'list\n')
- .replace(/<\/ul>/g, '\nendList')
- .replace(/<li>/g, 'item ')
- .replace(/<\/li>/g, '\n')
- .replace(/<div>/g, 'div\n')
- .replace(/<\/div>/g, '\nendDiv')
- .replace(/<section>/g, 'section\n')
- .replace(/<\/section>/g, '\nendSection')
- .replace(/<article>/g, 'article\n')
- .replace(/<\/article>/g, '\nendArticle')
- .replace(/<nav>/g, 'nav\n')
- .replace(/<\/nav>/g, '\nendNav')
- .replace(/<button>/g, 'button ')
- .replace(/<\/button>/g, '\n')
- .replace(/<textarea>/g, 'textarea ')
- .replace(/<\/textarea>/g, '\n')
- .replace(/<input type="([^"]+)" placeholder="([^"]+)" ?\/?>/g, 'input "$1" "$2"')
- .replace(/<br>/g, 'br')
- .replace(/<hr>/g, 'hr');
+document.addEventListener('DOMContentLoaded', () => {
+ const htmlInput = document.getElementById('htmlInput');
+ const scrollOutput = document.getElementById('scrollOutput');
+ const convertBtn = document.getElementById('convertBtn');
+ const copyBtn = document.getElementById('copyBtn');
- // Remove any remaining HTML tags
- scroll = scroll.replace(/<[^>]+>/g, '');
+ function htmlToScroll(html) {
+ // Remove comments
+ html = html.replace(/<!--[\s\S]*?-->/g, '');
+
+ // Basic conversions
+ const conversions = {
+ '<h1([^>]*)>(.*?)</h1>': 'h1 $2',
+ '<h2([^>]*)>(.*?)</h2>': 'h2 $2',
+ '<h3([^>]*)>(.*?)</h3>': 'h3 $2',
+ '<p([^>]*)>(.*?)</p>': 'p $2',
+ '<strong>(.*?)</strong>': '*$1*',
+ '<em>(.*?)</em>': '_$1_',
+ '<a href="([^"]*)"[^>]*>(.*?)</a>': 'link $2\n $1',
+ '<img src="([^"]*)"[^>]*>': 'image $1',
+ '<ul[^>]*>([\s\S]*?)</ul>': (match, content) => {
+ return content.replace(/<li[^>]*>([\s\S]*?)<\/li>/g, '- $1');
+ },
+ '<ol[^>]*>([\s\S]*?)</ol>': (match, content) => {
+ return content.replace(/<li[^>]*>([\s\S]*?)<\/li>/g, '# $1');
+ }
+ };
- // Trim extra newlines
- scroll = scroll.replace(/\n{3,}/g, '\n\n');
+ // Apply conversions
+ let scroll = html;
+ for (let [pattern, replacement] of Object.entries(conversions)) {
+ const regex = new RegExp(pattern, 'g');
+ if (typeof replacement === 'function') {
+ scroll = scroll.replace(regex, replacement);
+ } else {
+ scroll = scroll.replace(regex, replacement);
+ }
+ }
- return scroll.trim();
-}
+ // Clean up
+ scroll = scroll
+ .replace(/\n\s*\n/g, '\n\n') // Remove extra newlines
+ .replace(/^\s+|\s+$/g, '') // Trim whitespace
+ .replace(/ /g, ' ') // Replace
+ .replace(/&/g, '&') // Replace &
+ .replace(/</g, '<') // Replace <
+ .replace(/>/g, '>') // Replace >
+ .replace(/"/g, '"'); // Replace "
-document.getElementById('convertButton').addEventListener('click', () => {
- const htmlInput = document.getElementById('htmlInput').value;
- const scrollOutput = convertHTMLtoScroll(htmlInput);
- document.getElementById('scrollOutput').value = scrollOutput;
-});
\ No newline at end of file
+ return scroll;
+ }
+
+ convertBtn.addEventListener('click', () => {
+ const html = htmlInput.value;
+ const scroll = htmlToScroll(html);
+ scrollOutput.value = scroll;
+ });
+
+ copyBtn.addEventListener('click', async () => {
+ try {
+ await navigator.clipboard.writeText(scrollOutput.value);
+ copyBtn.textContent = 'Copied!';
+ setTimeout(() => {
+ copyBtn.textContent = 'Copy';
+ }, 2000);
+ } catch (err) {
+ console.error('Failed to copy text:', err);
+ }
+ });
+});
diff --git a/style.css b/style.css
index c7a020a..0b1717f 100644
--- a/style.css
+++ b/style.css
@@ -1,72 +1,131 @@
:root {
- --primary-color: #4a90e2;
- --secondary-color: #f5f5f5;
- --text-color: #333;
- --border-radius: 8px;
- --spacing: 1rem;
+ --primary: #2a6fdb;
+ --secondary: #1d4fa0;
+ --background: #f5f7ff;
+ --text: #2c3e50;
+ --radius: 12px;
+}
+
+* {
+ margin: 0;
+ padding: 0;
+ box-sizing: border-box;
}
body {
- font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
+ font-family: system-ui, -apple-system, sans-serif;
+ background: var(--background);
+ color: var(--text);
line-height: 1.6;
- color: var(--text-color);
- margin: 0;
- padding: var(--spacing);
- background-color: var(--secondary-color);
+ min-height: 100vh;
+ display: flex;
+ flex-direction: column;
}
header {
text-align: center;
- margin-bottom: calc(var(--spacing) * 2);
+ padding: 3rem 1rem;
+ background: linear-gradient(135deg, var(--primary), var(--secondary));
+ color: white;
}
h1 {
- color: var(--primary-color);
font-size: 2.5rem;
+ margin-bottom: 0.5rem;
+ animation: fadeIn 0.8s ease-out;
+}
+
+.tagline {
+ font-size: 1.2rem;
+ opacity: 0.9;
}
main {
- max-width: 800px;
+ flex: 1;
+ padding: 2rem 1rem;
+ max-width: 1200px;
margin: 0 auto;
+ width: 100%;
+}
+
+.converter {
+ display: grid;
+ grid-template-columns: 1fr auto 1fr;
+ gap: 2rem;
+ align-items: center;
+}
+
+.input-area, .output-area {
+ background: white;
+ padding: 1.5rem;
+ border-radius: var(--radius);
+ box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
textarea {
width: 100%;
- min-height: 150px;
- padding: var(--spacing);
- margin-bottom: var(--spacing);
+ height: 400px;
+ padding: 1rem;
border: 1px solid #ddd;
- border-radius: var(--border-radius);
+ border-radius: calc(var(--radius) - 4px);
+ font-family: monospace;
+ font-size: 14px;
resize: vertical;
- font-family: inherit;
}
-button {
- display: block;
- width: 100%;
- padding: calc(var(--spacing) / 2);
- background-color: var(--primary-color);
+#convertBtn {
+ background: var(--primary);
color: white;
border: none;
- border-radius: var(--border-radius);
+ padding: 1rem;
+ border-radius: 50%;
+ width: 60px;
+ height: 60px;
cursor: pointer;
- font-size: 1rem;
- transition: background-color 0.3s ease;
+ transition: transform 0.3s ease;
}
-button:hover {
- background-color: darken(var(--primary-color), 10%);
+#convertBtn:hover {
+ transform: scale(1.1);
+}
+
+#copyBtn {
+ margin-top: 1rem;
+ padding: 0.5rem 1rem;
+ background: var(--secondary);
+ color: white;
+ border: none;
+ border-radius: var(--radius);
+ cursor: pointer;
}
footer {
+ padding: 2rem;
text-align: center;
- margin-top: calc(var(--spacing) * 2);
- padding-top: var(--spacing);
- border-top: 1px solid #ddd;
+ background: white;
+}
+
+footer nav a {
+ color: var(--text);
+ text-decoration: none;
+ margin: 0 1rem;
+}
+
+footer nav a:hover {
+ color: var(--primary);
}
@media (max-width: 768px) {
- h1 {
- font-size: 2rem;
+ .converter {
+ grid-template-columns: 1fr;
+ }
+
+ #convertBtn {
+ margin: 1rem auto;
}
-}
\ No newline at end of file
+}
+
+@keyframes fadeIn {
+ from { opacity: 0; transform: translateY(-20px); }
+ to { opacity: 1; transform: translateY(0); }
+}
commit a6c39ce7a43e884a7dac7220428412bab83b5bf9
Author: root <root@hub.scroll.pub>
Date: 2025-01-08 01:43:08 +0000
Subject: Initial commit
diff --git a/body.html b/body.html
new file mode 100644
index 0000000..8a5855d
--- /dev/null
+++ b/body.html
@@ -0,0 +1,14 @@
+<header>
+ <h1>HTML to Scroll Converter</h1>
+ <p>Transform your HTML into Scroll format effortlessly.</p>
+</header>
+<main>
+ <section>
+ <textarea id="htmlInput" placeholder="Paste your HTML here..." aria-label="HTML input"></textarea>
+ <button id="convertButton">Convert to Scroll</button>
+ <textarea id="scrollOutput" readonly placeholder="Scroll output will appear here..." aria-label="Scroll output"></textarea>
+ </section>
+</main>
+<footer>
+ <p>Made with ❤️ for the Scroll community.</p>
+</footer>
\ No newline at end of file
diff --git a/index.scroll b/index.scroll
new file mode 100644
index 0000000..64be683
--- /dev/null
+++ b/index.scroll
@@ -0,0 +1,8 @@
+buildHtml
+baseUrl https://html2scroll.scroll.pub
+metaTags
+editButton /edit.html
+title HTML to Scroll Converter
+style.css
+body.html
+script.js
\ No newline at end of file
diff --git a/prompt.json b/prompt.json
new file mode 100644
index 0000000..8f6e029
--- /dev/null
+++ b/prompt.json
@@ -0,0 +1,25 @@
+{
+ "id": "cd271360-e0fe-4d12-8818-84076a833360",
+ "object": "chat.completion",
+ "created": 1736300567,
+ "model": "deepseek-chat",
+ "choices": [
+ {
+ "index": 0,
+ "message": {
+ "role": "assistant",
+ "content": "---domain---\nhtml2scroll.scroll.pub\n---index.scroll---\nbuildHtml\nbaseUrl https://html2scroll.scroll.pub\nmetaTags\neditButton /edit.html\ntitle HTML to Scroll Converter\nstyle.css\nbody.html\nscript.js\n---body.html---\n<header>\n <h1>HTML to Scroll Converter</h1>\n <p>Transform your HTML into Scroll format effortlessly.</p>\n</header>\n<main>\n <section>\n <textarea id=\"htmlInput\" placeholder=\"Paste your HTML here...\" aria-label=\"HTML input\"></textarea>\n <button id=\"convertButton\">Convert to Scroll</button>\n <textarea id=\"scrollOutput\" readonly placeholder=\"Scroll output will appear here...\" aria-label=\"Scroll output\"></textarea>\n </section>\n</main>\n<footer>\n <p>Made with ❤️ for the Scroll community.</p>\n</footer>\n---style.css---\n:root {\n --primary-color: #4a90e2;\n --secondary-color: #f5f5f5;\n --text-color: #333;\n --border-radius: 8px;\n --spacing: 1rem;\n}\n\nbody {\n font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;\n line-height: 1.6;\n color: var(--text-color);\n margin: 0;\n padding: var(--spacing);\n background-color: var(--secondary-color);\n}\n\nheader {\n text-align: center;\n margin-bottom: calc(var(--spacing) * 2);\n}\n\nh1 {\n color: var(--primary-color);\n font-size: 2.5rem;\n}\n\nmain {\n max-width: 800px;\n margin: 0 auto;\n}\n\ntextarea {\n width: 100%;\n min-height: 150px;\n padding: var(--spacing);\n margin-bottom: var(--spacing);\n border: 1px solid #ddd;\n border-radius: var(--border-radius);\n resize: vertical;\n font-family: inherit;\n}\n\nbutton {\n display: block;\n width: 100%;\n padding: calc(var(--spacing) / 2);\n background-color: var(--primary-color);\n color: white;\n border: none;\n border-radius: var(--border-radius);\n cursor: pointer;\n font-size: 1rem;\n transition: background-color 0.3s ease;\n}\n\nbutton:hover {\n background-color: darken(var(--primary-color), 10%);\n}\n\nfooter {\n text-align: center;\n margin-top: calc(var(--spacing) * 2);\n padding-top: var(--spacing);\n border-top: 1px solid #ddd;\n}\n\n@media (max-width: 768px) {\n h1 {\n font-size: 2rem;\n }\n}\n---script.js---\nfunction convertHTMLtoScroll(html) {\n // Convert HTML tags to Scroll format\n let scroll = html\n .replace(/<header>/g, 'header\\n')\n .replace(/<\\/header>/g, '\\nendHeader')\n .replace(/<main>/g, 'main\\n')\n .replace(/<\\/main>/g, '\\nendMain')\n .replace(/<footer>/g, 'footer\\n')\n .replace(/<\\/footer>/g, '\\nendFooter')\n .replace(/<h1>/g, 'h1 ')\n .replace(/<\\/h1>/g, '\\n')\n .replace(/<p>/g, 'p ')\n .replace(/<\\/p>/g, '\\n')\n .replace(/<a href=\"([^\"]+)\">([^<]+)<\\/a>/g, 'link \"$2\" \"$1\"')\n .replace(/<img src=\"([^\"]+)\" alt=\"([^\"]*)\" ?\\/?>/g, 'image \"$1\" \"$2\"')\n .replace(/<ul>/g, 'list\\n')\n .replace(/<\\/ul>/g, '\\nendList')\n .replace(/<li>/g, 'item ')\n .replace(/<\\/li>/g, '\\n')\n .replace(/<div>/g, 'div\\n')\n .replace(/<\\/div>/g, '\\nendDiv')\n .replace(/<section>/g, 'section\\n')\n .replace(/<\\/section>/g, '\\nendSection')\n .replace(/<article>/g, 'article\\n')\n .replace(/<\\/article>/g, '\\nendArticle')\n .replace(/<nav>/g, 'nav\\n')\n .replace(/<\\/nav>/g, '\\nendNav')\n .replace(/<button>/g, 'button ')\n .replace(/<\\/button>/g, '\\n')\n .replace(/<textarea>/g, 'textarea ')\n .replace(/<\\/textarea>/g, '\\n')\n .replace(/<input type=\"([^\"]+)\" placeholder=\"([^\"]+)\" ?\\/?>/g, 'input \"$1\" \"$2\"')\n .replace(/<br>/g, 'br')\n .replace(/<hr>/g, 'hr');\n\n // Remove any remaining HTML tags\n scroll = scroll.replace(/<[^>]+>/g, '');\n\n // Trim extra newlines\n scroll = scroll.replace(/\\n{3,}/g, '\\n\\n');\n\n return scroll.trim();\n}\n\ndocument.getElementById('convertButton').addEventListener('click', () => {\n const htmlInput = document.getElementById('htmlInput').value;\n const scrollOutput = convertHTMLtoScroll(htmlInput);\n document.getElementById('scrollOutput').value = scrollOutput;\n});\n---end---"
+ },
+ "logprobs": null,
+ "finish_reason": "stop"
+ }
+ ],
+ "usage": {
+ "prompt_tokens": 246,
+ "completion_tokens": 1211,
+ "total_tokens": 1457,
+ "prompt_cache_hit_tokens": 0,
+ "prompt_cache_miss_tokens": 246
+ },
+ "system_fingerprint": "fp_3a5770e1b4"
+}
\ No newline at end of file
diff --git a/readme.scroll b/readme.scroll
new file mode 100644
index 0000000..c3c6d44
--- /dev/null
+++ b/readme.scroll
@@ -0,0 +1,2 @@
+# html2scroll.scroll.pub
+Website generated by DeepSeek from prompt: a website with a large javascript function that converts HTML to Scroll
\ No newline at end of file
diff --git a/script.js b/script.js
new file mode 100644
index 0000000..9ee7d34
--- /dev/null
+++ b/script.js
@@ -0,0 +1,49 @@
+function convertHTMLtoScroll(html) {
+ // Convert HTML tags to Scroll format
+ let scroll = html
+ .replace(/<header>/g, 'header\n')
+ .replace(/<\/header>/g, '\nendHeader')
+ .replace(/<main>/g, 'main\n')
+ .replace(/<\/main>/g, '\nendMain')
+ .replace(/<footer>/g, 'footer\n')
+ .replace(/<\/footer>/g, '\nendFooter')
+ .replace(/<h1>/g, 'h1 ')
+ .replace(/<\/h1>/g, '\n')
+ .replace(/<p>/g, 'p ')
+ .replace(/<\/p>/g, '\n')
+ .replace(/<a href="([^"]+)">([^<]+)<\/a>/g, 'link "$2" "$1"')
+ .replace(/<img src="([^"]+)" alt="([^"]*)" ?\/?>/g, 'image "$1" "$2"')
+ .replace(/<ul>/g, 'list\n')
+ .replace(/<\/ul>/g, '\nendList')
+ .replace(/<li>/g, 'item ')
+ .replace(/<\/li>/g, '\n')
+ .replace(/<div>/g, 'div\n')
+ .replace(/<\/div>/g, '\nendDiv')
+ .replace(/<section>/g, 'section\n')
+ .replace(/<\/section>/g, '\nendSection')
+ .replace(/<article>/g, 'article\n')
+ .replace(/<\/article>/g, '\nendArticle')
+ .replace(/<nav>/g, 'nav\n')
+ .replace(/<\/nav>/g, '\nendNav')
+ .replace(/<button>/g, 'button ')
+ .replace(/<\/button>/g, '\n')
+ .replace(/<textarea>/g, 'textarea ')
+ .replace(/<\/textarea>/g, '\n')
+ .replace(/<input type="([^"]+)" placeholder="([^"]+)" ?\/?>/g, 'input "$1" "$2"')
+ .replace(/<br>/g, 'br')
+ .replace(/<hr>/g, 'hr');
+
+ // Remove any remaining HTML tags
+ scroll = scroll.replace(/<[^>]+>/g, '');
+
+ // Trim extra newlines
+ scroll = scroll.replace(/\n{3,}/g, '\n\n');
+
+ return scroll.trim();
+}
+
+document.getElementById('convertButton').addEventListener('click', () => {
+ const htmlInput = document.getElementById('htmlInput').value;
+ const scrollOutput = convertHTMLtoScroll(htmlInput);
+ document.getElementById('scrollOutput').value = scrollOutput;
+});
\ No newline at end of file
diff --git a/style.css b/style.css
new file mode 100644
index 0000000..c7a020a
--- /dev/null
+++ b/style.css
@@ -0,0 +1,72 @@
+:root {
+ --primary-color: #4a90e2;
+ --secondary-color: #f5f5f5;
+ --text-color: #333;
+ --border-radius: 8px;
+ --spacing: 1rem;
+}
+
+body {
+ font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
+ line-height: 1.6;
+ color: var(--text-color);
+ margin: 0;
+ padding: var(--spacing);
+ background-color: var(--secondary-color);
+}
+
+header {
+ text-align: center;
+ margin-bottom: calc(var(--spacing) * 2);
+}
+
+h1 {
+ color: var(--primary-color);
+ font-size: 2.5rem;
+}
+
+main {
+ max-width: 800px;
+ margin: 0 auto;
+}
+
+textarea {
+ width: 100%;
+ min-height: 150px;
+ padding: var(--spacing);
+ margin-bottom: var(--spacing);
+ border: 1px solid #ddd;
+ border-radius: var(--border-radius);
+ resize: vertical;
+ font-family: inherit;
+}
+
+button {
+ display: block;
+ width: 100%;
+ padding: calc(var(--spacing) / 2);
+ background-color: var(--primary-color);
+ color: white;
+ border: none;
+ border-radius: var(--border-radius);
+ cursor: pointer;
+ font-size: 1rem;
+ transition: background-color 0.3s ease;
+}
+
+button:hover {
+ background-color: darken(var(--primary-color), 10%);
+}
+
+footer {
+ text-align: center;
+ margin-top: calc(var(--spacing) * 2);
+ padding-top: var(--spacing);
+ border-top: 1px solid #ddd;
+}
+
+@media (max-width: 768px) {
+ h1 {
+ font-size: 2rem;
+ }
+}
\ No newline at end of file