whoops broke buttons and modals
This commit is contained in:
		
							
								
								
									
										42
									
								
								handlers.go
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								handlers.go
									
									
									
									
									
								
							| @@ -65,27 +65,29 @@ func ready(s *discordgo.Session, event *discordgo.Ready) { | |||||||
|  |  | ||||||
| func interactionCreate(s *discordgo.Session, i *discordgo.InteractionCreate) { | func interactionCreate(s *discordgo.Session, i *discordgo.InteractionCreate) { | ||||||
| 	for _, command := range commands { | 	for _, command := range commands { | ||||||
| 		if i.ApplicationCommandData().Name == command.Definition.Name && !command.AllowDM && i.Interaction.GuildID == "" { |  | ||||||
| 			respond(i.Interaction, "This interaction is not available in DMs.", true) |  | ||||||
| 			return |  | ||||||
| 		} |  | ||||||
| 		switch i.Type { | 		switch i.Type { | ||||||
| 		case discordgo.InteractionApplicationCommand: | 		case discordgo.InteractionApplicationCommand: | ||||||
| 			if command.Interact != nil && i.ApplicationCommandData().Name == command.Definition.Name { | 			if command.Interact != nil && i.ApplicationCommandData().Name == command.Definition.Name { | ||||||
| 				command.Interact(s, i) | 				if !command.AllowDM && i.Interaction.GuildID == "" { | ||||||
|  | 					respond(i.Interaction, "This command is not available in DMs.", true) | ||||||
|  | 				} else { | ||||||
|  | 					command.Interact(s, i) | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 		case discordgo.InteractionApplicationCommandAutocomplete: | 		case discordgo.InteractionApplicationCommandAutocomplete: | ||||||
| 			if command.Autocomplete != nil && i.ApplicationCommandData().Name == command.Definition.Name { | 			if command.Autocomplete != nil && i.ApplicationCommandData().Name == command.Definition.Name && command.AllowDM && i.Interaction.GuildID != "" { | ||||||
| 				command.Autocomplete(s, i) | 				command.Autocomplete(s, i) | ||||||
| 			} | 			} | ||||||
| 		case discordgo.InteractionModalSubmit: | 		case discordgo.InteractionModalSubmit: | ||||||
| 			if command.ModalSubmit != nil { | 			if !command.AllowDM && i.Interaction.GuildID == "" { | ||||||
| 				// FIXME: Makes it dynamic i don't know why it isn't otherwise | 				respond(i.Interaction, "This modal is not available in DMs.", true) | ||||||
| 				if command.Definition.Name == "form" { | 			} else { | ||||||
| 					command.ModalIDs = getFormButtonIDs() |  | ||||||
| 				} |  | ||||||
| 				var hasID bool = false |  | ||||||
| 				if command.ModalSubmit != nil { | 				if command.ModalSubmit != nil { | ||||||
|  | 					// FIXME: Makes it dynamic i don't know why it isn't otherwise | ||||||
|  | 					if command.Definition.Name == "form" { | ||||||
|  | 						command.ModalIDs = getFormButtonIDs() | ||||||
|  | 					} | ||||||
|  | 					var hasID bool = false | ||||||
| 					for _, modalID := range command.ModalIDs { | 					for _, modalID := range command.ModalIDs { | ||||||
| 						if strings.HasPrefix(i.ModalSubmitData().CustomID, modalID) { | 						if strings.HasPrefix(i.ModalSubmitData().CustomID, modalID) { | ||||||
| 							hasID = true | 							hasID = true | ||||||
| @@ -97,12 +99,16 @@ func interactionCreate(s *discordgo.Session, i *discordgo.InteractionCreate) { | |||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		case discordgo.InteractionMessageComponent: | 		case discordgo.InteractionMessageComponent: | ||||||
| 			if command.ComponentInteract != nil { | 			if !command.AllowDM && i.Interaction.GuildID == "" { | ||||||
| 				if command.Definition.Name == "form" { | 				respond(i.Interaction, "This component is not available in DMs.", true) | ||||||
| 					command.ComponentIDs = getFormButtonIDs() | 			} else { | ||||||
| 				} // FIXME: Makes it dynamic i don't know why it isn't otherwise | 				if command.ComponentInteract != nil { | ||||||
| 				if slices.Contains(command.ComponentIDs, i.MessageComponentData().CustomID) { | 					if command.Definition.Name == "form" { | ||||||
| 					command.ComponentInteract(s, i) | 						command.ComponentIDs = getFormButtonIDs() | ||||||
|  | 					} // FIXME: Makes it dynamic i don't know why it isn't otherwise | ||||||
|  | 					if slices.Contains(command.ComponentIDs, i.MessageComponentData().CustomID) { | ||||||
|  | 						command.ComponentInteract(s, i) | ||||||
|  | 					} | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user