-
Notifications
You must be signed in to change notification settings - Fork 740
/
chatt.js
158 lines (134 loc) · 5.3 KB
/
chatt.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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
const chatMessages = document.getElementById('chat-messages');
const messageInput = document.getElementById('message-input');
const sendButton = document.getElementById('send-button');
const mediaButton = document.getElementById('media-button');
// Sample chat data
const chatData = [
{ username: 'John', message: 'Hello everyone!', timestamp: '10:00 AM', dp: './assets/images/avatar2.jpg' },
{ username: 'Ritu', message: 'Hi John!', timestamp: '10:01 AM', dp: './assets/images/avatar1.jpg' },
{ username: 'Admin', message: 'Welcome to SwapReads Community Chat!', timestamp: '10:02 AM', dp: './assets/images/avatar5.jpg' },
];
// Display initial chat messages
chatData.forEach((message) => {
const messageHTML = `
<div class="message ${message.username === 'You' ? 'right' : 'left'}">
<img src="${message.dp}" class="dp">
<span class="username">${message.username}:</span>
<span class="message-text">${message.message}</span>
<span class="timestamp">${message.timestamp}</span>
</div>
`;
chatMessages.innerHTML += messageHTML;
});
// Send message functionality
sendButton.addEventListener('click', () => {
const message = messageInput.value.trim();
if (message) {
const messageHTML = `
<div class="message right">
<span class="username"></span>
<span class="message-text">${message}</span>
<span class="timestamp">${formatTime(new Date())}</span>
</div>
`;
chatMessages.innerHTML += messageHTML;
messageInput.value = '';
chatMessages.scrollTop = chatMessages.scrollHeight;
saveMessageToLocalStorage('You', message);
}
});
// Format time to HH:MM
function formatTime(date) {
const hours = date.getHours().toString().padStart(2, '0');
const minutes = date.getMinutes().toString().padStart(2, '0');
return `${hours}:${minutes}`;
}
// Media button functionality
mediaButton.addEventListener('click', () => {
const mediaInput = document.createElement('input');
mediaInput.type = 'file';
mediaInput.accept = 'image/*, video/*';
mediaInput.addEventListener('change', (e) => {
const file = mediaInput.files[0];
const mediaPreview = document.createElement('div');
mediaPreview.className = 'media-preview';
if (file.type.startsWith('image/')) {
mediaPreview.innerHTML = `<img src="${URL.createObjectURL(file)}">`;
} else {
mediaPreview.innerHTML = `<video controls><source src="${URL.createObjectURL(file)}"></video>`;
}
chatMessages.appendChild(mediaPreview);
saveMediaToLocalStorage(file);
});
mediaInput.click();
});
// Save message to local storage
function saveMessageToLocalStorage(username, message) {
const messages = JSON.parse(localStorage.getItem('messages')) || [];
messages.push({ username, message, timestamp: new Date().toLocaleTimeString() });
localStorage.setItem('messages', JSON.stringify(messages));
}
// Save media to local storage
function saveMediaToLocalStorage(file) {
const media = JSON.parse(localStorage.getItem('media')) || [];
media.push(file);
localStorage.setItem('media', JSON.stringify(media));
}
// Load messages from local storage
function loadMessagesFromLocalStorage() {
const messages = JSON.parse(localStorage.getItem('messages')) || [];
messages.forEach((message) => {
const messageHTML = `
<div class="message ${message.username === 'You' ? 'right' : 'left'}">
<span class="username">${message.username}:</span>
<span class="message-text">${message.message}</span>
<span class="timestamp">${message.timestamp}</span>
</div>
`;
chatMessages.innerHTML += messageHTML;
});
}
// Call the function to load messages when the page loads
loadMessagesFromLocalStorage();
// Coordinates for the cursor
const coords = { x: 0, y: 0 };
const circles = document.querySelectorAll(".circle");
// Colors for the circles
const colors = [
"#ffb56b", "#fdaf69", "#f89d63", "#f59761", "#ef865e", "#ec805d",
"#e36e5c", "#df685c", "#d5585c", "#d1525c", "#c5415d", "#c03b5d",
"#b22c5e", "#ac265e", "#9c155f", "#950f5f", "#830060", "#7c0060",
"#680060", "#60005f", "#48005f", "#3d005e"
];
// Assign colors and initial position to each circle
circles.forEach(function (circle, index) {
circle.x = 0;
circle.y = 0;
circle.style.backgroundColor = colors[index % colors.length];
});
// Update the coordinates when the mouse moves
window.addEventListener("mousemove", function (e) {
coords.x = e.clientX;
coords.y = e.clientY;
});
// Animation function to move the circles
function animateCircles() {
let x = coords.x;
let y = coords.y;
circles.forEach(function (circle, index) {
// Update the position and scale of each circle
circle.style.left = x - 12 + "px";
circle.style.top = y - 12 + "px";
circle.style.scale = (circles.length - index) / circles.length;
circle.x = x;
circle.y = y;
// Get the next circle in the sequence
const nextCircle = circles[index + 1] || circles[0];
x += (nextCircle.x - x) * 0.15;
y += (nextCircle.y - y) * 0.15;
});
// Repeat the animation
requestAnimationFrame(animateCircles);
}
// Start the animation
animateCircles();