0
|
1 //
|
|
2 // GameToolbar.swift
|
|
3 // GeoQuiz
|
|
4 //
|
|
5 // Created by Dennis Concepción Martín on 18/9/22.
|
|
6 //
|
|
7
|
|
8 import SwiftUI
|
|
9
|
3
|
10 struct GameToolbar<T: Game>: View {
|
0
|
11 @Binding var gameName: GameName?
|
3
|
12 @ObservedObject var game: T
|
|
13
|
0
|
14
|
|
15 var body: some View {
|
|
16 HStack(spacing: 0) {
|
|
17 Group {
|
|
18 Button {
|
|
19 gameName = nil
|
|
20 } label: {
|
|
21 Image(systemName: "multiply")
|
|
22 .padding(10)
|
|
23 .background(
|
|
24 Circle()
|
|
25 .strokeBorder(lineWidth: 2)
|
|
26 )
|
|
27 }
|
|
28 }
|
|
29 .foregroundColor(.white)
|
|
30 .font(.headline)
|
|
31 .frame(maxWidth: .infinity, alignment: .leading)
|
|
32
|
|
33 Group {
|
3
|
34 Text("\(game.userScore)")
|
0
|
35 .padding()
|
|
36 .background(
|
|
37 Circle()
|
|
38 .strokeBorder(lineWidth: 3)
|
|
39 )
|
|
40 }
|
|
41 .foregroundColor(.white)
|
|
42 .font(.title2)
|
3
|
43 .scaleEffect(game.scoreScaleAmount)
|
0
|
44 .frame(maxWidth: .infinity, alignment: .center)
|
|
45
|
|
46 Group {
|
|
47 Button {
|
3
|
48 game.showingBuyLivesView = true
|
0
|
49 } label: {
|
|
50 HStack {
|
|
51 Image(systemName: "heart.fill")
|
3
|
52 Text("\(game.userLives)")
|
0
|
53 }
|
|
54 .padding(10)
|
|
55 .background(
|
|
56 Capsule()
|
|
57 .strokeBorder(lineWidth: 2)
|
|
58 )
|
3
|
59 .scaleEffect(game.livesScaleAmount)
|
0
|
60 }
|
|
61 }
|
|
62 .foregroundColor(.white)
|
|
63 .font(.headline)
|
|
64 .frame(maxWidth: .infinity, alignment: .trailing)
|
|
65 }
|
|
66 }
|
|
67 }
|
|
68
|
|
69 struct GameToolbar_Previews: PreviewProvider {
|
|
70 static var previews: some View {
|
|
71 ZStack {
|
|
72 LinearGradient(gradient: .main, startPoint: .top, endPoint: .bottom)
|
|
73 .ignoresSafeArea()
|
|
74
|
|
75 GeometryReader { geo in
|
|
76 VStack {
|
|
77 GameToolbar(
|
3
|
78 gameName: .constant(GameName.guessTheFlag),
|
|
79 game: GuessTheFlag()
|
0
|
80 )
|
|
81
|
|
82 Spacer()
|
|
83 }
|
|
84 .padding()
|
|
85 }
|
|
86 }
|
|
87 }
|
|
88 }
|