passepartout-apple/Packages/App/Sources/UILibrary/Theme/Theme.swift
Davide 1942b82ebb
Rework App+Kit as monorepository (#1055)
Simplify development and maintenance immensely by making this a
monorepository:

- Convert PassepartoutKit and VPN bindings to local packages
  - OpenVPN/OpenSSL
  - WireGuard/Go
- Make PassepartoutKit available via
  - Source submodule for production (private)
- [Binary XCFramework for
development](https://github.com/passepartoutvpn/passepartoutkit)
 - Add PassepartoutKit Demo in root
   - Deploy package later
2025-01-13 12:26:53 +01:00

102 lines
3.0 KiB
Swift

//
// Theme.swift
// Passepartout
//
// Created by Davide De Rosa on 8/18/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 <http://www.gnu.org/licenses/>.
//
import CommonUtils
import SwiftUI
@MainActor
public final class Theme: ObservableObject {
private var animation: Animation = .spring
public internal(set) var animationCategories: Set<ThemeAnimationCategory> = Set(ThemeAnimationCategory.allCases)
public internal(set) var relevantWeight: Font.Weight = .semibold
public internal(set) var secondaryWeight: Font.Weight = .light
public internal(set) var titleColor: Color = .primary
public internal(set) var valueColor: Color = .secondary
public internal(set) var gridHeaderStyle: Font = .headline
public internal(set) var gridRadius: CGFloat = 12.0
public internal(set) var gridHeaderBottom: CGFloat = 8.0
public internal(set) var gridCellColor: HierarchicalShapeStyle = .quinary
public internal(set) var gridCellActiveColor: HierarchicalShapeStyle = .quaternary
public internal(set) var emptyMessageFont: Font = .title
public internal(set) var emptyMessageColor: Color = .secondary
public internal(set) var primaryColor = Color(
red: Double(0x51) / 255.0,
green: Double(0x5D) / 255.0,
blue: Double(0x70) / 255.0
)
public internal(set) var activeColor = Color(
red: .zero,
green: Double(0xAA) / 255.0,
blue: .zero
)
public internal(set) var inactiveColor: Color = .gray
public internal(set) var pendingColor: Color = .orange
public internal(set) var errorColor: Color = .red
public var enableColor: Color {
activeColor
}
public var disableColor: Color {
errorColor
}
public internal(set) var upgradeColor: Color = .orange
public internal(set) var logoImage = "Logo"
public internal(set) var modalSize: (ThemeModalSize) -> CGSize = {
$0.defaultSize
}
public internal(set) var systemImageName: (ImageName) -> String = Theme.ImageName.defaultSystemName
public internal(set) var menuImageName: (MenuImageName) -> String = Theme.MenuImageName.defaultImageName
init(dummy: Void) {
}
public func animation(for category: ThemeAnimationCategory) -> Animation? {
animationCategories.contains(category) ? animation : nil
}
}