secant-ios-wallet/modules/Sources/Features/DeleteWallet/DeleteWalletView.swift

88 lines
2.5 KiB
Swift

//
// DeleteWalletView.swift
// secant-testnet
//
// Created by Lukáš Korba on 03-27-2024
//
import SwiftUI
import ComposableArchitecture
import Generated
import UIComponents
public struct DeleteWalletView: View {
@Perception.Bindable var store: StoreOf<DeleteWallet>
public init(store: StoreOf<DeleteWallet>) {
self.store = store
}
public var body: some View {
WithPerceptionTracking {
ScrollView {
Group {
ZashiIcon()
Text(L10n.DeleteWallet.title)
.font(.custom(FontFamily.Archivo.semiBold.name, size: 25))
.padding(.bottom, 15)
VStack(alignment: .leading) {
Text(L10n.DeleteWallet.message1)
.font(.custom(FontFamily.Inter.bold.name, size: 16))
Text(L10n.DeleteWallet.message2)
.font(.custom(FontFamily.Inter.medium.name, size: 16))
.padding(.top, 20)
}
HStack {
Toggle(isOn: $store.isAcknowledged, label: {
Text(L10n.DeleteWallet.iUnderstand)
.font(.custom(FontFamily.Inter.medium.name, size: 14))
})
.toggleStyle(CheckboxToggleStyle())
Spacer()
}
.padding(.top, 30)
Button(L10n.DeleteWallet.actionButtonTitle.uppercased()) {
store.send(.deleteTapped)
}
.zcashStyle()
.disabled(!store.isAcknowledged || store.isProcessing)
.padding(.vertical, 50)
}
.padding(.horizontal, 60)
}
.padding(.vertical, 1)
.zashiBack(store.isProcessing)
}
.navigationBarTitleDisplayMode(.inline)
.applyScreenBackground(withPattern: true)
}
}
// MARK: - Previews
#Preview {
DeleteWalletView(store: DeleteWallet.demo)
}
// MARK: - Store
extension DeleteWallet {
public static var demo = StoreOf<DeleteWallet>(
initialState: .initial
) {
DeleteWallet()
}
}
// MARK: - Placeholders
extension DeleteWallet.State {
public static let initial = DeleteWallet.State()
}