mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-09 09:12:07 +02:00
Join Role
This commit is contained in:
@@ -5,5 +5,6 @@
|
||||
"joinMsg",
|
||||
"leaveMsg",
|
||||
"staffRole",
|
||||
"singleRole"
|
||||
"singleRole",
|
||||
"joinRole"
|
||||
]
|
||||
|
||||
@@ -0,0 +1,30 @@
|
||||
const { Command } = require('discord.js-commando');
|
||||
|
||||
module.exports = class JoinRoleCommand extends Command {
|
||||
constructor(client) {
|
||||
super(client, {
|
||||
name: 'join-role',
|
||||
group: 'settings',
|
||||
memberName: 'join-role',
|
||||
description: 'Sets a role that new members are automatically joined to.',
|
||||
guildOnly: true,
|
||||
args: [
|
||||
{
|
||||
key: 'role',
|
||||
prompt: 'What role should new members be joined to?',
|
||||
type: 'role'
|
||||
}
|
||||
]
|
||||
});
|
||||
}
|
||||
|
||||
hasPermission(msg) {
|
||||
return msg.member.hasPermission('ADMINISTRATOR');
|
||||
}
|
||||
|
||||
run(msg, args) {
|
||||
const { role } = args;
|
||||
msg.guild.settings.set('joinRole', role.id);
|
||||
return msg.say(`Join Role set to ${role.name}.`);
|
||||
}
|
||||
};
|
||||
@@ -17,11 +17,13 @@ module.exports = class SettingListCommand extends Command {
|
||||
const modLog = msg.guild.settings.get('modLog', false);
|
||||
const memberLog = msg.guild.settings.get('memberLog', false);
|
||||
const singleRole = msg.guild.settings.get('singleRole', false);
|
||||
const joinRole = msg.guild.settings.get('joinRole', false);
|
||||
return msg.say(stripIndents`
|
||||
**Prefix:** ${msg.guild.commandPrefix}
|
||||
**Invite Guard:** ${msg.guild.settings.get('inviteGuard', false)}
|
||||
**Staff Role:** ${staffRole ? (msg.guild.roles.has(staffRole) ? msg.guild.roles.get(staffRole).name : 'Missing') : 'None'}
|
||||
**Mod Channel:** ${modLog ? (msg.guild.channels.has(modLog) ? msg.guild.channels.get(modLog).name : 'Missing') : 'None'}
|
||||
**Join Role:** ${joinRole ? (msg.guild.roles.has(joinRole) ? msg.guild.roles.get(joinRole).name : 'Missing') : 'None'}
|
||||
**Member Channel:** ${memberLog ? (msg.guild.channels.has(memberLog) ? msg.guild.channels.get(memberLog).name : 'Missing') : 'None'}
|
||||
**Join Message:** ${msg.guild.settings.get('joinMsg', 'Welcome <user>! (Default)')}
|
||||
**Leave Message:** ${msg.guild.settings.get('leaveMsg', 'Bye <user>... (Default)')}
|
||||
|
||||
@@ -107,6 +107,8 @@ client.dispatcher.addInhibitor(msg => {
|
||||
});
|
||||
|
||||
client.on('guildMemberAdd', (member) => {
|
||||
const role = member.guild.roles.get(member.guild.settings.get('joinRole'));
|
||||
if (member.guild.me.hasPermission('MANAGE_ROLES') && role) member.addRole(role);
|
||||
const channel = member.guild.channels.get(member.guild.settings.get('memberLog'));
|
||||
if (!channel) return;
|
||||
if (!channel.permissionsFor(client.user).has('SEND_MESSAGES')) return;
|
||||
|
||||
+1
-1
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "xiaobot",
|
||||
"version": "19.11.2",
|
||||
"version": "19.12.0",
|
||||
"description": "A Discord Bot",
|
||||
"main": "shardingmanager.js",
|
||||
"scripts": {
|
||||
|
||||
Reference in New Issue
Block a user