html
html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>WhatsApp Clone</title>
<link rel="stylesheet" href="styles.css">
<script defer src="script.js"></script>
</head>
<body>
<div class="container">
<div class="sidebar">
<div class="header">
<h2>WhatsApp</h2>
<input type="text" id="search" placeholder="Search Chat...">
<button id="toggleTheme">🌙</button>
</div>
<div class="chat-list" id="chatList">
</div>
</div>
<div class="chat-area">
<div class="chat-header">
Enter to Rename, Shift+Enter to Preview
css
css
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
body {
overflow-x: hidden;
}
@media (max-width: 768px) {
.container {
flex-direction: column;
}
.sidebar {
width: 100%;
height: 80%;
}
.chat-area {
width: 100%;
height: 40%;
}
}
body {
Enter to Rename, Shift+Enter to Preview
js
js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
document.addEventListener("DOMContentLoaded", () => {
const chatList = document.getElementById("chatList");
const messagesDiv = document.getElementById("messages");
const messageInput = document.getElementById("messageInput");
const sendMessageBtn = document.getElementById("sendMessage");
const toggleThemeBtn = document.getElementById("toggleTheme");
const newChatBtn = document.getElementById("newChat");
let darkMode = false;
let chats = [
{ name: "Papa", lastMessage: "How are you?", time: "8:24 PM" },
{ name: "Mummy ❤️", lastMessage: "Photo", time: "1:30 PM" },
{ name: "Bhai", lastMessage: "Check this GitHub repo", time: "Yesterday" }
];
function renderChats() {
chatList.innerHTML = "";
chats.forEach(chat => {
let chatItem = document.createElement("div");
chatItem.classList.add("chat-item");
chatItem.innerHTML = `
<img src="assets/profile.png" alt="Profile">
<div>
<h4>${chat.name}</h4>
<p>${chat.lastMessage}</p>
</div>
<span>${chat.time}</span>
Enter to Rename, Shift+Enter to Preview
BROWSER
Console
Run