mirror of
				https://github.com/veganhacktivists/arabot.git
				synced 2025-10-25 21:47:40 +02:00 
			
		
		
		
	refactor(arabot): change StatRole to one to one relationship in Prisma
This commit is contained in:
		
							parent
							
								
									086d1d50c6
								
							
						
					
					
						commit
						80d90256d5
					
				| @ -96,6 +96,8 @@ model LeaveLog { | ||||
|   roles  String[] | ||||
| } | ||||
| 
 | ||||
| // Outreach | ||||
| 
 | ||||
| model Event { | ||||
|   id        Int       @id @default(autoincrement()) | ||||
|   type      EventType @relation(fields: [eventType], references: [type]) | ||||
| @ -125,7 +127,7 @@ model Stat { | ||||
|   documentary  Int               @default(0) | ||||
|   educated     Int               @default(0) | ||||
|   participants ParticipantStat[] | ||||
|   role         StatRole[] | ||||
|   role         StatRole? | ||||
| } | ||||
| 
 | ||||
| model StatRole { | ||||
| @ -143,6 +145,8 @@ model ParticipantStat { | ||||
|   @@id([statId, userId]) | ||||
| } | ||||
| 
 | ||||
| // Moderation | ||||
| 
 | ||||
| model Sus { | ||||
|   id     Int      @id @default(autoincrement()) | ||||
|   user   User     @relation("susUser", fields: [userId], references: [id]) | ||||
|  | ||||
| @ -75,7 +75,7 @@ export class OutreachCommand extends Subcommand { | ||||
|         .addSubcommandGroup((group) => group.setName('event') | ||||
|           .setDescription('Commands to do with outreach events') | ||||
|           .addSubcommand((command) => command.setName('create') | ||||
|             .setDescription('Start an outreach event'))) | ||||
|             .setDescription('Start an outreach event')) | ||||
|         /* | ||||
|         TODO add this back at a later date | ||||
| 
 | ||||
| @ -83,9 +83,9 @@ export class OutreachCommand extends Subcommand { | ||||
|               .setDescription('Start the event immediately')) | ||||
|           .addSubcommand((command) => command.setName('start') | ||||
|             .setDescription('Start an outreach event')) | ||||
|          */ | ||||
|           .addSubcommand((command) => command.setName('end') | ||||
|             .setDescription('End an outreach event'))) | ||||
|          */ | ||||
|         .addSubcommandGroup((group) => group.setName('group') | ||||
|           .setDescription('Commands to do with groups') | ||||
|           .addSubcommand((command) => command.setName('create') | ||||
| @ -210,8 +210,10 @@ export class OutreachCommand extends Subcommand { | ||||
| 
 | ||||
|     const [stat] = await Promise.all([getStatGroups(event.id)]); | ||||
| 
 | ||||
|     stat.forEach((group) => { | ||||
|       guild.roles.delete(group.role[0].roleId); | ||||
|     stat.forEach(({ role }) => { | ||||
|       if (role !== null) { | ||||
|         guild.roles.delete(role.roleId); | ||||
|       } | ||||
|     }); | ||||
| 
 | ||||
|     await endEvent(event.id); | ||||
| @ -331,7 +333,7 @@ export class OutreachCommand extends Subcommand { | ||||
|     await interaction.deferReply({ ephemeral: true }); | ||||
| 
 | ||||
|     let statId: number; | ||||
|     let roleId: Snowflake; | ||||
|     let roleId: Snowflake | undefined; | ||||
| 
 | ||||
|     // Find group from role
 | ||||
|     if (group !== null) { | ||||
| @ -375,7 +377,7 @@ export class OutreachCommand extends Subcommand { | ||||
|       } | ||||
| 
 | ||||
|       statId = stat.id; | ||||
|       roleId = stat.role[0].roleId; | ||||
|       roleId = stat.role?.roleId; | ||||
|     } | ||||
| 
 | ||||
|     if (await userInStats(statId, user.id)) { | ||||
| @ -398,7 +400,9 @@ export class OutreachCommand extends Subcommand { | ||||
| 
 | ||||
|     await addStatUser(statId, user.id); | ||||
| 
 | ||||
|     if (roleId !== undefined) { | ||||
|       await member.roles.add(roleId); | ||||
|     } | ||||
| 
 | ||||
|     await interaction.editReply({ | ||||
|       content: `Added ${user} to the group!`, | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 smyalygames
						smyalygames