forked from GitHub/dbot
underscorisation for dent and ignore [#81]
This commit is contained in:
parent
3cc013635d
commit
ca8a8ca9c2
@ -16,7 +16,6 @@ var dent = function(dbot) {
|
|||||||
},
|
},
|
||||||
function(error, response, body) {
|
function(error, response, body) {
|
||||||
event.reply('Status posted (probably).');
|
event.reply('Status posted (probably).');
|
||||||
console.log(body);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -4,54 +4,69 @@
|
|||||||
* and commands from certain modules. It also populates the JSBot instance with
|
* and commands from certain modules. It also populates the JSBot instance with
|
||||||
* this information, since that actually performs the ignorance.
|
* this information, since that actually performs the ignorance.
|
||||||
*/
|
*/
|
||||||
|
var _ = require('underscore')._;
|
||||||
|
|
||||||
var ignore = function(dbot) {
|
var ignore = function(dbot) {
|
||||||
var commands = {
|
var commands = {
|
||||||
'~ignore': function(event) {
|
'~ignore': function(event) {
|
||||||
var ignorableModules = dbot.modules.filter(function(module) {
|
|
||||||
if(module.ignorable != null && module.ignorable == true) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
var module = event.params[1];
|
var module = event.params[1];
|
||||||
|
var ignorableModules = _.chain(dbot.modules)
|
||||||
|
.filter(function(module) {
|
||||||
|
return module.ignorable !== null && module.ignorable === true;
|
||||||
|
})
|
||||||
|
.pluck('name')
|
||||||
|
.value();
|
||||||
|
|
||||||
if(module === undefined) {
|
if(_.isUndefined(module)) {
|
||||||
event.reply(dbot.t('ignore_usage', {'user': event.user, 'modules': ignorableModules.join(', ')}));
|
event.reply(dbot.t('ignore_usage', {
|
||||||
|
'user': event.user,
|
||||||
|
'modules': ignorableModules.join(', ')
|
||||||
|
}));
|
||||||
} else {
|
} else {
|
||||||
if(ignorableModules.include(module)) {
|
if(_.include(ignorableModules, module)) {
|
||||||
if(dbot.db.ignores.hasOwnProperty(event.user) && dbot.db.ignores[event.user].include(module)) {
|
if(_.has(dbot.db.ignores, event.user) && _.include(dbot.db.ignores[event.user], module)) {
|
||||||
event.reply(dbot.t('already_ignoring', {'user': event.user}));
|
event.reply(dbot.t('already_ignoring', { 'user': event.user }));
|
||||||
} else {
|
} else {
|
||||||
if(dbot.db.ignores.hasOwnProperty(module)) {
|
if(_.has(dbot.db.ignores, module)) {
|
||||||
dbot.db.ignores[event.user].push(module);
|
dbot.db.ignores[event.user].push(module);
|
||||||
} else {
|
} else {
|
||||||
dbot.db.ignores[event.user] = [module];
|
dbot.db.ignores[event.user] = [module];
|
||||||
}
|
}
|
||||||
|
|
||||||
dbot.instance.ignoreTag(event.user, module);
|
dbot.instance.ignoreTag(event.user, module);
|
||||||
event.reply(dbot.t('ignored', {'user': event.user, 'module': module}));
|
event.reply(dbot.t('ignored', {
|
||||||
|
'user': event.user,
|
||||||
|
'module': module
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
event.reply(dbot.t('invalid_ignore', {'user': event.user}));
|
event.reply(dbot.t('invalid_ignore', { 'user': event.user }));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
'~unignore': function(event) {
|
'~unignore': function(event) {
|
||||||
var ignoredModules = [];
|
var ignoredModules = [];
|
||||||
if(dbot.db.ignores.hasOwnProperty(event.user)) {
|
if(_.has(dbot.db.ignores, event.user)) {
|
||||||
ignoredModules = dbot.db.ignores[event.user];
|
ignoredModules = dbot.db.ignores[event.user];
|
||||||
}
|
}
|
||||||
var module = event.params[1];
|
var module = event.params[1];
|
||||||
|
|
||||||
if(module === undefined) {
|
if(_.isUndefined(module)) {
|
||||||
event.reply(dbot.t('unignore_usage', {'user': event.user, 'modules': ignoredModules.join(', ')}));
|
event.reply(dbot.t('unignore_usage', {
|
||||||
|
'user': event.user,
|
||||||
|
'modules': ignoredModules.join(', ')
|
||||||
|
}));
|
||||||
} else {
|
} else {
|
||||||
if(ignoredModules.include(module) == false) {
|
if(_.include(ignoredModules, module)) {
|
||||||
event.reply(dbot.t('invalid_unignore', {'user': event.user}));
|
|
||||||
} else {
|
|
||||||
dbot.db.ignores[event.user].splice(dbot.db.ignores[event.user].indexOf(module), 1);
|
dbot.db.ignores[event.user].splice(dbot.db.ignores[event.user].indexOf(module), 1);
|
||||||
dbot.instance.removeIgnore(event.user, module)
|
dbot.instance.removeIgnore(event.user, module)
|
||||||
event.reply(dbot.t('unignored', {'user': event.user, 'module': module}));
|
event.reply(dbot.t('unignored', {
|
||||||
|
'user': event.user,
|
||||||
|
'module': module
|
||||||
|
}));
|
||||||
|
} else {
|
||||||
|
event.reply(dbot.t('invalid_unignore', { 'user': event.user }));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -64,13 +79,11 @@ var ignore = function(dbot) {
|
|||||||
|
|
||||||
'onLoad': function() {
|
'onLoad': function() {
|
||||||
dbot.instance.clearIgnores();
|
dbot.instance.clearIgnores();
|
||||||
for(var user in dbot.db.ignores) {
|
_.each(dbot.db.ignores, function(ignores, user) {
|
||||||
if(dbot.db.ignores.hasOwnProperty(user)) {
|
_.each(ignores, function(ignore) {
|
||||||
for(var i=0;i<dbot.db.ignores[user].length;i++) {
|
dbot.instance.ignoreTag(user, ignore);
|
||||||
dbot.instance.ignoreTag(user, dbot.db.ignores[user][i]);
|
}, this);
|
||||||
}
|
}, this);
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user