открыть приватное окно чата по нажатию кнопки - PullRequest
0 голосов
/ 16 ноября 2018

Я пытаюсь реализовать один-на-один чат между двумя пользователями, используя node js и socket.io. Я пытаюсь открыть chatroom по щелчку find friend button и username вводится в текстовое поле chatGroupName. После нажатия на кнопку он проверит, «пользователь» ли он «онлайн», который он получит из массива «onlineusers», тогда я хочу показать окно чата с обоими «пользовательскими» сообщениями приватно. Извините за грязный код.

серверный скрипт -> app.js

var express = require('express');
var app = express();
var server = require('http').createServer(app);
const io = require('socket.io').listen(server);
var bodyParser = require('body-parser');
var nsp = io.of('/my-namespace');
var PORT = 8000;
users = [];
connections = [];
onlineusers = [];
rooms = [];
app.use(bodyParser.urlencoded({
    extended: true
}));

app.set('view engine', 'ejs')
app.use(express.static('public'))

app.get('/chat', (req, res) => {

    res.render("chat") //pick the index.ejs file 
})

io.on('connection', (socket) => {
    console.log('New user connected!')
    // console.log(socket.client.id)
    connections.push(socket);
    console.log('Connected : %s sockets connected', connections.length)


    //disconnect user
    socket.on('disconnect', function (data) {
        // if (!socket.username) return;
        users.splice(users.indexOf(socket.username), 1);
        // updateUsernames();
        connections.splice(connections.indexOf(socket), 1);
        console.log('Disconnected : %s sockets connected', connections.length)
    });

    //////////////////////////////////////////////////////////////////////////
    socket.on('find_friend',function(data){
        for(var i = 1; i <= onlineusers.length; i++){
           // console.log(onlineusers.length)
            console.log( "onlineusers",onlineusers[i])

            if(data == onlineusers[i] && i < onlineusers.length ){
               // console.log(true)
                socket.emit('chat',onlineusers[i]);
            }
            else {
                console.log('user not online')
            }
        }  
    })
    /////////////////////////////////////////////////////////////////////////////////

    //new message
    socket.on('new_message', (data) => {

        io.sockets.emit('new_message', {
            message: JSON.stringify(data),
            username: socket.username
        });
    })


    //broadcast message
    socket.on("typing", (data) => {
        socket.broadcast.emit('typing', {
            username: socket.username
        });
    })


    // new user
    socket.on('new_user', (data, callback) => {

        callback(true);
        socket.username = data;
        users.push({
             id: socket.id,
             username: socket.username
        });
        onlineusers.push(data);
        //console.log(onlineusers)
        updateUsernames();
    })

    //update user list function
    function updateUsernames() {
         io.sockets.emit('get_users', onlineusers);
    }

//create a new room
    socket.on('new_room', (data, callback) => {
        callback(true);
        rooms.push(data);
        socket.join(data);
        socket.emit("sucess","you join the room");
        //console.log(users)
        updateRoomNames();
    })

    //update user list function
    function updateRoomNames() {
         io.sockets.emit('get_room', rooms);
    }



})


//server listen to the port
server.listen(PORT, function () {
    console.log('server is connected to the port : ' + PORT)
})

клиентский скрипт -> chat.js

$(function () {
    //make connection
    console.log("hello")
    var socket = io() //.connect('http://localhost:8000')
    //buttons and inputs
    var message = $("#message")
    var username = $("#username")
    var send_message = $("#send_message")
    var login = $('#Login')
    var chatroom = $("#chatroom")
    var feedback = $("#feedback")
    var userForm = $("#userForm")
    var userFormArea = $("#userFormArea")
    var messageArea = $("messageArea")
    var users = $("#users")
    var rooms = $('#myDropdown')
    var chatGroupName = $("#chatGroupName")
    var createChatGroup = $("#createChatGroup")
    var joinChatGroup = $("#joinChatGroup")
    var friendName = $('#friendName')
    var upper_name = $('#upper_name')

    //Emit message
    send_message.click(function () {
        socket.emit('new_message', {
            message: message.val()
        })
        message.val(''); //empty the message variable
    })

    socket.emit('create', 'room1');


    //new user
    login.click(function () {
        socket.emit('new_user', username.val(), function (data) {
            console.log(data)
            if (data) {
                userFormArea.hide();
                // console.log("hide userform")
                document.getElementById('messageArea').style.display = "block";
                //  console.log('show message area')
            }
        })
        username.val(''); //empty the message variable
    })

    //create chat group
    createChatGroup.click(function () {
        socket.emit('new_room', chatGroupName.val(), function (data) {
            console.log(data)
            if (data) {
                document.getElementById('messageArea').style.display = "block";
                // socket.emit('create', chatGroupName.val())
                //  console.log('show message area')
            }
        })
        chatGroupName.val(''); //empty the message variable
    })
    joinChatGroup.click(function () {
        document.getElementById("myDropdown").classList.toggle("show");
        window.onclick = function (event) {
            if (!event.target.matches('.dropbtn')) {

                var dropdowns = document.getElementsByClassName("dropdown-content");
                var i;
                for (i = 0; i < dropdowns.length; i++) {
                    var openDropdown = dropdowns[i];
                    if (openDropdown.classList.contains('show')) {
                        openDropdown.classList.remove('show');
                    }
                }
            }
        }

    })
     //here is the problem code
    ///////////////////////////////////*TEST1* */
    friendName.click(function () {
        socket.emit('find_friend', chatGroupName.val())
    })
     //
    socket.on('chat', (data) => {
        console.log(data)
        // document.getElementById('messageArea').style.display = "block";
        if (data) {
            var html = '<h1 class = "upper_name">' + data + '</h1>';

           // socket.on(data).emit(document.getElementById('messageArea').style.display = "block");
            upper_name.html(html);
            document.getElementById('upper_name').style.display = "block";
        }
    })


    //////////////////////////////////TEST 1 END///
    // List of users
    socket.on('get_users', function (data) {
        var html = '';
        for (i = 0; i < data.length; i++) {
            html += '<li class = "list-group-item">' + data[i] + '</li>';
        }
        users.html(html);
    })

    //list of rooms
    socket.on('get_room', function (data) {
        var html = '';
        for (i = 1; i <= data.length; i++) {
            html += '<a class = "list-group-item">' + data[i] + '</a>';
        }
        rooms.html(html);
    })

    //Listen on new_message
    socket.on("new_message", (data) => {
        feedback.html('');
        message.val('');
        chatroom.append("<p class='message'>" + data.username + ": " + data.message + "</p>")
    })

    //Emit typing
    message.bind("keypress", () => {
        socket.emit('typing', username)
    })

    //Listen on typing
    socket.on('typing', (data) => {
        feedback.html("<p><i>" + data.username + " is typing a message..." + "</i></p>")
    })



    //socket.emit('login',{userId:'YourUserID'});
});



/************************************************************* */

мой HTML-файл -> chat.ejs

<!DOCTYPE html>
<html>

<head>
  <meta http-equiv="Content-Type" const="text/html;charset=UTF-8" />
  <link href="http://fonts.googleapis.com/css?family=Comfortaa" rel="stylesheet" type="text/css">
  <link rel="stylesheet" type="text/css" href="style.css">
  <script src="socket.io/socket.io.js"></script>
  <title>Simple Chat App</title>

</head>

<body>
  <header>
    <h1>Super Chat</h1>
  </header>
  <div id="userFormArea" style="margin-top: 30px" ;>
    <section>
      <label class="vertical-align">Enter username</label>
      <input id="username" class="vertical-align" type="text" />
      <button id="Login" class="vertical-align" type="button">Login</button>
    </section>
  </div>
  <div id="messageArea" style="display:none";>
    <div class="split left">
    <div id = "groupchat">
        <input id="chatGroupName" class="dropbtn" type="text" placeholder="Find people,group name..." />
        <button id="createChatGroup" class="dropbtn" type="button">Create group</button>
        <button class="dropbtn" id = "friendName">Enter friend's name</button>   
        <div class = "dropdown"><button id="joinChatGroup" class="dropbtn" type="button">Join group</button></div>
        <div id="myDropdown" class="dropdown-content">
           <!-- <a href="#home">Home</a>
            <a href="#about">About</a>
            <a href="#contact">Contact</a>-->
        </div>

    </div>
    <div class="col-md-4"></div>
    <div class="well">
      <h3>Online Users</h3>
      <!--<input id="chat_with" class="vertical-align" type="text" placeholder="Enter name to chat with..." />-->

      <ul >
        <li>
          <a href = # class="list_group" id="users" ></a>
        </li>
      </ul>
    </div>
    </div>
<div class="split right">
  <div id ="upper_name">

  </div>
  <div id = "chat">
      <section id="chatroom">
          <section id="feedback"></section>
        </section>

        <section id="input_zone">
          <input id="message" class="vertical-align" type="text" />
          <button id="send_message" class="vertical-align" type="button">Send</button>
        </section>
  </div>

    </div>
  </div>


  <script src="http://code.jquery.com/jquery-latest.min.js"></script>
  <script src="chat.js"></script>


</body>

</html>

Возможно, я не смогу правильно объяснить проблему, потому что я действительно не знаю об этом (это может помочь: попытка реализовать формат, подобный скайпу, когда при нажатии на пользователя онлайн открывается окно чата). Любая помощь будет оценена.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...