| | <!DOCTYPE html> |
| | <html lang="vi"> |
| | <head> |
| | <meta charset="UTF-8" /> |
| | <meta name="viewport" content="width=device-width, initial-scale=1" /> |
| | <title>AI Tư Vấn & Chăm Sóc Khách Hàng</title> |
| | <style> |
| | :root { |
| | --bg-light: #f5f7fa; |
| | --container-light: #ffffff; |
| | --text-light: #333; |
| | --bubble-light: #f1f0f0; |
| | --me-light: #0084ff; |
| | |
| | --bg-dark: #121212; |
| | --container-dark: #1e1e1e; |
| | --text-dark: #e0e0e0; |
| | --bubble-dark: #2c2c2c; |
| | --me-dark: #3498db; |
| | } |
| | |
| | body { |
| | font-family: Arial, sans-serif; |
| | background-color: var(--bg-light); |
| | color: var(--text-light); |
| | padding: 30px; |
| | transition: all 0.3s ease; |
| | } |
| | |
| | body.dark { |
| | background-color: var(--bg-dark); |
| | color: var(--text-dark); |
| | } |
| | |
| | #container { |
| | max-width: 800px; |
| | margin: auto; |
| | background-color: var(--container-light); |
| | border-radius: 12px; |
| | padding: 30px; |
| | box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); |
| | transition: background 0.3s ease; |
| | } |
| | |
| | body.dark #container { |
| | background-color: var(--container-dark); |
| | } |
| | |
| | h1 { |
| | text-align: center; |
| | margin-bottom: 20px; |
| | } |
| | |
| | #toggleMode { |
| | background-color: #3498db; |
| | border: none; |
| | color: white; |
| | padding: 10px 20px; |
| | border-radius: 8px; |
| | cursor: pointer; |
| | float: right; |
| | margin-bottom: 20px; |
| | } |
| | |
| | #Output { |
| | display: flex; |
| | flex-direction: column; |
| | gap: 10px; |
| | max-height: 400px; |
| | overflow-y: auto; |
| | padding: 15px; |
| | border-radius: 8px; |
| | background: var(--bubble-light); |
| | transition: background 0.3s ease; |
| | } |
| | |
| | body.dark #Output { |
| | background: var(--bubble-dark); |
| | } |
| | |
| | .message { |
| | display: flex; |
| | max-width: 80%; |
| | } |
| | |
| | .message.me { |
| | align-self: flex-end; |
| | } |
| | |
| | .message.other { |
| | align-self: flex-start; |
| | } |
| | |
| | .bubble { |
| | padding: 10px 15px; |
| | border-radius: 16px; |
| | max-width: 100%; |
| | word-wrap: break-word; |
| | opacity: 0; |
| | transform: translateY(10px); |
| | animation: fadeInUp 0.4s forwards; |
| | } |
| | |
| | .message.me .bubble { |
| | background-color: var(--me-light); |
| | color: white; |
| | border-bottom-right-radius: 0; |
| | } |
| | |
| | body.dark .message.me .bubble { |
| | background-color: var(--me-dark); |
| | } |
| | |
| | .message.other .bubble { |
| | background-color: #ffffff; |
| | color: #333; |
| | border: 1px solid #dfe6e9; |
| | border-left: 4px solid #3498db; |
| | box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05); |
| | } |
| | |
| | body.dark .message.other .bubble { |
| | background-color: #2c3e50; |
| | color: #ecf0f1; |
| | } |
| | |
| | #Input { |
| | width: 100%; |
| | padding: 15px; |
| | font-size: 16px; |
| | border: 1px solid #ccc; |
| | border-radius: 8px; |
| | margin-bottom: 15px; |
| | } |
| | |
| | #sendButton { |
| | padding: 10px 20px; |
| | background-color: #3498db; |
| | color: white; |
| | border: none; |
| | font-size: 16px; |
| | border-radius: 8px; |
| | cursor: pointer; |
| | transition: background-color 0.3s ease; |
| | } |
| | |
| | #sendButton:hover { |
| | background-color: #2980b9; |
| | } |
| | |
| | @keyframes fadeInUp { |
| | to { |
| | opacity: 1; |
| | transform: translateY(0); |
| | } |
| | } |
| | .dive { |
| | background-color: #f0f8ff; |
| | border: 2px solid #00aaff; |
| | padding: 20px; |
| | margin: 30px; |
| | font-size: 18px; |
| | text-align: center; |
| | color: #333; |
| | border-radius: 8px; |
| | } |
| | </style> |
| | </head> |
| | <body> |
| | <div id="container"> |
| | <button id="toggleMode">🌗 Chuyển chế độ</button> |
| | <h1>AI tư vấn, chăm sóc khách hàng</h1> |
| |
|
| | <div id="Output"></div> |
| |
|
| | <label for="Input">Nhập câu hỏi vào đây:</label> |
| | <input id="Input" placeholder="VD: Apple là gì?" /> |
| | <button id="sendButton" onclick="askGemini()">Gửi</button> |
| | </div> |
| | <div class="dive"> |
| | <a href="index.html">Nhấn vào đây để xem bản tiếng anh</a> |
| | </div> |
| |
|
| | <script> |
| | document.getElementById("toggleMode").addEventListener("click", function () { |
| | document.body.classList.toggle("dark"); |
| | }); |
| | |
| | function askGemini() { |
| | const url = `https://generativelanguage.googleapis.com/v1beta/models/gemini-2.0-flash:generateContent?key=AIzaSyBNxw7SIRHBzm7ALF0YTJ87_K6w1_Qc_74`; |
| | const Inputs = document.getElementById("Input").value.trim(); |
| | if (Inputs === "") return; |
| | |
| | appendMessage(Inputs, true); |
| | |
| | const loadingMsg = appendMessage("Đang trả lời...", false); |
| | |
| | const body = { |
| | contents: [ |
| | { |
| | parts: [ |
| | { |
| | text: `Bạn tên là Tèo ở VN hãy tưởng tượng bạn là dân đa cấp, bán hàng chuyên nghiệp về thiết bị điện tử; một ngày bán hơn triệu đơn hãy trả lời câu hỏi sau: ${Inputs}`, |
| | } |
| | ] |
| | } |
| | ] |
| | }; |
| | |
| | fetch(url, { |
| | method: "POST", |
| | headers: { |
| | "Content-Type": "application/json", |
| | }, |
| | body: JSON.stringify(body), |
| | }) |
| | .then((res) => res.json()) |
| | .then((data) => { |
| | const output = data.candidates[0].content.parts[0].text; |
| | loadingMsg.querySelector(".bubble").textContent = "🤖 " + output; |
| | document.getElementById("Input").value = ""; |
| | }) |
| | .catch((err) => { |
| | console.error(err); |
| | loadingMsg.querySelector(".bubble").textContent = |
| | "Lỗi khi gọi API Gemini."; |
| | }); |
| | } |
| | |
| | document.getElementById("Input").addEventListener("keydown", function (event) { |
| | if (event.key === "Enter") { |
| | askGemini(); |
| | } |
| | }); |
| | |
| | function appendMessage(content, isMe) { |
| | const chatBox = document.getElementById("Output"); |
| | |
| | const messageDiv = document.createElement("div"); |
| | messageDiv.className = `message ${isMe ? "me" : "other"}`; |
| | |
| | const bubble = document.createElement("div"); |
| | bubble.className = "bubble"; |
| | bubble.textContent = content; |
| | |
| | messageDiv.appendChild(bubble); |
| | chatBox.appendChild(messageDiv); |
| | chatBox.scrollTop = chatBox.scrollHeight; |
| | return messageDiv; |
| | } |
| | </script> |
| | </body> |
| | </html> |
| |
|