Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/RxSwiftCommunity/RxTheme
Theme management based on Rx
https://github.com/RxSwiftCommunity/RxTheme
rxcocoa rxswift rxswift-extensions swift theme
Last synced: about 2 months ago
JSON representation
Theme management based on Rx
- Host: GitHub
- URL: https://github.com/RxSwiftCommunity/RxTheme
- Owner: RxSwiftCommunity
- License: mit
- Created: 2018-03-04T09:05:30.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2021-04-23T13:40:43.000Z (over 3 years ago)
- Last Synced: 2024-10-04T04:16:23.876Z (3 months ago)
- Topics: rxcocoa, rxswift, rxswift-extensions, swift, theme
- Language: Swift
- Homepage:
- Size: 1.92 MB
- Stars: 382
- Watchers: 8
- Forks: 29
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-rxswift - RxTheme
- awesome - RxTheme - Theme management based on Rx (OOM-Leaks-Crash / Rx Series)
- awesome - RxTheme - Theme management based on Rx (OOM-Leaks-Crash / Rx Series)
README
# RxTheme
[![Build Status](https://travis-ci.org/RxSwiftCommunity/RxTheme.svg?branch=master)](https://travis-ci.org/RxSwiftCommunity/RxTheme)
[![Version](https://img.shields.io/cocoapods/v/RxTheme.svg?style=flat)](http://cocoapods.org/pods/RxTheme)
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage)
[![License](https://img.shields.io/cocoapods/l/RxTheme.svg?style=flat)](http://cocoapods.org/pods/RxTheme)
[![Platform](https://img.shields.io/cocoapods/p/RxTheme.svg?style=flat)](http://cocoapods.org/pods/RxTheme)## Manual
### Define theme service
```swift
import RxThemeprotocol Theme {
var backgroundColor: UIColor { get }
var textColor: UIColor { get }
}struct LightTheme: Theme {
let backgroundColor = .white
let textColor = .black
}struct DarkTheme: Theme {
let backgroundColor = .black
let textColor = .white
}enum ThemeType: ThemeProvider {
case light, dark
var associatedObject: Theme {
switch self {
case .light:
return LightTheme()
case .dark:
return DarkTheme()
}
}
}let themeService = ThemeType.service(initial: .light)
```### Apply theme to UI
```swift
// Bind stream to a single attribute
// RxTheme would automatically manage the lifecycle of the binded stream
view.theme.backgroundColor = themeService.attribute { $0.backgroundColor }
```### Switch themes
```swift
themeService.switch(.dark)
// When this is triggered by some signal, you can use:
someSignal.bind(to: themeService.switcher)
```### Other APIs
```swift
// Current theme type
themeService.type
// Theme type stream
themeService.typeStream
```## Examples
You can run the example project, clone the repo, run `pod install` from the Example directory first, and open up the workspace file.
## Installation
### SPM
1. File > Swift Packages > Add Package Dependency
2. Add https://github.com/RxSwiftCommunity/RxTheme### Cocoapods
```ruby
pod 'RxTheme', '~> 6.0'
```### Carthage
```
github "RxSwiftCommunity/RxTheme" ~> 6.0.0
```## Author
duan, [email protected]
## License
RxTheme is available under the MIT license. See the LICENSE file for more info.