Spaces:
Paused
Paused
Update currentbets.py
Browse files- currentbets.py +23 -11
currentbets.py
CHANGED
|
@@ -1,34 +1,40 @@
|
|
| 1 |
from discord import app_commands
|
| 2 |
import discord
|
| 3 |
-
from
|
| 4 |
|
| 5 |
-
@app_commands.command(name="currentbets", description="
|
| 6 |
async def currentbets(interaction: discord.Interaction):
|
| 7 |
user_id = interaction.user.id
|
| 8 |
if user_id not in user_bets or not user_bets[user_id]:
|
| 9 |
-
await interaction.response.send_message("
|
| 10 |
return
|
| 11 |
|
| 12 |
-
embed = discord.Embed(title="Current Bets", color=0x787878)
|
| 13 |
for i, bet in enumerate(user_bets[user_id], 1):
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 14 |
embed.add_field(
|
| 15 |
name=f"Bet {i}",
|
| 16 |
-
value=f"Team: {bet['team']}\nAmount: ${bet['amount']}\nGame: {bet['game_data']['teams']['away']['teamName']} vs {bet['game_data']['teams']['home']['teamName']}\
|
| 17 |
inline=False
|
| 18 |
)
|
| 19 |
|
| 20 |
view = discord.ui.View()
|
| 21 |
select = discord.ui.Select(
|
| 22 |
-
placeholder="Select a bet to
|
| 23 |
options=[discord.SelectOption(label=f"Bet {i}", value=str(i-1)) for i in range(1, len(user_bets[user_id])+1)]
|
| 24 |
)
|
| 25 |
|
| 26 |
async def select_callback(interaction: discord.Interaction):
|
| 27 |
bet_index = int(select.values[0])
|
| 28 |
removed_bet = user_bets[user_id].pop(bet_index)
|
| 29 |
-
user_cash[user_id] += removed_bet['amount']
|
| 30 |
|
| 31 |
-
await interaction.response.send_message(f"Bet on {removed_bet['team']} for ${removed_bet['amount']} has been
|
| 32 |
|
| 33 |
if not user_bets[user_id]:
|
| 34 |
del user_bets[user_id]
|
|
@@ -38,19 +44,25 @@ async def currentbets(interaction: discord.Interaction):
|
|
| 38 |
new_view = discord.ui.View()
|
| 39 |
if user_id in user_bets and user_bets[user_id]:
|
| 40 |
for i, bet in enumerate(user_bets[user_id], 1):
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 41 |
new_embed.add_field(
|
| 42 |
name=f"Bet {i}",
|
| 43 |
-
value=f"Team: {bet['team']}\nAmount: ${bet['amount']}\nGame: {bet['game_data']['teams']['away']['teamName']} vs {bet['game_data']['teams']['home']['teamName']}\
|
| 44 |
inline=False
|
| 45 |
)
|
| 46 |
new_select = discord.ui.Select(
|
| 47 |
-
placeholder="Select a bet to
|
| 48 |
options=[discord.SelectOption(label=f"Bet {i}", value=str(i-1)) for i in range(1, len(user_bets[user_id])+1)]
|
| 49 |
)
|
| 50 |
new_select.callback = select_callback
|
| 51 |
new_view.add_item(new_select)
|
| 52 |
else:
|
| 53 |
-
new_embed.description = "
|
| 54 |
|
| 55 |
await interaction.message.edit(embed=new_embed, view=new_view)
|
| 56 |
|
|
|
|
| 1 |
from discord import app_commands
|
| 2 |
import discord
|
| 3 |
+
from main import user_cash, user_bets, fetch_nhl_scores
|
| 4 |
|
| 5 |
+
@app_commands.command(name="currentbets", description="vie wbets")
|
| 6 |
async def currentbets(interaction: discord.Interaction):
|
| 7 |
user_id = interaction.user.id
|
| 8 |
if user_id not in user_bets or not user_bets[user_id]:
|
| 9 |
+
await interaction.response.send_message("You got any bets.", ephemeral=True)
|
| 10 |
return
|
| 11 |
|
| 12 |
+
embed = discord.Embed(title="Your Current Bets", color=0x787878)
|
| 13 |
for i, bet in enumerate(user_bets[user_id], 1):
|
| 14 |
+
scores = await fetch_nhl_scores()
|
| 15 |
+
game = next((g for g in scores['games'] if g['teams']['away']['abbreviation'] == bet['game_data']['teams']['away']['abbreviation'] and
|
| 16 |
+
g['teams']['home']['abbreviation'] == bet['game_data']['teams']['home']['abbreviation']), None)
|
| 17 |
+
|
| 18 |
+
score_info = f"Current Score: {game['scores']['away']} - {game['scores']['home']}" if game and 'scores' in game else "Score not available"
|
| 19 |
+
|
| 20 |
embed.add_field(
|
| 21 |
name=f"Bet {i}",
|
| 22 |
+
value=f"Team: {bet['team']}\nAmount: ${bet['amount']}\nGame: {bet['game_data']['teams']['away']['teamName']} vs {bet['game_data']['teams']['home']['teamName']}\n{score_info}",
|
| 23 |
inline=False
|
| 24 |
)
|
| 25 |
|
| 26 |
view = discord.ui.View()
|
| 27 |
select = discord.ui.Select(
|
| 28 |
+
placeholder="Select a bet to cancel",
|
| 29 |
options=[discord.SelectOption(label=f"Bet {i}", value=str(i-1)) for i in range(1, len(user_bets[user_id])+1)]
|
| 30 |
)
|
| 31 |
|
| 32 |
async def select_callback(interaction: discord.Interaction):
|
| 33 |
bet_index = int(select.values[0])
|
| 34 |
removed_bet = user_bets[user_id].pop(bet_index)
|
| 35 |
+
user_cash[user_id] += removed_bet['amount'] # Refund the bet amount
|
| 36 |
|
| 37 |
+
await interaction.response.send_message(f"Bet on {removed_bet['team']} for ${removed_bet['amount']} has been cancelled and refunded.", ephemeral=True)
|
| 38 |
|
| 39 |
if not user_bets[user_id]:
|
| 40 |
del user_bets[user_id]
|
|
|
|
| 44 |
new_view = discord.ui.View()
|
| 45 |
if user_id in user_bets and user_bets[user_id]:
|
| 46 |
for i, bet in enumerate(user_bets[user_id], 1):
|
| 47 |
+
scores = await fetch_nhl_scores()
|
| 48 |
+
game = next((g for g in scores['games'] if g['teams']['away']['abbreviation'] == bet['game_data']['teams']['away']['abbreviation'] and
|
| 49 |
+
g['teams']['home']['abbreviation'] == bet['game_data']['teams']['home']['abbreviation']), None)
|
| 50 |
+
|
| 51 |
+
score_info = f"Current Score: {game['scores']['away']} - {game['scores']['home']}" if game and 'scores' in game else "Score not available"
|
| 52 |
+
|
| 53 |
new_embed.add_field(
|
| 54 |
name=f"Bet {i}",
|
| 55 |
+
value=f"Team: {bet['team']}\nAmount: ${bet['amount']}\nGame: {bet['game_data']['teams']['away']['teamName']} vs {bet['game_data']['teams']['home']['teamName']}\n{score_info}",
|
| 56 |
inline=False
|
| 57 |
)
|
| 58 |
new_select = discord.ui.Select(
|
| 59 |
+
placeholder="Select a bet to cancel",
|
| 60 |
options=[discord.SelectOption(label=f"Bet {i}", value=str(i-1)) for i in range(1, len(user_bets[user_id])+1)]
|
| 61 |
)
|
| 62 |
new_select.callback = select_callback
|
| 63 |
new_view.add_item(new_select)
|
| 64 |
else:
|
| 65 |
+
new_embed.description = "none active bets."
|
| 66 |
|
| 67 |
await interaction.message.edit(embed=new_embed, view=new_view)
|
| 68 |
|