Implemented QUIT and MODE events

This commit is contained in:
Mattias Erming 2014-03-14 16:12:01 +01:00
parent b5571f8fdb
commit 8bedfba27f
1 changed files with 56 additions and 9 deletions

View File

@ -271,12 +271,17 @@ function handleEvent(argv) {
name: argv.nick
})
);
} else {
var irc = network.irc;
if (typeof irc !== "undefined") {
irc.send("TOPIC", argv.args[0]);
}
}
messages.add(
new models.Message({
user: argv.nick,
text: "has joined the channel.",
text: "join",
type: "join"
})
);
@ -298,7 +303,7 @@ function handleEvent(argv) {
messages.add(
new models.Message({
user: argv.nick,
text: "has left the channel.",
text: "part",
type: "part"
})
);
@ -308,7 +313,8 @@ function handleEvent(argv) {
case "NICK":
var message = new models.Message({
user: argv.nick,
text: "changed name to " + argv.args[0]
text: "changed name to " + argv.args[0],
type: "nick"
});
channels.each(function(channel) {
@ -330,6 +336,8 @@ function handleEvent(argv) {
});
var users = channel.get("users");
var messages = channel.get("messages");
if (argv.args[1] == network.get("nick")) {
users.reset();
} else {
@ -340,16 +348,52 @@ function handleEvent(argv) {
);
}
var messages = channel.get("messages");
messages.add(
new models.Message({
user: argv.args[1],
text: "was kicked from " + argv.args[0] + " by " + argv.nick,
text: "was kicked by " + argv.nick,
type: "kick"
})
);
break;
case "QUIT":
var message = new models.Message({
user: argv.nick,
text: "quit",
type: "quit"
});
channels.each(function(channel) {
var user = channel.get("users").findWhere({name: argv.nick});
if (typeof user !== "undefined") {
channel.get("users").remove(user);
channel.get("messages").add(message);
}
});
break;
case "MODE":
var channel = channels.findWhere({name: argv.args[0]});
if (typeof channel === "undefined") {
break;
}
var messages = channel.get("messages");
messages.add(
new models.Message({
user: argv.nick,
text: "sets mode: " + argv.args[1] + " " + argv.args[2],
type: "mode"
})
);
var irc = network.irc;
if (typeof irc !== "undefined") {
irc.send("NAMES", argv.args[0]);
}
break;
case "TOPIC":
var channel = channels.findWhere({name: argv.args[0]});
var messages = channel.get("messages");
@ -378,8 +422,8 @@ function handleEvent(argv) {
break;
case "rpl_namreply":
var names = argv.args[3].split(' ');
var channel = network.get("channels").findWhere({name: argv.args[2]});
var users = channel.get("users");
if (typeof channel === "undefined") {
channel = channels.add(
@ -389,10 +433,13 @@ function handleEvent(argv) {
);
}
var users = channel.get("users");
if (names[0] == network.get("nick")) {
var names = argv.args[3].split(' ');
var first = names[0].replace(/^\W/, ''); // Strip mode prefixes
if (first == network.get("nick")) {
users.reset();
}
for (var i in names) {
users.add(
new models.User({name: names[i]}), {
@ -403,7 +450,7 @@ function handleEvent(argv) {
break;
case "rpl_endofnames":
var channel = network.get("channels").findWhere({name: argv.args[1]});
var channel = channels.findWhere({name: argv.args[1]});
var users = channel.get("users");
users.trigger(