# Styles **Repository Path**: mirrors_inloop/Styles ## Basic Information - **Project Name**: Styles - **Description**: Styling iOS apps made easy - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-09-25 - **Last Updated**: 2026-03-01 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README ![alt text](https://imgur.com/download/rvaWqH3 "Styles - A declarative and type-safe framework for beautiful applications") Artwork: Josef Čapek - 7. Povídání o pejskovi a kočičce (7/43)

Styles

Styling framework that works
A declarative and type-safe framework for beautiful applications.

License Travis-CI Version Platform Platform Swift version
## Table of Contents - [Features](#features) - [Requirements](#requirements) - [Examples](#examples) - [TextStyle](#textstyle) - [Updating TextStyle](#updating-textstyle) - [Combining TextStyle](#combining-textstyle) - [TextEffects](#texteffects) - [ViewStyle](#viewstyle) - [Layer Properties](#layer-properties) - [Updating ViewStyle](#updating-viewstyle) - [Combining ViewStyle](#combining-viewstyle) - [SwitchStyle](#switchstyle) - [Installation](#installation) - [Contributions](#contributions) - [License](#license) - [Authors](#authors) ## Features - __declarative__: You describe the style, framework will do the rest - __type-safe__: Type system will help you describe your style - __plays nice with UIAppearance__: In fact its designed for it. - __usable as settable property__: Not only works as UIAppearance proxy, but also as settable property - __supports UIControl states and UITextField editing__: You're gonna ❤︎ it. - __saves you from the `NSAttributedString`[1](#soso)__: Just work with `String`s. - __text, color and layer properties__: Custom line height, letter spacing, corners? Me gusta. - __supports Styles updating__: Design base style for you app and update it on the fly as needed. - __Zeplin extension__: Just copy styles over to your project. Super easy. Check out: https://github.com/inloop/styles-zeplin-extension 1: In some cases. ## Requirements - iOS 10.0+ - Xcode 9.2+ - Swift 4.1+ ## Examples For full set of feature examples refer to our [wiki page](https://github.com/inloop/Styles/wiki). ### TextStyle ```swift let h1 = TextStyle( .font(.preferredFont(forTextStyle: .largeTitle)), .foregroundColor(.black), .backgroundColor(.yellow), .letterSpacing(1.5), .paragraphStyle([ .alignment(.natural), .lineSpacing(2.5) ]), .strikethrought(TextDecoration( style: .thick, pattern: .dash )), .underline(TextDecoration( style: .single, pattern: .dashDotDot, byWord: true, color: .red )) ) UILabel.appearance().textStyle = h1 UIButton.appearance().setTextStyle(h1, for: .normal) ``` ```swift let h1 = TextStyle( .font(.preferredFont(forTextStyle: .largeTitle)), .foregroundColor(.black), .backgroundColor(.yellow) ) myLabel.textStyle = h1 ``` #### Updating TextStyle ```swift let footnote = TextStyle( .font(.preferredFont(forTextStyle: .footnote)) ) let blueFootnote = footnote.updating(.foregroundColor(.blue)) myLabel.textStyle = blueFootnote ``` ```swift let blueFootnote = TextStyle( .font(.preferredFont(forTextStyle: .footnote)) .foregroundColor(.blue) ) let redFootnote = blueFootnote.updating(.foregroundColor(.red)) myLabel.textStyle = redFootnote ``` #### Combining TextStyle ```swift let blueFootnote = TextStyle( .font(.preferredFont(forTextStyle: .footnote)) .foregroundColor(.blue) ) let yellowBackground = TextStyle( .backgroundColor(.yellow) ) myLabel.textStyle = blueFootnote + yellowBackground ``` ```swift let h1 = TextStyle( .font(.preferredFont(forTextStyle: .largeTitle)), .letterSpacing(1.5), .paragraphStyle([ .alignment(.natural), .lineSpacing(2.5) ]), .strikethrought(TextDecoration( style: .thick, pattern: .dash )), .underline(TextDecoration( style: .single, pattern: .dashDotDot, byWord: true, color: .red )) ) let blue = TextStyle( .foregroundColor(.blue) ) let yellowBackground = TextStyle( .backgroundColor(.yellow) ) let secret = TextStyle( .writingDirectionOverrides([ .rightToLeftOverride ]) ) let title = h1 + blue + yellowBackground myLabel.textStyle = title secretMessageLabel.textStyle = h1 + secret ``` #### TextEffects ```swift let bigRed: TextStyle = ... let bigGreen: TextStyle = ... let smallCyan: TextStyle = ... let bigRedFirstWord = TextEffect( style: bigRed, matching: First(occurenceOf: "Styles") ) let bigGreenLastWord = TextEffect( style: bigGreen, matching: Block { $0.range(of: "awesome") } ) let everyOtherTildaCyan = TextEffect( style: smallCyan, matching: Regex("~.*?(~)") ) let tint = TextStyle( .foregroundColor(.red) ) let logo: UIImage = ... let logoBeforeCompanyName = TextEffect(image: logo, style: tint, matching: First(occurenceOf: "INLOOPX")) let styleWithEffects = TextStyle( .font(.preferredFont(forTextStyle: .body)), .backgroundColor(.yellow), effects: [ bigRedFirstWord, bigGreenLastWord, everyOtherTildaCyan, logoBeforeCompanyName ] ) ``` ### ViewStyle ```swift let pill = ViewStyle( .cornerRadius(10), .borderWidth(3), .borderColor(.red), .opacity(0.8) ) UILabel.appearance().viewStyle = pill ``` ```swift let red = ViewStyle( .backgroundColor(.red), .tintColor(.red), .borderColor(.red), .borderWidth(0.5), .shadow(Shadow( color: .red, offset: UIOffset(horizontal: 0, vertical: 8), radius: 16 )) ) let blue = ViewStyle( .borderColor(.blue), .borderWidth(0.5), .shadow(.none) ) UITextField.appearance().setViewStyle(red, for: .editing) UITextField.appearance().setViewStyle(blue, for: .inactive) UITextView.appearance().setViewStyle(red, for: .editing) UITextView.appearance().setViewStyle(blue, for: .inactive) ``` ```swift let blue = ViewStyle( .borderColor(.blue), .borderWidth(0.5), .cornerRadius(10) ) myButton.viewStyle = blue ``` #### Layer properties If you set any of `[.borderColor, .borderWidth, .cornerRadius, .opacity, .shadow]` properties for particular states to `UITextView` or `UITextField`, the Styles will require to match properties under the hood. If you don't do so the styling becomes invalid because layer properties are not reset when state is changed. It is up to you to define the style. Below is the example which produces assertion error and second snippet is valid configuration. ```swift let redBorder = ViewStyle( .borderColor(.red), .borderWidth(1.5) ) let roundedCorners = ViewStyle( .cornerRadius(10) ) UITextField.appearance().setViewStyle(redBorder, for: .editing) // It throws an assertion error // because rounded corners is missing .borderColor & .borderWidth UITextField.appearance().setViewStyle(roundedCorners, for: .inactive) ``` ```swift let redRoundedBorder = ViewStyle( .borderColor(.red), .borderWidth(1.5), .cornerRadius(10) ) let redFlatBorder = ViewStyle( .borderColor(.red), .borderWidth(1.5), .cornerRadius(0) ) UITextField.appearance().setViewStyle(redRoundedBorder, for: .editing) UITextField.appearance().setViewStyle(redFlatBorder, for: .inactive) ``` #### Updating ViewStyle ```swift let app = ViewStyle( .borderWidth(0.5), .cornerRadius(10) ) let blue = app.updating(.borderColor(.blue)) ``` ```swift let app = ViewStyle( .borderWidth(0.5), .cornerRadius(radius: 10) ) let thick = app.updating(.borderWidth(3)) ``` #### Combining ViewStyle ```swift let app = ViewStyle( .borderWidth(0.5), .cornerRadius(10) ) let semiVisible = ViewStyle( .opacity(0.5) ) myLabel.viewStyle = app + semiVisible ``` ```swift let app = ViewStyle( .borderWidth(0.5), .cornerRadius(10) ) let semiVisible = ViewStyle( .opacity(0.5) ) let blue = ViewStyle( .backgroundColor(.blue) ) let labelStyle = app + semiVisible + blue myLabel.viewStyle = labelStyle ``` ### SwitchStyle ```swift let prettySwitchStyle = SwitchStyle( .onTintColor(.red), .tintColor(.blue), .thumbTintColor(.yellow) ) // style only one switch mySwitch.switchStyle = prettySwitchStyle // style all switches UISwitch.appearance().switchStyle = prettySwitchStyle ``` ## Installation ### CocoaPods [CocoaPods](http://cocoapods.org) is a dependency manager for Cocoa projects. You can install it with the following command: ```bash $ gem install cocoapods ``` > CocoaPods 1.1+ is required to build Styles. To integrate Styles into your Xcode project using CocoaPods, specify it in your `Podfile`: ```ruby source 'https://github.com/CocoaPods/Specs.git' platform :ios, '10.0' use_frameworks! target '' do pod 'Styles', :git => 'https://github.com/inloop/Styles.git' end ``` Then, run the following command: ```bash $ pod install ``` ### Carthage [Carthage](https://github.com/Carthage/Carthage) is a decentralized dependency manager that builds your dependencies and provides you with binary frameworks. You can install Carthage with [Homebrew](http://brew.sh/) using the following command: ```bash $ brew update $ brew install carthage ``` To integrate Styles into your Xcode project using Carthage, specify it in your `Cartfile`: ```ogdl github "inloop/Styles" ``` Run `carthage update` to build the framework and drag the built `Styles.framework` into your Xcode project. ## Contributions ARE WELCOME! 🖖 ## License Styles is available under the MIT license. See the LICENSE file for more info. ## Authors |

[Radim Halfar](https://github.com/radimhalfar)
|

[Jakub Petrik](https://github.com/jakubpetrik)
|

[Matěj Děcký](https://github.com/matejdecky)
| | :---: | :---: | :---: |
Built with ❤︎ at INLOOPX