chat
this is code for basic chat application without any user login
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
*{box-sizing: border-box;}
body{
margin: 0;background-image: linear-gradient(45deg ,rgb(255, 208, 0) 50%,rgb(1, 163, 1) 50%);
height: 100vh;background-attachment: fixed;
}
.maindiv{
height: auto;display: flex;flex-direction: column;align-items: center;
max-width: 1200px;position: relative;left: 50%;transform: translate(-50% , 0 );
}
.link{
height: 60px;width: 95%;background-color: white;border-radius: 4px;margin: 15px 0 10px 0 ;
}
.upload{
height: auto;width: 95%;background-color: whitesmoke;border-radius: 4px;margin: 0 0 10px 0;
}
.uploaded{
height: 3500px;width: 97%;margin: 1.5%;background-color: rgb(223, 223, 223);border-radius: 2px;padding: 10px;
}
.data{
height: 60px;width: 98%;margin: 1%;background-color: rgb(76, 123, 177);border-radius: 4px;
display: flex;justify-content: space-evenly;align-items: center;padding: 5px;
position: sticky;bottom: 10px;
}
.fromdevice{
height: 40px;width: 40px;border-radius: 50%;background-color: rgb(255, 255, 255,1);
display: flex;justify-content: center;align-items: center;
}
.send{
height: 40px;width: 40px;border-radius: 50%;background-color: rgba(255, 255,255, 1);
display: flex;justify-content: center;align-items: center;
}
#txt{
height: 40px;width: 60%;background-color: white;color: black;border: none;outline: none;
border-radius: 5px;margin: 5px;
}
#fromdevicefiles{display: none;}
img{width: 25px;}
.uploadedmsg{width: 60%;margin: 10px 10px 10px 10px;background: chocolate;}
.chat{width: 50%;margin: 5px;background: chocolate;padding: 10px ;border-radius: 10px;}
.chat2{width: 50%;margin: 5px;background: rgb(20, 228, 48);padding: 10px ;border-radius: 10px;}
</style>
</head>
<body>
<div class="maindiv">
<div class="link"></div>
<div class="upload">
<div class="uploaded"></div>
<div class="data">
<label class="fromdevice" for="fromdevicefiles"><input type="file" id="fromdevicefiles" multiple><img alt="uploadfiles" id="upload" src="https://img.icons8.com/external-tal-revivo-shadow-tal-revivo/96/000000/external-upload-processing-bar-with-upwards-arrow-logotype-upload-shadow-tal-revivo.png"/></label>
<input type="text" id="txt">
<div class="send"><img alt="send" src=""></div>
</div>
</div>
</div>
</div>
<script>
document.getElementById("fromdevicefiles").addEventListener('change' ,()=>{
console.log( document.getElementById("fromdevicefiles").value)
})
</script>
<script type="module">
import { initializeApp } from "https://www.gstatic.com/firebasejs/9.5.0/firebase-app.js";
import { getFirestore,doc, getDoc,addDoc, collection,
getDocs, onSnapshot, query, where,setDoc, orderBy, limit , Timestamp
} from "https://www.gstatic.com/firebasejs/9.5.0/firebase-firestore.js";
import { getStorage, ref, uploadBytes , getDownloadURL } from "https://www.gstatic.com/firebasejs/9.5.0/firebase-storage.js";
//Replace firebaseConfig with your firebase database config
const firebaseConfig = {
apiKey: "",
authDomain: "",
databaseURL:"",
projectId: "shop",
storageBucket:"",
messagingSenderId: "",
appId: "",
measurementId: ""
}; const app = initializeApp(firebaseConfig);
const db = getFirestore(app);
document.getElementsByClassName("send")[0].addEventListener('click' ,async function(){
var time = (new Date().getTime())
const docRef = await addDoc(collection(db, "group+messages"), {
value:document.getElementById("txt").value,
sentby:"vinay",
time:time
});
document.getElementById("txt").value = "";
})
const q = query(collection(db, "group+messages") , orderBy("time" , "asc"));
const unsubscribe = onSnapshot(q, (snapshot) => {
snapshot.docChanges().forEach((change) => {
if (change.type === "added") {
//console.log("New city: ", change.doc.data());
if (change.doc.data().sentby == "vinay") {
var msgdiv = document.createElement("div")
msgdiv.className = "chat2"
msgdiv.innerHTML = change.doc.data().value
document.getElementsByClassName("uploaded")[0].appendChild(msgdiv)
}else{
var msgdiv = document.createElement("div")
msgdiv.className = "chat"
msgdiv.innerHTML = change.doc.data().value
document.getElementsByClassName("uploaded")[0].appendChild(msgdiv)
}
}
if (change.type === "modified") {
console.log("Modified city: ", change.doc.data());
}
if (change.type === "removed") {
console.log("Removed city: ", change.doc.data());
}
});
});
</script>
</body>
</html>
Comments
Post a Comment