srsViewer/public/chat.html
creations a3b03fdec4
All checks were successful
Code quality checks / biome (push) Successful in 22s
add chat :p
2025-06-08 19:57:50 -04:00

79 lines
3.2 KiB
HTML

<!DOCTYPE html>
<html lang="en" data-theme="dark">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Chat</title>
<link rel="stylesheet" href="/public/css/style.css">
<link rel="stylesheet" href="/public/css/chat.css">
<script type="module" src="/public/js/chat.js" defer></script>
<meta name="color-scheme" content="dark">
</head>
<body>
<div class="chat-widget">
<div class="chat-header">
<div class="username-section">
<input type="text" id="usernameInput" class="username-input" placeholder="Enter your name..."
maxlength="20" required>
<div class="settings-container">
<button type="button" class="settings-btn" id="settingsBtn" title="Settings">
<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor"
stroke-width="2">
<path
d="M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z">
</path>
<circle cx="12" cy="12" r="3"></circle>
</svg>
</button>
<div class="settings-dropdown" id="settingsDropdown">
<h4>Chat Settings</h4>
<div class="setting-item">
<span class="setting-label">Show Images</span>
<label class="setting-toggle">
<input type="checkbox" id="imageToggle" checked>
<span class="toggle-slider"></span>
</label>
</div>
<div class="setting-item">
<span class="setting-label">24-Hour Time</span>
<label class="setting-toggle">
<input type="checkbox" id="timeToggle" checked>
<span class="toggle-slider"></span>
</label>
</div>
</div>
</div>
</div>
</div>
<div class="chat-messages" id="chatMessages">
<div id="loadingState" class="loading-state">
<div class="spinner"></div>
<p>Connecting...</p>
</div>
<div id="errorState" class="error-state" style="display: none;">
<p id="errorMessage">Connection failed</p>
<button id="retryBtn" class="retry-btn">Retry</button>
</div>
<div id="messagesContainer" class="messages-container" style="display: none;"></div>
<div id="emptyState" class="empty-state" style="display: none;">
<p>No messages yet</p>
</div>
</div>
<form class="chat-input-form" id="chatForm">
<div class="message-row">
<input type="text" id="messageInput" class="message-input" placeholder="Type your message..."
maxlength="500" required>
<button type="submit" class="send-btn" id="sendBtn" disabled>
<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
<path d="m3 3 3 9-3 9 19-9Z"></path>
<path d="m6 12 16 0"></path>
</svg>
</button>
</div>
</form>
</div>
</body>
</html>