// // ProfileCardView.swift // Passepartout // // Created by Davide De Rosa on 9/5/24. // Copyright (c) 2024 Davide De Rosa. All rights reserved. // // https://github.com/passepartoutvpn // // This file is part of Passepartout. // // Passepartout is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Passepartout is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Passepartout. If not, see . // import AppLibrary import PassepartoutKit import SwiftUI struct ProfileCardView: View { enum Style { case compact case full } let style: Style let header: ProfileHeader @ObservedObject var profileManager: ProfileManager var body: some View { switch style { case .compact: HStack { Text(header.name) .themeTruncating() if isShared { ThemeImage(.cloud) } } .frame(maxWidth: .infinity, alignment: .leading) case .full: VStack(alignment: .leading) { HStack { Text(header.name) .font(.headline) .themeTruncating() if isShared { ThemeImage(.cloud) } } Text(Strings.Views.Profiles.Rows.modules(header.modules.count)) .font(.subheadline) .foregroundStyle(.secondary) } .frame(maxWidth: .infinity, alignment: .leading) } } } private extension ProfileCardView { var isShared: Bool { profileManager.isRemotelyShared(profileWithId: header.id) } } // MARK: - Previews #Preview { List { Section { ProfileCardView( style: .compact, header: Profile.mock.header(), profileManager: .mock ) } Section { ProfileCardView( style: .full, header: Profile.mock.header(), profileManager: .mock ) } } .withMockEnvironment() }