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

Popular posts from this blog