Files
NodeBB/public/src/forum/chats.js

147 lines
3.6 KiB
JavaScript
Raw Normal View History

2014-05-12 18:42:13 -04:00
'use strict';
/* globals define, app, ajaxify, utils, socket, templates */
2014-05-12 18:42:13 -04:00
define('forum/chats', ['string', 'sounds'], function(S, sounds) {
var Chats = {
initialised: false
};
2014-05-12 18:42:13 -04:00
Chats.init = function() {
var containerEl = $('.expanded-chat ul');
if (!Chats.initialised) {
Chats.addSocketListeners();
}
Chats.addEventListeners();
Chats.scrollToBottom(containerEl);
Chats.setActive();
Chats.initialised = true;
};
Chats.getRecipientUid = function() {
return parseInt($('.expanded-chat').attr('data-uid'), 10);
};
Chats.isCurrentChat = function(uid) {
uid = parseInt(uid, 10);
if (Chats.getRecipientUid() === uid) {
return true;
} else {
return false;
}
};
Chats.addEventListeners = function() {
2014-07-07 12:26:17 -04:00
var inputEl = $('.chat-input'),
sendEl = $('.expanded-chat button[data-action="send"]');
2014-05-12 18:42:13 -04:00
$('.chats-list').on('click', 'li', function(e) {
ajaxify.go('chats/' + utils.slugify($(this).attr('data-username')));
});
inputEl.on('keypress', function(e) {
2014-07-07 12:26:17 -04:00
if(e.which === 13) {
Chats.sendMessage(Chats.getRecipientUid(), inputEl);
}
});
inputEl.on('keyup', function() {
if ($(this).val()) {
2014-07-07 12:26:17 -04:00
Chats.notifyTyping(Chats.getRecipientUid(), true);
} else {
2014-07-07 12:26:17 -04:00
Chats.notifyTyping(Chats.getRecipientUid(), false);
}
});
sendEl.on('click', function(e) {
2014-07-07 12:26:17 -04:00
Chats.sendMessage(Chats.getRecipientUid(), inputEl);
return false;
});
};
Chats.addSocketListeners = function() {
socket.on('event:chats.receive', function(data) {
var typingNotifEl = $('.user-typing'),
containerEl = $('.expanded-chat ul');
if (Chats.isCurrentChat(data.withUid)) {
Chats.parseMessage(data.message, function(html) {
var newMessage = $(html);
newMessage.insertBefore(typingNotifEl);
newMessage.find('span.timeago').timeago();
newMessage.find('img:not(".chat-user-image")').addClass('img-responsive');
Chats.scrollToBottom(containerEl);
});
} else {
$('.chats-list li[data-uid="' + data.withUid + '"]').addClass('unread');
app.alternatingTitle('[[modules:chat.user_has_messaged_you, ' + data.message.fromUser.username + ']]');
}
});
socket.on('event:chats.userStartTyping', function(withUid) {
var typingNotifEl = $('.user-typing');
if (Chats.isCurrentChat(withUid)) {
typingNotifEl.removeClass('hide');
}
$('.chats-list li[data-uid="' + withUid + '"]').addClass('typing');
});
socket.on('event:chats.userStopTyping', function(withUid) {
var typingNotifEl = $('.user-typing');
if (Chats.isCurrentChat(withUid)) {
typingNotifEl.addClass('hide');
}
$('.chats-list li[data-uid="' + withUid + '"]').removeClass('typing');
});
};
2014-07-07 12:26:17 -04:00
Chats.notifyTyping = function(toUid, typing) {
socket.emit('modules.chats.user' + (typing ? 'Start' : 'Stop') + 'Typing', {
2014-07-07 12:26:17 -04:00
touid: toUid,
fromUid: app.uid
2014-05-12 18:42:13 -04:00
});
};
2014-07-07 12:26:17 -04:00
Chats.sendMessage = function(toUid, inputEl) {
var msg = S(inputEl.val()).stripTags().s;
if (msg.length) {
msg = msg +'\n';
socket.emit('modules.chats.send', {
touid:toUid,
message:msg
});
inputEl.val('');
sounds.play('chat-outgoing');
Chats.notifyTyping(toUid, false);
}
};
Chats.scrollToBottom = function(containerEl) {
if (containerEl.length) {
containerEl.scrollTop(
containerEl[0].scrollHeight - containerEl.height()
);
}
};
Chats.setActive = function() {
$('.chats-list li').removeClass('bg-primary');
$('.chats-list li[data-uid="' + Chats.getRecipientUid() + '"]').addClass('bg-primary');
};
Chats.parseMessage = function(data, callback) {
templates.parse('partials/chat_message' + (Array.isArray(data) ? 's' : ''), {
messages: data
}, callback);
};
2014-05-12 18:42:13 -04:00
return Chats;
});