Merge pull request #5 from PrajeetShrestha/theme close #3

Color Set added for light and dark mode.
This commit is contained in:
Thomas Ricouard 2022-12-31 06:50:05 +01:00 committed by GitHub
commit 423df5f4b4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 65 additions and 8 deletions

View file

@ -0,0 +1,26 @@
import SwiftUI
public protocol ColorSet {
var tintColor: Color { get set }
var primaryBackgroundColor: Color { get set }
var secondaryBackgroundColor: Color { get set }
var labelColor: Color { get set }
}
public struct DarkSet: ColorSet {
public var tintColor: Color = Color(red: 187/255, green: 59/255, blue: 226/255)
public var primaryBackgroundColor: Color = Color(red: 16/255, green: 21/255, blue: 35/255)
public var secondaryBackgroundColor: Color = Color(red: 30/255, green: 35/255, blue: 62/255)
public var labelColor: Color = .white
public init() {}
}
public struct LightSet: ColorSet {
public var tintColor: Color = Color(red: 187/255, green: 59/255, blue: 226/255)
public var primaryBackgroundColor: Color = .white
public var secondaryBackgroundColor: Color = Color(hex:0xF0F1F2)
public var labelColor: Color = .black
public init() {}
}

View file

@ -40,3 +40,13 @@ extension Color: RawRepresentable {
return CIColor(color: .init(self)) return CIColor(color: .init(self))
} }
} }
extension Color {
init(hex: Int, opacity: Double = 1.0) {
let red = Double((hex & 0xff0000) >> 16) / 255.0
let green = Double((hex & 0xff00) >> 8) / 255.0
let blue = Double((hex & 0xff) >> 0) / 255.0
self.init(.sRGB, red: red, green: green, blue: blue, opacity: opacity)
}
}

View file

@ -2,14 +2,35 @@ import SwiftUI
public class Theme: ObservableObject { public class Theme: ObservableObject {
enum ThemeKey: String { enum ThemeKey: String {
case colorScheme, tint, label, primaryBackground, secondaryBackground case colorScheme, tint, label, primaryBackground, secondaryBackground
} }
@AppStorage(ThemeKey.colorScheme.rawValue) public var colorScheme: String = "dark" @AppStorage("is_previously_set") var isSet: Bool = false
@AppStorage(ThemeKey.tint.rawValue) public var tintColor: Color = .brand @AppStorage(ThemeKey.colorScheme.rawValue) public var colorScheme: String = "dark" {
@AppStorage(ThemeKey.primaryBackground.rawValue) public var primaryBackgroundColor: Color = .primaryBackground didSet {
@AppStorage(ThemeKey.secondaryBackground.rawValue) public var secondaryBackgroundColor: Color = .secondaryBackground if colorScheme == "dark" {
@AppStorage(ThemeKey.label.rawValue) public var labelColor: Color = .label setColor(set: DarkSet())
} else {
setColor(set: LightSet())
}
}
}
@AppStorage(ThemeKey.tint.rawValue) public var tintColor: Color = .black
@AppStorage(ThemeKey.primaryBackground.rawValue) public var primaryBackgroundColor: Color = .white
@AppStorage(ThemeKey.secondaryBackground.rawValue) public var secondaryBackgroundColor: Color = .gray
@AppStorage(ThemeKey.label.rawValue) public var labelColor: Color = .black
public init() { } public init() {
if !isSet {
setColor(set: DarkSet())
isSet.toggle()
}
}
public func setColor(set: ColorSet) {
self.tintColor = set.tintColor
self.primaryBackgroundColor = set.primaryBackgroundColor
self.secondaryBackgroundColor = set.secondaryBackgroundColor
self.labelColor = set.labelColor
}
} }