black format
This commit is contained in:
		
							parent
							
								
									18f5a3afc5
								
							
						
					
					
						commit
						eda036a1b0
					
				
							
								
								
									
										201
									
								
								fight/fight.py
									
									
									
									
									
								
							
							
						
						
									
										201
									
								
								fight/fight.py
									
									
									
									
									
								
							| @ -12,9 +12,14 @@ from redbot.core.utils.chat_formatting import pagify | ||||
| # from typing import Union | ||||
| 
 | ||||
| # 0 - Robin, 1 - Single, 2 - Double, 3 - Triple, 4 - Guarantee, 5 - Compass | ||||
| T_TYPES = {0: "Round Robin", 1: "Single Elimination", | ||||
|            2: "Double Elimination", 3: "Triple Elimination", | ||||
|            4: "3 Game Guarantee", 5: "Compass Draw"} | ||||
| T_TYPES = { | ||||
|     0: "Round Robin", | ||||
|     1: "Single Elimination", | ||||
|     2: "Double Elimination", | ||||
|     3: "Triple Elimination", | ||||
|     4: "3 Game Guarantee", | ||||
|     5: "Compass Draw", | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| class Fight: | ||||
| @ -30,7 +35,7 @@ class Fight: | ||||
|             "loss": None, | ||||
|             "lossu": None, | ||||
|             "dispute": None, | ||||
|             "disputeu": None | ||||
|             "disputeu": None, | ||||
|         } | ||||
|         default_guild = { | ||||
|             "current": None, | ||||
| @ -39,13 +44,9 @@ class Fight: | ||||
|                 "selfreport": True, | ||||
|                 "reportchnnl": None, | ||||
|                 "announcechnnl": None, | ||||
|                 "admin": None | ||||
|                 "admin": None, | ||||
|             }, | ||||
|             "emoji": { | ||||
|                 "nums": [], | ||||
|                 "undo": None, | ||||
|                 "appr": None | ||||
|             } | ||||
|             "emoji": {"nums": [], "undo": None, "appr": None}, | ||||
|         } | ||||
|         self.default_tourney = { | ||||
|             "PLAYERS": [], | ||||
| @ -53,30 +54,19 @@ class Fight: | ||||
|             "RULES": {"BESTOF": 1, "BESTOFFINAL": 1, "TYPE": 0}, | ||||
|             "TYPEDATA": {}, | ||||
|             "OPEN": False, | ||||
|             "WINNER": None | ||||
|             "WINNER": None, | ||||
|         } | ||||
|         self.default_match = { | ||||
|             "TEAM1": [], | ||||
|             "TEAM2": [], | ||||
|             "SCORE1": None, | ||||
|             "SCORE2": None, | ||||
|             "USERSCORE1": { | ||||
|                 "SCORE1": None, | ||||
|                 "SCORE2": None | ||||
|             }, | ||||
|             "USERSCORE2": { | ||||
|                 "SCORE1": None, | ||||
|                 "SCORE2": None | ||||
|             }, | ||||
|             "USERSCORE1": {"SCORE1": None, "SCORE2": None}, | ||||
|             "USERSCORE2": {"SCORE1": None, "SCORE2": None}, | ||||
|             "WINNER": None, | ||||
|             "DISPUTE": False | ||||
|         } | ||||
|         self.default_tracker = { | ||||
|             "TID": None, | ||||
|             "MID": None, | ||||
|             "RID": None, | ||||
|             "GUILDID": None | ||||
|             "DISPUTE": False, | ||||
|         } | ||||
|         self.default_tracker = {"TID": None, "MID": None, "RID": None, "GUILDID": None} | ||||
|         self.config.register_global(**default_global) | ||||
|         self.config.register_guild(**default_guild) | ||||
| 
 | ||||
| @ -201,7 +191,7 @@ class Fight: | ||||
| 
 | ||||
|     # **********************Fightset command group start********************* | ||||
| 
 | ||||
|     @commands.group(aliases=['setfight']) | ||||
|     @commands.group(aliases=["setfight"]) | ||||
|     @commands.guild_only() | ||||
|     @checks.mod_or_permissions(administrator=True) | ||||
|     async def fightset(self, ctx): | ||||
| @ -228,8 +218,9 @@ class Fight: | ||||
|             try: | ||||
|                 await message.add_reaction(actual_emoji) | ||||
|             except discord.HTTPException: | ||||
|                 await ctx.send("I can't add that emoji because I'm not in the guild that" | ||||
|                                " owns it.") | ||||
|                 await ctx.send( | ||||
|                     "I can't add that emoji because I'm not in the guild that" " owns it." | ||||
|                 ) | ||||
|                 return | ||||
| 
 | ||||
|             if need == "reporting a win": | ||||
| @ -415,20 +406,25 @@ class Fight: | ||||
|             return | ||||
| 
 | ||||
|         if (await self._get_announcechnnl(ctx.guild)) is None:  # Announcechnnl not setup | ||||
|             await ctx.send("Announcement channel has not been configured, see `[p]fightset guild announce`") | ||||
|             await ctx.send( | ||||
|                 "Announcement channel has not been configured, see `[p]fightset guild announce`" | ||||
|             ) | ||||
|             return | ||||
| 
 | ||||
|         if (await self._get_reportchnnl(ctx.guild)) is None:  # Reportchnnl not setup | ||||
|             await ctx.send("Self-Report channel has not been configured, see `[p]fightset guild report`") | ||||
|             await ctx.send( | ||||
|                 "Self-Report channel has not been configured, see `[p]fightset guild report`" | ||||
|             ) | ||||
|             return | ||||
| 
 | ||||
|         if curr_fight["TYPEDATA"]:  # Empty dicionary {} resolves to False | ||||
|             await ctx.send( | ||||
|                 "Looks like this tournament has already started.\nDo you want to delete all match data and restart? " | ||||
|                 "(yes/no)") | ||||
|                 "(yes/no)" | ||||
|             ) | ||||
| 
 | ||||
|             try: | ||||
|                 answer = await self.bot.wait_for('message', check=check, timeout=120) | ||||
|                 answer = await self.bot.wait_for("message", check=check, timeout=120) | ||||
|             except asyncio.TimeoutError: | ||||
|                 await ctx.send("Cancelled due to timeout") | ||||
|                 return | ||||
| @ -454,8 +450,9 @@ class Fight: | ||||
|         Type: 0 (Round Robin)""" | ||||
|         # guild = ctx.message.guild | ||||
|         # currServ = self.the_data[guild.id] | ||||
|         t_id = str(len(await self.config.guild( | ||||
|             ctx.guild).tourneys()))  # Can just be len without +1, tourney 0 makes len 1, tourney 1 makes len 2, etc | ||||
|         t_id = str( | ||||
|             len(await self.config.guild(ctx.guild).tourneys()) | ||||
|         )  # Can just be len without +1, tourney 0 makes len 1, tourney 1 makes len 2, etc | ||||
| 
 | ||||
|         # currServ["CURRENT"] = t_id | ||||
|         curr_fight = self.default_tourney.copy() | ||||
| @ -465,7 +462,9 @@ class Fight: | ||||
| 
 | ||||
|         await ctx.send("Tournament has been created!\n\n" + str(curr_fight)) | ||||
| 
 | ||||
|         await ctx.send("Adjust settings as necessary, then open the tournament with [p]fightset open") | ||||
|         await ctx.send( | ||||
|             "Adjust settings as necessary, then open the tournament with [p]fightset open" | ||||
|         ) | ||||
| 
 | ||||
|     @fightset.command(name="stop") | ||||
|     async def fightset_stop(self, ctx): | ||||
| @ -483,10 +482,13 @@ class Fight: | ||||
|         # currServ = self.the_data[guild.id] | ||||
| 
 | ||||
|         await ctx.send( | ||||
|             "Current fight ID is " + str(await self.config.guild(ctx.guild).current()) + "\nOkay to stop? (yes/no)") | ||||
|             "Current fight ID is " | ||||
|             + str(await self.config.guild(ctx.guild).current()) | ||||
|             + "\nOkay to stop? (yes/no)" | ||||
|         ) | ||||
| 
 | ||||
|         try: | ||||
|             answer = await self.bot.wait_for('message', check=check, timeout=120) | ||||
|             answer = await self.bot.wait_for("message", check=check, timeout=120) | ||||
|         except asyncio.TimeoutError: | ||||
|             await ctx.send("Cancelled due to timeout") | ||||
|             return | ||||
| @ -524,7 +526,7 @@ class Fight: | ||||
| 
 | ||||
|         await self.config.guild(ctx.guild).settings.reportchnnl.set(channel.id) | ||||
| 
 | ||||
|         channel = (await self._get_reportchnnl(ctx.guild)) | ||||
|         channel = await self._get_reportchnnl(ctx.guild) | ||||
|         await ctx.send("Self-Reporting Channel is now set to: " + channel.mention) | ||||
| 
 | ||||
|     @fightset_guild.command(name="announce") | ||||
| @ -535,7 +537,7 @@ class Fight: | ||||
| 
 | ||||
|         await self.config.guild(ctx.guild).settings.announcechnnl.set(channel.id) | ||||
| 
 | ||||
|         channel = (await self._get_announcechnnl(ctx.guild)) | ||||
|         channel = await self._get_announcechnnl(ctx.guild) | ||||
|         await ctx.send("Announcement Channel is now set to: " + channel.mention) | ||||
| 
 | ||||
|     @fightset_guild.command(name="setadmin") | ||||
| @ -600,19 +602,23 @@ class Fight: | ||||
|         :return: | ||||
|         """ | ||||
|         if messagetext: | ||||
|             message = await ctx.send("Please react to this message with the reaction you" | ||||
|             message = await ctx.send( | ||||
|                 "Please react to this message with the reaction you" | ||||
|                 " would like for " + messagetext + ", you have 20 seconds to" | ||||
|                                                                         " respond.") | ||||
|                 " respond." | ||||
|             ) | ||||
|         else: | ||||
|             message = await ctx.send("Please react to this message with the reaction you" | ||||
|             message = await ctx.send( | ||||
|                 "Please react to this message with the reaction you" | ||||
|                 " would like, you have 20 seconds to" | ||||
|                                      " respond.") | ||||
|                 " respond." | ||||
|             ) | ||||
| 
 | ||||
|         def _wait_check(react, user): | ||||
|             msg = react.message | ||||
|             return msg.id == message.id and user.id == ctx.author.id | ||||
| 
 | ||||
|         reaction, _ = await ctx.bot.wait_for('reaction_add', check=_wait_check, timeout=20) | ||||
|         reaction, _ = await ctx.bot.wait_for("reaction_add", check=_wait_check, timeout=20) | ||||
| 
 | ||||
|         try: | ||||
|             ret = reaction.emoji.id | ||||
| @ -668,7 +674,7 @@ class Fight: | ||||
| 
 | ||||
|     async def _embed_tourney(self, ctx, t_id): | ||||
|         """Prints a pretty embed of the tournament""" | ||||
|         #_placeholder Todo | ||||
|         # _placeholder Todo | ||||
|         pass | ||||
| 
 | ||||
|     async def _comparescores(self, ctx): | ||||
| @ -846,19 +852,30 @@ class Fight: | ||||
|         for m_id in the_round: | ||||
|             if not await self._rr_matchover(guild, t_id, m_id): | ||||
|                 match = the_fight["TYPEDATA"]["MATCHES"][m_id] | ||||
|                 if ((match["USERSCORE1"]["SCORE1"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2)) != | ||||
|                         (match["USERSCORE1"]["SCORE2"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2)) and | ||||
|                         (match["USERSCORE2"]["SCORE1"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2)) != | ||||
|                         (match["USERSCORE2"]["SCORE2"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2)) and | ||||
|                         (match["USERSCORE1"]["SCORE1"] == match["USERSCORE2"]["SCORE1"]) and | ||||
|                         (match["USERSCORE1"]["SCORE2"] == match["USERSCORE2"]["SCORE2"])): | ||||
|                 if ( | ||||
|                     (match["USERSCORE1"]["SCORE1"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2)) | ||||
|                     != ( | ||||
|                         match["USERSCORE1"]["SCORE2"] | ||||
|                         == math.ceil(the_fight["RULES"]["BESTOF"] / 2) | ||||
|                     ) | ||||
|                     and ( | ||||
|                         match["USERSCORE2"]["SCORE1"] | ||||
|                         == math.ceil(the_fight["RULES"]["BESTOF"] / 2) | ||||
|                     ) | ||||
|                     != ( | ||||
|                         match["USERSCORE2"]["SCORE2"] | ||||
|                         == math.ceil(the_fight["RULES"]["BESTOF"] / 2) | ||||
|                     ) | ||||
|                     and (match["USERSCORE1"]["SCORE1"] == match["USERSCORE2"]["SCORE1"]) | ||||
|                     and (match["USERSCORE1"]["SCORE2"] == match["USERSCORE2"]["SCORE2"]) | ||||
|                 ): | ||||
| 
 | ||||
|                     the_fight["TYPEDATA"]["MATCHES"][m_id]["SCORE1"] = \ | ||||
|                         the_fight["TYPEDATA"]["MATCHES"][m_id]["USERSCORE1"][ | ||||
|                             "SCORE1"] | ||||
|                     the_fight["TYPEDATA"]["MATCHES"][m_id]["SCORE1"] = \ | ||||
|                         the_fight["TYPEDATA"]["MATCHES"][m_id]["USERSCORE2"][ | ||||
|                             "SCORE2"] | ||||
|                     the_fight["TYPEDATA"]["MATCHES"][m_id]["SCORE1"] = the_fight["TYPEDATA"][ | ||||
|                         "MATCHES" | ||||
|                     ][m_id]["USERSCORE1"]["SCORE1"] | ||||
|                     the_fight["TYPEDATA"]["MATCHES"][m_id]["SCORE1"] = the_fight["TYPEDATA"][ | ||||
|                         "MATCHES" | ||||
|                     ][m_id]["USERSCORE2"]["SCORE2"] | ||||
|                     await self._save_fight(None, t_id, the_fight) | ||||
|                 else: | ||||
|                     await self._rr_report_dispute(guild, t_id, m_id) | ||||
| @ -871,8 +888,9 @@ class Fight: | ||||
|         for rnd in schedule: | ||||
|             for mID in rnd: | ||||
|                 teamnum = await self._rr_matchperms(guild, t_id, userid, mID) | ||||
|                 if teamnum and not await self._rr_matchover(guild, t_id, | ||||
|                                                             mID):  # User is in this match, check if it's done yet | ||||
|                 if teamnum and not await self._rr_matchover( | ||||
|                     guild, t_id, mID | ||||
|                 ):  # User is in this match, check if it's done yet | ||||
|                     return mID | ||||
| 
 | ||||
|         return False  # All matches done or not in tourney | ||||
| @ -881,8 +899,9 @@ class Fight: | ||||
|         the_fight = await self._getfight(guild, t_id) | ||||
|         match = the_fight["TYPEDATA"]["MATCHES"][m_id] | ||||
| 
 | ||||
|         if ((match["SCORE1"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2)) != | ||||
|                 (match["SCORE2"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2))): | ||||
|         if (match["SCORE1"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2)) != ( | ||||
|             match["SCORE2"] == math.ceil(the_fight["RULES"]["BESTOF"] / 2) | ||||
|         ): | ||||
|             return True | ||||
| 
 | ||||
|         return False | ||||
| @ -949,11 +968,17 @@ class Fight: | ||||
| 
 | ||||
|             mention1 = ", ".join(team1) | ||||
|             mention2 = ", ".join(team2) | ||||
|             outembed = discord.Embed(title="Match ID: " + m_id, color=0x0000bf) | ||||
|             outembed = discord.Embed(title="Match ID: " + m_id, color=0x0000BF) | ||||
|             outembed.add_field(name="Team 1", value=mention1, inline=False) | ||||
|             outembed.add_field(name="Team 2", value=mention2, inline=False) | ||||
|             outembed.set_footer(text=(await self._get_win_str()) + " Report Win || " + ( | ||||
|                 await self._get_loss_str()) + " Report Loss || " + (await self._get_dispute_str()) + " Dispute Result") | ||||
|             outembed.set_footer( | ||||
|                 text=(await self._get_win_str()) | ||||
|                 + " Report Win || " | ||||
|                 + (await self._get_loss_str()) | ||||
|                 + " Report Loss || " | ||||
|                 + (await self._get_dispute_str()) | ||||
|                 + " Dispute Result" | ||||
|             ) | ||||
| 
 | ||||
|             if channel: | ||||
|                 message = await channel.send(embed=outembed) | ||||
| @ -1044,11 +1069,34 @@ class Fight: | ||||
|         s = []  # Schedule list | ||||
|         out_id = {}  # Matches | ||||
| 
 | ||||
|         first_id = ["A", "B", "C", "D", "E", "F", | ||||
|                     "G", "H", "I", "J", "K", "L", | ||||
|                     "M", "N", "O", "P", "Q", "R", | ||||
|                     "S", "T", "U", "V", "W", "X", | ||||
|                     "Y", "Z"]  # God dammit this could've been a string | ||||
|         first_id = [ | ||||
|             "A", | ||||
|             "B", | ||||
|             "C", | ||||
|             "D", | ||||
|             "E", | ||||
|             "F", | ||||
|             "G", | ||||
|             "H", | ||||
|             "I", | ||||
|             "J", | ||||
|             "K", | ||||
|             "L", | ||||
|             "M", | ||||
|             "N", | ||||
|             "O", | ||||
|             "P", | ||||
|             "Q", | ||||
|             "R", | ||||
|             "S", | ||||
|             "T", | ||||
|             "U", | ||||
|             "V", | ||||
|             "W", | ||||
|             "X", | ||||
|             "Y", | ||||
|             "Z", | ||||
|         ]  # God dammit this could've been a string | ||||
| 
 | ||||
|         if len(inlist) % 2 == 1: | ||||
|             inlist = inlist + ["BYE"] | ||||
| @ -1105,8 +1153,9 @@ class Fight: | ||||
| 
 | ||||
|     # **************** Attempt 2, borrow from Squid******* | ||||
| 
 | ||||
|     async def on_raw_reaction_add(self, emoji: discord.PartialEmoji, | ||||
|                                   message_id: int, channel_id: int, user_id: int): | ||||
|     async def on_raw_reaction_add( | ||||
|         self, emoji: discord.PartialEmoji, message_id: int, channel_id: int, user_id: int | ||||
|     ): | ||||
|         """ | ||||
|         Event handler for long term reaction watching. | ||||
|         :param discord.PartialReactionEmoji emoji: | ||||
| @ -1132,7 +1181,7 @@ class Fight: | ||||
|             return | ||||
| 
 | ||||
|         if tracker["MID"] != (await self._parseuser(guild, tracker["TID"], member.id)): | ||||
|             message = (await self._get_message_from_id(guild, message_id)) | ||||
|             message = await self._get_message_from_id(guild, message_id) | ||||
|             await message.remove_reaction(emoji, member) | ||||
|             return | ||||
| 
 | ||||
| @ -1144,7 +1193,11 @@ class Fight: | ||||
|         else: | ||||
|             emoji_id = emoji.name | ||||
| 
 | ||||
|         wld = [(await self.config.win()), (await self.config.loss()), (await self.config.dispute())] | ||||
|         wld = [ | ||||
|             (await self.config.win()), | ||||
|             (await self.config.loss()), | ||||
|             (await self.config.dispute()), | ||||
|         ] | ||||
|         if emoji_id not in wld:  # Not sure if this works # It does | ||||
|             await message.remove_reaction(emoji, member) | ||||
|             return | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 bobloy
						bobloy