You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
3.2 KiB
87 lines
3.2 KiB
//
|
|
// BetCard.swift
|
|
// AllIn
|
|
//
|
|
// Created by Lucas on 24/09/2023.
|
|
//
|
|
|
|
import SwiftUI
|
|
import Model
|
|
|
|
struct BetCard: View {
|
|
|
|
var bet: Bet
|
|
@State var showDetails: Bool = false
|
|
@State var showParticipate: Bool = false
|
|
|
|
var body: some View {
|
|
VStack(spacing: 0) {
|
|
VStack(alignment: .leading,spacing: 2){
|
|
HStack{
|
|
Spacer()
|
|
Text("bet_proposed_by_format \(bet.author.capitalized)")
|
|
.font(.system(size: 10))
|
|
.foregroundColor(AllInColors.grey800Color)
|
|
}
|
|
Text(bet.theme)
|
|
.font(.system(size: 15))
|
|
.foregroundColor(AllInColors.grey800Color)
|
|
Text(bet.phrase)
|
|
.font(.system(size: 20))
|
|
.fontWeight(.bold)
|
|
HStack{
|
|
Text("bet_starting")
|
|
.font(.system(size: 15))
|
|
.foregroundColor(AllInColors.grey800Color)
|
|
TextCapsule(date: bet.endRegisterDate)
|
|
Spacer()
|
|
}
|
|
}
|
|
.frame(width: .infinity)
|
|
.padding(.all,15)
|
|
.background(AllInColors.componentBackgroundColor).cornerRadius(20, corners: [.topLeft,.topRight]).padding(.bottom,0)
|
|
|
|
VStack(alignment: .leading,spacing: 2){
|
|
HStack{
|
|
Spacer()
|
|
UsersPreview(users: [])
|
|
Text("bet_players_waiting_format \(bet.invited.count.description)")
|
|
.font(.system(size: 15))
|
|
.foregroundColor(AllInColors.grey800Color)
|
|
.fontWeight(.medium)
|
|
Spacer()
|
|
|
|
}
|
|
.padding(0)
|
|
ParticipateButton(isOpen: $showDetails, isParticapatedOpen: $showParticipate, bet: bet)
|
|
.padding(.top, 5)
|
|
}
|
|
.frame(width: .infinity)
|
|
.padding(.all,8)
|
|
.background(AllInColors.underComponentBackgroundColor)
|
|
.cornerRadius(20, corners: [.bottomLeft,.bottomRight])
|
|
.border(width: 1, edges: [.top], color: AllInColors.delimiterGrey)
|
|
}
|
|
.onTapGesture {
|
|
showDetails.toggle()
|
|
}
|
|
.fullScreenCover(isPresented: $showDetails) {
|
|
DetailsView(isModalPresented: $showDetails, isModalParticipated: $showParticipate, id: bet.id)
|
|
}
|
|
}
|
|
}
|
|
|
|
struct BetCard_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
BetCard(bet: BinaryBet(theme: "Football - Finale de la Ligue des Champions",
|
|
phrase: "Le gagnant de la finale sera l'équipe avec le plus de tirs au but.",
|
|
endRegisterDate: Date().addingTimeInterval(86400),
|
|
endBetDate: Date().addingTimeInterval(172800),
|
|
isPrivate: false,
|
|
status: .inProgress,
|
|
invited: [],
|
|
author: "Imri"))
|
|
.preferredColorScheme(.dark)
|
|
}
|
|
}
|