Merge branch '2.0' of https://github.com/iDevision/enhanced-discord.py into flags_option_description
This commit is contained in:
		| @@ -136,6 +136,14 @@ application_option_type_lookup = { | |||||||
|     discord.Role: 8, |     discord.Role: 8, | ||||||
|     float: 10, |     float: 10, | ||||||
| } | } | ||||||
|  | application_option_channel_types = { | ||||||
|  |     discord.VoiceChannel: [2], | ||||||
|  |     discord.TextChannel: [0, 5, 6], | ||||||
|  |     discord.CategoryChannel: [4], | ||||||
|  |     discord.Thread: [10, 11, 12], | ||||||
|  |     discord.StageChannel: [13], | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| if TYPE_CHECKING: | if TYPE_CHECKING: | ||||||
|     P = ParamSpec("P") |     P = ParamSpec("P") | ||||||
| @@ -1275,12 +1283,19 @@ class Command(_BaseCommand, Generic[CogT, P, T]): | |||||||
|             for python_type, discord_type in application_option_type_lookup.items(): |             for python_type, discord_type in application_option_type_lookup.items(): | ||||||
|                 if issubclass(annotation, python_type): |                 if issubclass(annotation, python_type): | ||||||
|                     option["type"] = discord_type |                     option["type"] = discord_type | ||||||
|  |                     # Set channel types | ||||||
|  |                     if discord_type == 7: | ||||||
|  |                         option["channel_types"] = application_option_channel_types[annotation] | ||||||
|                     break |                     break | ||||||
|  |  | ||||||
|         elif origin is Union: |         elif origin is Union: | ||||||
|             if annotation in {Union[discord.Member, discord.Role], Union[MemberConverter, RoleConverter]}: |             if annotation in {Union[discord.Member, discord.Role], Union[MemberConverter, RoleConverter]}: | ||||||
|                 option["type"] = 9 |                 option["type"] = 9 | ||||||
|  |  | ||||||
|  |             elif all([arg in application_option_channel_types for arg in annotation.__args__]): | ||||||
|  |                 option["type"] = 7 | ||||||
|  |                 option["channel_types"] = [discord_value for arg in annotation.__args__ for discord_value in application_option_channel_types[arg]] | ||||||
|  |  | ||||||
|         elif origin is Literal: |         elif origin is Literal: | ||||||
|             literal_values = annotation.__args__ |             literal_values = annotation.__args__ | ||||||
|             python_type = type(literal_values[0]) |             python_type = type(literal_values[0]) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user