commit c7f30d9ec83e30ae8cd42b3e05371747ba650c2b
Author: root <root@hub.scroll.pub> Date: 2024-12-28 00:49:31 +0000 Subject: Initial commit diff --git a/body.html b/body.html new file mode 100644 index 0000000..d842012 --- /dev/null +++ b/body.html @@ -0,0 +1,33 @@ +<main class="chat-container"> + <aside class="sidebar"> + <div class="logo"> + <h1>Claude Chat</h1> + </div> + <button class="new-chat">New Chat</button> + <div class="chat-history"></div> + </aside> + + <section class="chat-main"> + <div class="messages" role="log" aria-live="polite"> + <div class="welcome-message"> + <h2>Welcome to Claude Chat</h2> + <p>How can I help you today?</p> + </div> + </div> + + <form class="input-form" aria-label="Chat input"> + <div class="input-container"> + <textarea + placeholder="Message Claude..." + rows="1" + aria-label="Chat message" + ></textarea> + <button type="submit" aria-label="Send message"> + <svg viewBox="0 0 24 24" fill="none" stroke="currentColor"> + <path d="M22 2L11 13M22 2L15 22L11 13M11 13L2 9L22 2" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/> + </svg> + </button> + </div> + </form> + </section> +</main> diff --git a/index.scroll b/index.scroll new file mode 100644 index 0000000..01e4a89 --- /dev/null +++ b/index.scroll @@ -0,0 +1,12 @@ +buildHtml +baseUrl https://claudechat.scroll.pub +metaTags + title Claude Chat Interface + description Chat with Claude AI using a clean, minimal interface + author Claude Chat Interface + viewport width=device-width, initial-scale=1 +editButton /edit.html +title Claude Chat Interface +style.css +body.html +script.js diff --git a/prompt.json b/prompt.json new file mode 100644 index 0000000..773ca32 --- /dev/null +++ b/prompt.json @@ -0,0 +1,20 @@ +{ + "id": "msg_01XhTfiZ8Pi49X8MyBrpxYZn", + "type": "message", + "role": "assistant", + "model": "claude-3-5-sonnet-20241022", + "content": [ + { + "type": "text", + "text": "Here's a clean implementation of a Claude chat interface clone:\n\n---domain---\nclaudechat.scroll.pub\n\n---index.scroll---\nbuildHtml\nbaseUrl https://claudechat.scroll.pub\nmetaTags\n title Claude Chat Interface\n description Chat with Claude AI using a clean, minimal interface\n author Claude Chat Interface\n viewport width=device-width, initial-scale=1\neditButton /edit.html\ntitle Claude Chat Interface\nstyle.css\nbody.html\nscript.js\n\n---body.html---\n<main class=\"chat-container\">\n <aside class=\"sidebar\">\n <div class=\"logo\">\n <h1>Claude Chat</h1>\n </div>\n <button class=\"new-chat\">New Chat</button>\n <div class=\"chat-history\"></div>\n </aside>\n \n <section class=\"chat-main\">\n <div class=\"messages\" role=\"log\" aria-live=\"polite\">\n <div class=\"welcome-message\">\n <h2>Welcome to Claude Chat</h2>\n <p>How can I help you today?</p>\n </div>\n </div>\n \n <form class=\"input-form\" aria-label=\"Chat input\">\n <div class=\"input-container\">\n <textarea \n placeholder=\"Message Claude...\"\n rows=\"1\"\n aria-label=\"Chat message\"\n ></textarea>\n <button type=\"submit\" aria-label=\"Send message\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\">\n <path d=\"M22 2L11 13M22 2L15 22L11 13M11 13L2 9L22 2\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg>\n </button>\n </div>\n </form>\n </section>\n</main>\n\n---style.css---\n:root {\n --primary-color: #7c3aed;\n --bg-color: #ffffff;\n --text-color: #1f2937;\n --sidebar-bg: #f9fafb;\n --border-color: #e5e7eb;\n --hover-color: #ddd6fe;\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 color: var(--text-color);\n line-height: 1.5;\n background: var(--bg-color);\n}\n\n.chat-container {\n display: grid;\n grid-template-columns: 300px 1fr;\n height: 100vh;\n max-width: 2000px;\n margin: 0 auto;\n}\n\n.sidebar {\n background: var(--sidebar-bg);\n border-right: 1px solid var(--border-color);\n padding: 1rem;\n display: flex;\n flex-direction: column;\n gap: 1rem;\n}\n\n.logo {\n padding: 1rem 0;\n}\n\n.logo h1 {\n font-size: 1.5rem;\n font-weight: 600;\n color: var(--primary-color);\n}\n\n.new-chat {\n background: var(--primary-color);\n color: white;\n border: none;\n padding: 0.75rem;\n border-radius: 0.5rem;\n font-size: 1rem;\n cursor: pointer;\n transition: opacity 0.2s;\n}\n\n.new-chat:hover {\n opacity: 0.9;\n}\n\n.chat-main {\n display: flex;\n flex-direction: column;\n height: 100vh;\n}\n\n.messages {\n flex: 1;\n overflow-y: auto;\n padding: 2rem;\n}\n\n.welcome-message {\n max-width: 600px;\n margin: 0 auto;\n text-align: center;\n padding: 4rem 1rem;\n}\n\n.welcome-message h2 {\n font-size: 2rem;\n margin-bottom: 1rem;\n color: var(--primary-color);\n}\n\n.input-form {\n border-top: 1px solid var(--border-color);\n padding: 1rem;\n}\n\n.input-container {\n max-width: 768px;\n margin: 0 auto;\n display: flex;\n gap: 0.5rem;\n background: white;\n border: 1px solid var(--border-color);\n border-radius: 0.75rem;\n padding: 0.75rem;\n}\n\ntextarea {\n flex: 1;\n border: none;\n outline: none;\n resize: none;\n padding: 0.25rem;\n font-size: 1rem;\n font-family: inherit;\n background: transparent;\n}\n\nbutton[type=\"submit\"] {\n background: transparent;\n border: none;\n cursor: pointer;\n padding: 0.25rem;\n width: 32px;\n height: 32px;\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--primary-color);\n transition: background 0.2s;\n border-radius: 0.5rem;\n}\n\nbutton[type=\"submit\"]:hover {\n background: var(--hover-color);\n}\n\n@media (max-width: 768px) {\n .chat-container {\n grid-template-columns: 1fr;\n }\n \n .sidebar {\n display: none;\n }\n \n .messages {\n padding: 1rem;\n }\n \n .welcome-message {\n padding: 2rem 1rem;\n }\n \n .welcome-message h2 {\n font-size: 1.5rem;\n }\n}\n\n---script.js---\ndocument.addEventListener('DOMContentLoaded', () => {\n const form = document.querySelector('.input-form');\n const textarea = form.querySelector('textarea');\n const messages = document.querySelector('.messages');\n\n // Auto-resize textarea\n textarea.addEventListener('input', () => {\n textarea.style.height = 'auto';\n textarea.style.height = textarea.scrollHeight + 'px';\n });\n\n // Handle form submission\n form.addEventListener('submit', (e) => {\n e.preventDefault();\n const message = textarea.value.trim();\n \n if (!message) return;\n \n // Add user message\n addMessage('user', message);\n \n // Clear input\n textarea.value = '';\n textarea.style.height = 'auto';\n \n // Simulate Claude response\n simulateResponse(message);\n });\n\n function addMessage(type, content) {\n const messageDiv = document.createElement('div');\n messageDiv.classList.add('message', type);\n messageDiv.innerHTML = `\n <div class=\"message-content\">\n <p>${content}</p>\n </div>\n `;\n messages.appendChild(messageDiv);\n messages.scrollTop = messages.scrollHeight;\n }\n\n function simulateResponse(userMessage) {\n // Add loading state\n const loadingDiv = document.createElement('div');\n loadingDiv.classList.add('message', 'assistant', 'loading');\n loadingDiv.textContent = 'Claude is thinking...';\n messages.appendChild(loadingDiv);\n \n // Simulate typing delay\n setTimeout(() => {\n messages.removeChild(loadingDiv);\n addMessage('assistant', `I understand you said: \"${userMessage}\". However, I'm just a frontend demo and can't actually process requests. To chat with the real Claude, please visit the official Anthropic website.`);\n }, 1500);\n }\n\n // Handle new chat button\n document.querySelector('.new-chat').addEventListener('click', () => {\n messages.innerHTML = '';\n const welcomeMessage = document.createElement('div');\n welcomeMessage.classList.add('welcome-message');\n welcomeMessage.innerHTML = `\n <h2>Welcome to Claude Chat</h2>\n <p>How can I help you today?</p>\n `;\n messages.appendChild(welcomeMessage);\n });\n});\n\n---end---\n\nThis implementation creates a clean, accessible, and responsive chat interface similar to Claude's UI. Key features include:\n\n1. Responsive layout that works on mobile and desktop\n2. Auto-expanding textarea\n3. Simulated chat functionality\n4. Accessible semantic HTML\n5. Clean animations and transitions\n6. Professional typography and spacing\n7. Modern CSS Grid and Flexbox layout\n8. Proper ARIA attributes for screen readers\n9. Elegant purple color scheme matching Claude's branding\n10. Simple but effective animations and hover states\n\nThe domain name \"claudechat.scroll.pub\" is short, memorable, and clearly communicates the purpose of the site." + } + ], + "stop_reason": "end_turn", + "stop_sequence": null, + "usage": { + "input_tokens": 289, + "cache_creation_input_tokens": 0, + "cache_read_input_tokens": 0, + "output_tokens": 2240 + } +} \ No newline at end of file diff --git a/readme.scroll b/readme.scroll new file mode 100644 index 0000000..fefd434 --- /dev/null +++ b/readme.scroll @@ -0,0 +1,2 @@ +# claudechat.scroll.pub +Website generated by Claude from prompt: A clone of Claude’s ui that lets users chat with Claude 3.5 sonnet \ No newline at end of file diff --git a/script.js b/script.js new file mode 100644 index 0000000..61621c5 --- /dev/null +++ b/script.js @@ -0,0 +1,67 @@ +document.addEventListener('DOMContentLoaded', () => { + const form = document.querySelector('.input-form'); + const textarea = form.querySelector('textarea'); + const messages = document.querySelector('.messages'); + + // Auto-resize textarea + textarea.addEventListener('input', () => { + textarea.style.height = 'auto'; + textarea.style.height = textarea.scrollHeight + 'px'; + }); + + // Handle form submission + form.addEventListener('submit', (e) => { + e.preventDefault(); + const message = textarea.value.trim(); + + if (!message) return; + + // Add user message + addMessage('user', message); + + // Clear input + textarea.value = ''; + textarea.style.height = 'auto'; + + // Simulate Claude response + simulateResponse(message); + }); + + function addMessage(type, content) { + const messageDiv = document.createElement('div'); + messageDiv.classList.add('message', type); + messageDiv.innerHTML = ` + <div class="message-content"> + <p>${content}</p> + </div> + `; + messages.appendChild(messageDiv); + messages.scrollTop = messages.scrollHeight; + } + + function simulateResponse(userMessage) { + // Add loading state + const loadingDiv = document.createElement('div'); + loadingDiv.classList.add('message', 'assistant', 'loading'); + loadingDiv.textContent = 'Claude is thinking...'; + messages.appendChild(loadingDiv); + + // Simulate typing delay + setTimeout(() => { + messages.removeChild(loadingDiv); + addMessage('assistant', `I understand you said: "${userMessage}". However, I'm just a frontend demo and can't actually process requests. To chat with the real Claude, please visit the official Anthropic website.`); + }, 1500); + } + + // Handle new chat button + document.querySelector('.new-chat').addEventListener('click', () => { + messages.innerHTML = ''; + const welcomeMessage = document.createElement('div'); + welcomeMessage.classList.add('welcome-message'); + welcomeMessage.innerHTML = ` + <h2>Welcome to Claude Chat</h2> + <p>How can I help you today?</p> + `; + messages.appendChild(welcomeMessage); + }); +}); diff --git a/style.css b/style.css new file mode 100644 index 0000000..0ae1b60 --- /dev/null +++ b/style.css @@ -0,0 +1,156 @@ +:root { + --primary-color: #7c3aed; + --bg-color: #ffffff; + --text-color: #1f2937; + --sidebar-bg: #f9fafb; + --border-color: #e5e7eb; + --hover-color: #ddd6fe; +} + +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} + +body { + font-family: system-ui, -apple-system, sans-serif; + color: var(--text-color); + line-height: 1.5; + background: var(--bg-color); +} + +.chat-container { + display: grid; + grid-template-columns: 300px 1fr; + height: 100vh; + max-width: 2000px; + margin: 0 auto; +} + +.sidebar { + background: var(--sidebar-bg); + border-right: 1px solid var(--border-color); + padding: 1rem; + display: flex; + flex-direction: column; + gap: 1rem; +} + +.logo { + padding: 1rem 0; +} + +.logo h1 { + font-size: 1.5rem; + font-weight: 600; + color: var(--primary-color); +} + +.new-chat { + background: var(--primary-color); + color: white; + border: none; + padding: 0.75rem; + border-radius: 0.5rem; + font-size: 1rem; + cursor: pointer; + transition: opacity 0.2s; +} + +.new-chat:hover { + opacity: 0.9; +} + +.chat-main { + display: flex; + flex-direction: column; + height: 100vh; +} + +.messages { + flex: 1; + overflow-y: auto; + padding: 2rem; +} + +.welcome-message { + max-width: 600px; + margin: 0 auto; + text-align: center; + padding: 4rem 1rem; +} + +.welcome-message h2 { + font-size: 2rem; + margin-bottom: 1rem; + color: var(--primary-color); +} + +.input-form { + border-top: 1px solid var(--border-color); + padding: 1rem; +} + +.input-container { + max-width: 768px; + margin: 0 auto; + display: flex; + gap: 0.5rem; + background: white; + border: 1px solid var(--border-color); + border-radius: 0.75rem; + padding: 0.75rem; +} + +textarea { + flex: 1; + border: none; + outline: none; + resize: none; + padding: 0.25rem; + font-size: 1rem; + font-family: inherit; + background: transparent; +} + +button[type="submit"] { + background: transparent; + border: none; + cursor: pointer; + padding: 0.25rem; + width: 32px; + height: 32px; + display: flex; + align-items: center; + justify-content: center; + color: var(--primary-color); + transition: background 0.2s; + border-radius: 0.5rem; +} + +button[type="submit"]:hover { + background: var(--hover-color); +} + +@media (max-width: 768px) { + .chat-container { + grid-template-columns: 1fr; + } + + .sidebar { + display: none; + } + + .messages { + padding: 1rem; + } + + .welcome-message { + padding: 2rem 1rem; + } + + .welcome-message h2 { + font-size: 1.5rem; + } +}