Go to file
Zach Eriksen 2dd3c57c30 Changed ViewValueView to KeyValueView 2021-06-16 11:29:18 -05:00
.swiftpm/xcode/package.xcworkspace 👊 commit 2021-06-16 11:27:27 -05:00
Sources/KeyValueView Changed ViewValueView to KeyValueView 2021-06-16 11:29:18 -05:00
Tests 👊 commit 2021-06-16 11:27:27 -05:00
.gitignore 👊 commit 2021-06-16 11:27:27 -05:00
Package.swift 👊 commit 2021-06-16 11:27:27 -05:00
README.md 👊 commit 2021-06-16 11:27:27 -05:00

README.md

KeyValueView

A Color and String KeyValue SwiftUI View

Usage

import KeyValueView

Example

public enum SomeColors: String, Hashable {
    case textColor, backgroundColor, iconColor
}

public enum SomeStrings: String, Hashable {
    case usageDescription
}

public struct SomeView<
    ColorDictionary: ColorProviding,
    StringDictionary: StringProviding
>: KeyValueView where ColorDictionary.ColorKey == SomeColors,
                    StringDictionary.StringKey == SomeStrings {
                    
    public var colorDictionary: ColorDictionary
    public var stringDictionary: StringDictionary
    
    public init(
        colorDictionary: ColorDictionary,
        stringDictionary: StringDictionary
    ) {
        self.colorDictionary = colorDictionary
        self.stringDictionary = stringDictionary
    }
    
    public var body: some View {
        Text(string(forKey: .usageDescription, defaultString: "👋"))
            .foregroundColor(color(forKey: .textColor, defaultColor: .white))
            .background(color(forKey: .backgroundColor, defaultColor: .clear))
    }
}

Using a KeyValueView

Define Colors and Strings

struct SomeColorDictionary: ColorProviding {
    var colors: [SomeColors : UIColor] = [
        .backgroundColor: .orange,
        .textColor: .blue
    ]
}

struct SomeStringDictionary: StringProviding {
    var strings: [SomeStrings : String] = [
        .usageDescription: "import KeyValueView"
    ]
}

Create a KeyValueView

SomeView(
    colorDictionary: SomeColorDictionary(),
    stringDictionary: SomeStringDictionary()
)