mirror of
				https://github.com/keanuplayz/TravBot-v3.git
				synced 2024-08-15 02:33:12 +00:00 
			
		
		
		
	Added welcome message and system logs channel
This commit is contained in:
		
							parent
							
								
									ee9c88996e
								
							
						
					
					
						commit
						c1b298a407
					
				
					 5 changed files with 97 additions and 6 deletions
				
			
		|  | @ -102,8 +102,18 @@ export default new Command({ | |||
|                         }), | ||||
|                         channel: new Command({ | ||||
|                             description: "Sets the welcome channel for your server. Type `#` to reference the channel.", | ||||
|                             usage: "<channel mention>", | ||||
|                             run: "You need to specify a channel.", | ||||
|                             usage: "(<channel mention>)", | ||||
|                             async run($) { | ||||
|                                 if ($.guild) { | ||||
|                                     Storage.getGuild($.guild.id).welcomeChannel = $.channel.id; | ||||
|                                     Storage.save(); | ||||
|                                     $.channel.send( | ||||
|                                         `Successfully set ${$.channel} as the welcome channel for this server.` | ||||
|                                     ); | ||||
|                                 } else { | ||||
|                                     $.channel.send("You must use this command in a server."); | ||||
|                                 } | ||||
|                             }, | ||||
|                             // If/when channel types come out, this will be the perfect candidate to test it.
 | ||||
|                             any: new Command({ | ||||
|                                 async run($) { | ||||
|  | @ -126,6 +136,32 @@ export default new Command({ | |||
|                                     } | ||||
|                                 } | ||||
|                             }) | ||||
|                         }), | ||||
|                         message: new Command({ | ||||
|                             description: | ||||
|                                 "Sets a custom welcome message for your server. Use `%user%` as the placeholder for the user.", | ||||
|                             usage: "(<message>)", | ||||
|                             async run($) { | ||||
|                                 if ($.guild) { | ||||
|                                     Storage.getGuild($.guild.id).welcomeMessage = null; | ||||
|                                     Storage.save(); | ||||
|                                     $.channel.send("Reset your server's welcome message to the default."); | ||||
|                                 } else { | ||||
|                                     $.channel.send("You must use this command in a server."); | ||||
|                                 } | ||||
|                             }, | ||||
|                             any: new Command({ | ||||
|                                 async run($) { | ||||
|                                     if ($.guild) { | ||||
|                                         const message = $.args.join(" "); | ||||
|                                         Storage.getGuild($.guild.id).welcomeMessage = message; | ||||
|                                         Storage.save(); | ||||
|                                         $.channel.send(`Set your server's welcome message to \`${message}\`.`); | ||||
|                                     } else { | ||||
|                                         $.channel.send("You must use this command in a server."); | ||||
|                                     } | ||||
|                                 } | ||||
|                             }) | ||||
|                         }) | ||||
|                     } | ||||
|                 }) | ||||
|  | @ -275,6 +311,19 @@ export default new Command({ | |||
|                         ); | ||||
|                 } | ||||
|             }) | ||||
|         }), | ||||
|         syslog: new Command({ | ||||
|             description: "Sets up the current channel to receive system logs.", | ||||
|             permission: Command.PERMISSIONS.BOT_ADMIN, | ||||
|             async run($) { | ||||
|                 if ($.guild) { | ||||
|                     Config.systemLogsChannel = $.channel.id; | ||||
|                     Config.save(); | ||||
|                     $.channel.send(`Successfully set ${$.channel} as the system logs channel.`); | ||||
|                 } else { | ||||
|                     $.channel.send("DM system log channels aren't supported."); | ||||
|                 } | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
| }); | ||||
|  |  | |||
|  | @ -3,12 +3,15 @@ import $, {select, GenericJSON, GenericStructure} from "./lib"; | |||
| import {watch} from "fs"; | ||||
| import {Guild as DiscordGuild, Snowflake} from "discord.js"; | ||||
| 
 | ||||
| // Maybe use getters and setters to auto-save on set?
 | ||||
| 
 | ||||
| class ConfigStructure extends GenericStructure { | ||||
|     public token: string; | ||||
|     public prefix: string; | ||||
|     public owner: string; | ||||
|     public admins: string[]; | ||||
|     public support: string[]; | ||||
|     public systemLogsChannel: string | null; | ||||
| 
 | ||||
|     constructor(data: GenericJSON) { | ||||
|         super("config"); | ||||
|  | @ -17,6 +20,7 @@ class ConfigStructure extends GenericStructure { | |||
|         this.owner = select(data.owner, "", String); | ||||
|         this.admins = select(data.admins, [], String, true); | ||||
|         this.support = select(data.support, [], String, true); | ||||
|         this.systemLogsChannel = select(data.systemLogsChannel, null, String); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  | @ -53,10 +57,12 @@ class Guild { | |||
|     public prefix: string | null; | ||||
|     public welcomeType: "none" | "text" | "graphical"; | ||||
|     public welcomeChannel: string | null; | ||||
|     public welcomeMessage: string | null; | ||||
| 
 | ||||
|     constructor(data?: GenericJSON) { | ||||
|         this.prefix = select(data?.prefix, null, String); | ||||
|         this.welcomeChannel = select(data?.welcomeChannel, null, String); | ||||
|         this.welcomeMessage = select(data?.welcomeMessage, null, String); | ||||
| 
 | ||||
|         switch (data?.welcomeType) { | ||||
|             case "text": | ||||
|  |  | |||
|  | @ -1,6 +1,9 @@ | |||
| import Event from "../core/event"; | ||||
| import $ from "../core/lib"; | ||||
| import {updateGlobalEmoteRegistry} from "../core/lib"; | ||||
| import {client} from "../index"; | ||||
| import {Config} from "../core/structures"; | ||||
| import {TextChannel} from "discord.js"; | ||||
| 
 | ||||
| export default new Event<"guildCreate">({ | ||||
|     on(guild) { | ||||
|  | @ -9,6 +12,21 @@ export default new Event<"guildCreate">({ | |||
|                 guild.owner!.user.id | ||||
|             }). Updated emote registry.` | ||||
|         ); | ||||
| 
 | ||||
|         if (Config.systemLogsChannel) { | ||||
|             const channel = client.channels.cache.get(Config.systemLogsChannel); | ||||
| 
 | ||||
|             if (channel && channel.type === "text") { | ||||
|                 (channel as TextChannel).send( | ||||
|                     `TravBot joined: \`${guild.name}\`. The owner of this guild is: \`${guild.owner!.user.tag}\` (\`${ | ||||
|                         guild.owner!.user.id | ||||
|                     }\`)` | ||||
|                 ); | ||||
|             } else { | ||||
|                 console.warn(`${Config.systemLogsChannel} is not a valid text channel for system logs!`); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         updateGlobalEmoteRegistry(); | ||||
|     } | ||||
| }); | ||||
|  |  | |||
|  | @ -1,10 +1,24 @@ | |||
| import Event from "../core/event"; | ||||
| import $ from "../core/lib"; | ||||
| import {updateGlobalEmoteRegistry} from "../core/lib"; | ||||
| import {client} from "../index"; | ||||
| import {Config} from "../core/structures"; | ||||
| import {TextChannel} from "discord.js"; | ||||
| 
 | ||||
| export default new Event<"guildDelete">({ | ||||
|     on(guild) { | ||||
|         $.log(`[GUILD LEAVE] ${guild.name} (${guild.id}) removed the bot. Updated emote registry.`); | ||||
| 
 | ||||
|         if (Config.systemLogsChannel) { | ||||
|             const channel = client.channels.cache.get(Config.systemLogsChannel); | ||||
| 
 | ||||
|             if (channel && channel.type === "text") { | ||||
|                 (channel as TextChannel).send(`\`${guild.name}\` (\`${guild.id}\`) removed the bot.`); | ||||
|             } else { | ||||
|                 console.warn(`${Config.systemLogsChannel} is not a valid text channel for system logs!`); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         updateGlobalEmoteRegistry(); | ||||
|     } | ||||
| }); | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ function applyText(canvas: Canvas, text: string) { | |||
| 
 | ||||
| export default new Event<"guildMemberAdd">({ | ||||
|     async on(member) { | ||||
|         const {welcomeType, welcomeChannel} = Storage.getGuild(member.guild.id); | ||||
|         const {welcomeType, welcomeChannel, welcomeMessage} = Storage.getGuild(member.guild.id); | ||||
| 
 | ||||
|         if (welcomeChannel) { | ||||
|             const channel = member.guild.channels.cache.get(welcomeChannel); | ||||
|  | @ -60,9 +60,13 @@ export default new Event<"guildMemberAdd">({ | |||
|                     (channel as TextChannel).send(`Welcome \`${member.user.tag}\`!`, attachment); | ||||
|                 } else if (welcomeType === "text") { | ||||
|                     (channel as TextChannel).send( | ||||
|                         parseVars("Say hello to `%user%`, everyone! We all need a warm welcome sometimes :D", { | ||||
|                             user: member.user.tag | ||||
|                         }) | ||||
|                         parseVars( | ||||
|                             welcomeMessage || | ||||
|                                 "Say hello to `%user%`, everyone! We all need a warm welcome sometimes :D", | ||||
|                             { | ||||
|                                 user: member.user.tag | ||||
|                             } | ||||
|                         ) | ||||
|                     ); | ||||
|                 } | ||||
|             } else { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue