3
0
mirror of https://github.com/reality/dbot.git synced 2025-02-17 05:51:01 +01:00

poll web list works [#420] some commands using new users [#434]

This commit is contained in:
reality 2013-05-06 18:12:25 +00:00
parent 9db515d44a
commit 33b9b8d1b0
3 changed files with 91 additions and 89 deletions

View File

@ -4,73 +4,73 @@ var _ = require('underscore')._,
NoSuchThingError = databank.NoSuchThingError; NoSuchThingError = databank.NoSuchThingError;
var commands = function(dbot) { var commands = function(dbot) {
var polls = dbot.db.polls;
var commands = { var commands = {
'~newpoll': function(event) { '~newpoll': function(event) {
var name = event.input[1].toLowerCase(), var name = event.input[1].toLowerCase(),
options = event.input[2].toLowerCase().split(','), options = event.input[2].toLowerCase().split(','),
description = event.input[3]; description = event.input[3];
var votes = {}; _.each(options, function(item, index, list) { list[index] = [ item, 0 ]; })
for(var i=0;i<options.length;i++) { votes = _.object(options);
votes[options[i]] = 0;
}
this.db.create('poll', name, { dbot.api.users.resolveUser(event.server, event.user, function(user) {
'description': description, this.db.create('poll', name, {
'owner': dbot.api.users.resolveUser(event.server, event.user), 'name': name,
'votes': votes, 'description': description,
'votees': {} 'owner': user.id,
}, 'votes': votes,
function(err, value) { 'votees': {}
if(!err) { }, function(err, value) {
event.reply(dbot.t('poll_created', { if(!err) {
'name': name, event.reply(dbot.t('poll_created', {
'description': description, 'name': name,
'url': dbot.api.web.getUrl('/poll/' + name) 'description': description,
})); 'url': dbot.api.web.getUrl('poll/' + name)
} else if(err instanceof AlreadyExistsError) { }));
event.reply(dbot.t('poll_exists', { 'name': name })); } else if(err instanceof AlreadyExistsError) {
} event.reply(dbot.t('poll_exists', { 'name': name }));
}); }
});
}.bind(this));
}, },
'~addoption': function(event) { '~addoption': function(event) {
var name = event.input[1].toLowerCase(), var name = event.input[1].toLowerCase(),
option = event.input[2].toLowerCase(), option = event.input[2].toLowerCase();
user = dbot.api.users.resolveUser(event.server, event.user);
this.db.read('poll', name, function(err, poll) { dbot.api.users.resolveUser(event.server, event.user, function(user) {
if(!err) { this.db.read('poll', name, function(err, poll) {
if(poll.owner === user) { if(!err) {
if(!_.has(poll.votes, option)) { if(poll.owner === user.id) {
poll.votes[option] = 0; if(!_.has(poll.votes, option)) {
this.db.save('poll', name, poll, function(err) { poll.votes[option] = 0;
event.reply(dbot.t('option_added', { this.db.save('poll', name, poll, function(err) {
'user': event.user, event.reply(dbot.t('option_added', {
'user': event.user,
'name': name,
'option': option
}));
});
} else {
event.reply(dbot.t('option_exists', {
'option': option,
'name': name, 'name': name,
'option': option 'user': event.user
})); }));
}.bind(this)); }
} else { } else {
event.reply(dbot.t('option_exists', { event.reply(dbot.t('not_poll_owner', {
'option': option, 'user': event.user,
'name': name, 'name': name
'user': event.user
})); }));
} }
} else { } else {
event.reply(dbot.t('not_poll_owner', { if(err instanceof NoSuchThingError) {
'user': event.user, event.reply(dbot.t('poll_unexistent', { 'name': name }));
'name': name }
}));
} }
} else { }.bind(this));
if(err instanceof NoSuchThingError) { });
event.reply(dbot.t('poll_unexistent', { 'name': name }));
}
}
}.bind(this));
}, },
'~rmoption': function(event) { '~rmoption': function(event) {
@ -107,38 +107,39 @@ var commands = function(dbot) {
'~vote': function(event) { '~vote': function(event) {
var name = event.input[1].toLowerCase(), var name = event.input[1].toLowerCase(),
vote = event.input[2].toLowerCase(), vote = event.input[2].toLowerCase();
user = dbot.api.users.resolveUser(event.server, event.user);
dbot.api.users.resolveUser(event.server, event.user, function(user) {
this.db.read('poll', name, function(err, poll) {
if(!err) {
if(_.has(poll.votes, vote)) {
if(_.has(poll.votees, user.id)) {
var oldVote = poll.votees[user.id];
poll.votes[oldVote]--;
poll.votes[vote]++;
poll.votees[user.id] = vote;
} else {
poll.votes[vote]++;
poll.votees[user.id] = vote;
}
this.db.read('poll', name, function(err, poll) { this.db.save('poll', name, poll, function(err) {
if(!err) { event.reply(dbot.t('voted', {
if(_.has(poll.votes, vote)) { 'vote': vote,
if(_.has(poll.votees, user)) { 'poll': name,
var oldVote = poll.votees[user]; 'count': poll.votes[vote],
poll.votes[oldVote]--; 'user': event.user
poll.votes[vote]++; }));
poll.votees[user] = vote; }.bind(this));
} else { } else {
poll.votes[vote]++; event.reply(dbot.t('invalid_vote', { 'vote': vote }));
poll.votees[user] = vote;
} }
this.db.save('poll', name, poll, function(err) {
event.reply(dbot.t('voted', {
'vote': vote,
'poll': name,
'count': poll.votes[vote],
'user': event.user
}));
}.bind(this));
} else { } else {
event.reply(dbot.t('invalid_vote', { 'vote': vote })); if(err instanceof NoSuchThingError) {
event.reply(dbot.t('poll_unexistent', { 'name': name }));
}
} }
} else { }.bind(this));
if(err instanceof NoSuchThingError) {
event.reply(dbot.t('poll_unexistent', { 'name': name }));
}
}
}.bind(this)); }.bind(this));
}, },
@ -156,15 +157,11 @@ var commands = function(dbot) {
event.reply(dbot.t('poll_describe', { event.reply(dbot.t('poll_describe', {
'name': name, 'name': name,
'description': poll.description, 'description': poll.description,
'url': dbot.t('url', { 'url': dbot.api.web.getUrl('poll/' + name)
'host': 'test.com',
'port': 80,
'path': 'polls/' + name
})
}) + optionString); }) + optionString);
} else { } else {
if(err instanceof NoSuchThingError) { if(err instanceof NoSuchThingError) {
event.reply(dbot.t('poll_unexistent', {'name': name})); event.reply(dbot.t('poll_unexistent', { 'name': name }));
} }
} }
}); });
@ -179,7 +176,7 @@ var commands = function(dbot) {
var order = _.chain(poll.votes) var order = _.chain(poll.votes)
.pairs() .pairs()
.sortBy(function(option) { return option[1] }) .sortBy(function(option) { return option[1]; })
.reverse() .reverse()
.value(); .value();

View File

@ -1,10 +1,9 @@
var _ = require('underscore')._; var _ = require('underscore')._;
var pages = function(dbot) { var pages = function(dbot) {
var polls = dbot.db.polls;
var pages = { var pages = {
// Shows the results of a poll // Shows the results of a poll
'/polls/:key': function(req, res) { '/poll/:key': function(req, res) {
var key = req.params.key.toLowerCase(); var key = req.params.key.toLowerCase();
if(_.has(dbot.db.polls, key)) { if(_.has(dbot.db.polls, key)) {
var totalVotes = _.reduce(dbot.db.polls[key].votes, var totalVotes = _.reduce(dbot.db.polls[key].votes,
@ -31,9 +30,15 @@ var pages = function(dbot) {
// Lists all of the polls // Lists all of the polls
'/poll': function(req, res) { '/poll': function(req, res) {
res.render('polllist', { var pollKeys = [];
'name': dbot.config.name, this.db.scan('poll', function(result) {
'polllist': Object.keys(dbot.db.polls) if(result) pollKeys.push(result.name);
}, function(err) {
console.log(pollKeys);
res.render('polllist', {
'name': dbot.config.name,
'polllist': pollKeys
});
}); });
} }
}; };

View File

@ -7,6 +7,6 @@ block content
input(type="text", name="search", id="search-text", oninput="search(this.value)") input(type="text", name="search", id="search-text", oninput="search(this.value)")
ul#quotelist ul#quotelist
-each poll in polllist -each poll in polllist
a(href='/polls/'+poll) a(href='/poll/'+poll)
li.quotes #{poll} li.quotes #{poll}