// Copyright © 2020 Metabolist. All rights reserved. import SwiftUI import KingfisherSwiftUI import ViewModels struct SecondaryNavigationView: View { @StateObject var viewModel: SecondaryNavigationViewModel @Environment(\.presentationMode) var presentationMode @Environment(\.displayScale) var displayScale: CGFloat var body: some View { NavigationView { Form { Section { NavigationLink( destination: IdentitiesView(viewModel: viewModel.identitiesViewModel()), label: { HStack { KFImage(viewModel.identity.image, options: .downsampled(dimension: 50, scaleFactor: displayScale)) VStack(alignment: .leading) { if let account = viewModel.identity.account { CustomEmojiText( text: account.displayName, emoji: account.emojis, textStyle: .headline) } Text(viewModel.identity.handle) .font(.subheadline) .foregroundColor(.secondary) .lineLimit(1) .minimumScaleFactor(0.5) Spacer() Text("secondary-navigation.manage-accounts") .font(.subheadline) } .padding() } }) } Section { NavigationLink(destination: ListsView(viewModel: viewModel.listsViewModel())) { Label("secondary-navigation.lists", systemImage: "scroll") } } Section { NavigationLink( "secondary-navigation.preferences", destination: PreferencesView( viewModel: viewModel.preferencesViewModel())) } } .navigationBarTitleDisplayMode(.inline) .toolbar { ToolbarItem(placement: .cancellationAction) { Button { presentationMode.wrappedValue.dismiss() } label: { Image(systemName: "xmark.circle.fill") } } } } .navigationViewStyle(StackNavigationViewStyle()) } } #if DEBUG import PreviewViewModels struct SecondaryNavigationView_Previews: PreviewProvider { static var previews: some View { SecondaryNavigationView(viewModel: .mock()) .environmentObject(RootViewModel.mock()) .environmentObject(TabNavigationViewModel.mock()) } } #endif