1. Create Plist
Add plist file to your project or copy a demo file from the demo project.
2. Define your plist keys
Add keys and values to your plist file
3. Initialize theme manager
var themeLoader = DB6ThemeLoader(themeFilename: "DB6Demo") var theme = DB6Theme.default
4. Read primitive values
let stringKey = "string" let stringValue: String? = theme?.string(key: stringKey) let key = "integer" let value: Int? = theme?.integer(key: key) let key = "float" let value: Float = theme?.float(key: key) let key = "double" let value: Double = theme?.double(key: key) let key = "boolean" let value: Bool = theme?.bool(key: key) let key = "colorHex" let value: UIColor = theme?.color(key: key)
Read values by reference
The theme manager allows you to read not only values from the plist file, but also use references for another values. A reference starts with @ symbol. If the there is not such key in the dictionary the reference string will be returned.
Style your UI controls.
You can style your UI controls with a dictionary in plist file. See the demo project.
You can add multiple styles in the Interface Builder. There is "style" custom attribute.
You can add multiple styles to your controll programmatically.
let style = "loginbutton" let button = UIButton() theme.update(button: button, key: style)
Supported UI controls and attributes
The demo app is very simple and straightforward, it explains how the library works via some sample code and unit tests.
DB6 is available on CocoaPods.
Add the following to your
Carthage - not available yet
DB6 is available through Carthage. To install it, simply add the following line to your Cartfile:
DB6 is available under the MIT license. See the LICENSE file for details.
- [x] Add variables
- [x] Add support for native plist types (Number, Boolean, Date)
- [ ] Add support for plist dictionaries
- [ ] Add support for plist arrays
- [x] Add Cocoa pod support
- [ ] Add Swift package manager support
- [ ] Add Carthage support
- [ ] Add theme switcher
- [ ] Add more UI components
- [ ] Add RGB color support