Я сделал представление в SwiftUI, которое оборачивается внутри кнопки в другом представлении.
struct BuySubscriptionView: View {
var subscriptionText: String = "Monthly Subscription"
var amountText: String = "2.99 € / Month"
var body: some View {
HStack() {
VStack(alignment:.leading) {
Text(subscriptionText)
.bold()
.fixedSize()
.foregroundColor(Color(.systemBackground))
.padding(.bottom, 5)
Text("Access to all exercises")
.fixedSize(horizontal: false, vertical: true)
.foregroundColor(Color(.systemBackground))
}.padding(.vertical)
VStack(alignment:.trailing) {
Text("Subscribe")
.foregroundColor(Color.baseDark)
.padding()
.background(Color.white)
.cornerRadius(5)
.padding(1)
.background(Color.black)
.cornerRadius(5)
Text(amountText).bold()
.foregroundColor(Color(.systemBackground))
.padding(.top)
}.padding(.leading)
}
.padding()
.background(Color.baseDark)
.cornerRadius(5)
.padding(1)
.cornerRadius(5)
}
}
Я обертываю его внутри кнопки. Когда я использую его в PreviewProvider, все генерируется правильно:
static var previews: some View {
GeometryReader { geometry in
VStack(spacing: 70) {
Spacer()
Button(action: {
}, label: {
BuySubscriptionView(subscriptionText: "Monthly Subscription", amountText: "29.99€/month").frame(width: geometry.size.width * 0.9, height: geometry.size.width * 0.2, alignment: .center)
})
Button(action: {
}, label: {
BuySubscriptionView().frame(width: geometry.size.width * 0.9, height: geometry.size.width * 0.2, alignment: .center)
})
}
}
}
data:image/s3,"s3://crabby-images/e2729/e2729c56ecf9412401fdbc54aefe4f8ac0205577" alt="enter image description here"
Но при реализации в моем приложении они не совпадают размер больше
var body: some View {
GeometryReader { geometry in
VStack {
Text("Hello " + self.userName + "!" ).font(.title)
Spacer().frame(height: geometry.size.height * 0.1)
self.premiumTextView()
.frame(width: geometry.size.width * 0.6)
Spacer().frame(height: geometry.size.height * 0.1)
Group {
if !self.isPremium {
VStack(alignment: .center,spacing: 70) {
Button(action: {
self.buyPremium()
}, label: {
BuySubscriptionView()
.frame(width: geometry.size.width * 0.9, height: geometry.size.width * 0.2, alignment: .center)
})
Button(action: {
self.buyPremium()
}, label: {
BuySubscriptionView(subscriptionText: "Yearly Subscription", amountText: "29.99 € / Year")
.frame(width: geometry.size.width * 0.9, height: geometry.size.width * 0.2, alignment: .center)
})
}
} else {
EmptyView()
}
}
Spacer().frame(height: geometry.size.height * 0.1)
LogInOutButton(action: {
self.logOut()
}, title: "Log out", width: geometry.size.width * 0.7)
}
}
}
И это выглядит так:
data:image/s3,"s3://crabby-images/c7068/c7068bfaeced85601f1feef589487c4331266cfd" alt="enter image description here"
Почему он так себя ведет? Что я сделал не так?