// // Theme+macOS.swift // Passepartout // // Created by Davide De Rosa on 7/31/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 . // #if os(macOS) import SwiftUI extension Theme { public convenience init() { self.init(dummy: Void()) rootModalSize = CGSize(width: 700, height: 400) secondaryModalSize = CGSize(width: 500.0, height: 200.0) animationCategories = [.profiles, .diagnostics] } } // MARK: - Modifiers extension ThemeWindowModifier { func body(content: Content) -> some View { content .frame(width: size.width, height: size.height) } } extension ThemeNavigationDetailModifier { func body(content: Content) -> some View { content } } extension ThemePlainButtonModifier { func body(content: Content) -> some View { Button(action: action) { content .frame(maxWidth: .infinity) .contentShape(.rect) } .buttonStyle(.plain) .cursor(.hand) } } extension ThemeManualInputModifier { func body(content: Content) -> some View { content .autocorrectionDisabled() } } extension ThemeSectionWithHeaderFooterModifier { @ViewBuilder func body(content: Content) -> some View { Section { content footer.map { Text($0) .foregroundStyle(.secondary) .font(.callout) .frame(maxWidth: .infinity, alignment: .leading) } } header: { header.map(Text.init) } } } // MARK: - Views extension ThemeTappableText { var body: some View { commonView .buttonStyle(.plain) .cursor(.hand) } } extension ThemeTextField { var body: some View { commonView .labelsHidden() } } extension ThemeSecureField { var body: some View { commonView .labelsHidden() } } extension ThemeRemovableItemRow { func removeView() -> some View { Button(action: removeAction) { ThemeImage(.contextRemove) } .buttonStyle(.borderless) } } extension ThemeEditableListSection.RemoveLabel { var body: some View { Button(action: action) { ThemeImage(.editableSectionRemove) } .buttonStyle(.borderless) } } extension ThemeEditableListSection.EditLabel { var body: some View { ThemeImage(.editableSectionEdit) } } #endif