SettingsKit

CI Status Version License Platform codecov.io Sponsored by Detroit Labs

SettingsKit is a small library & build tool that makes it easier to work with app preferences in the iOS Settings app. It also makes working with settings a bit safer by using enums instead of magic strings, which are vulnerable to typos.

How does it work?

SettingsKit comes bundled with a tool that generates an enum (Settings.swift) at build-time based on the preference items you have configured in your Settings.bundle. You can then use the Settings enum to easily access, update and observe individual settings.

Here is a Settings screen w/ generated enum and sample implementation code:

Settings Example

When would I want to use SettingKit?

Here are just a few ways you could use SettingsKit; - display the current app version & build number to users or testers, which can be very helpful for handling bug reports. - give users simple controls for app preferences (e.g. enable a color blindness theme) - enable testers to see which back-end environment (i.e. Staging) the current build is using, and also allow them to change the back-end environment at runtime, without having to provide seperate builds for each environment.

The types of settings you use are completely up to you. SettingsKit simply makes it easier to add settings to your app.

Usage

Fetch a setting

let name = Settings.get(.FirstName)

Modify a setting

Settings.set(.ApiEnvironment, "Staging")
Settings.set(.Contrast, 80)
Settings.set(.EnableAnalytics, true)

Observe a setting

// observe and respond to any changes made to a given setting
Settings.subscribe(.FavoriteColor) { (newValue) -> Void in
  print("Favorite color was changed to \(newValue)")
}

Installation

SettingsKit is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod "SettingsKit"

You will also need the xcodeproj ruby gem in order to use the SettingsKit build tool to auto-generate the Settings.swift file.

$ gem install xcodeproj

Setup

Create a Settings bundle

In order to add custom items to Settings your app must have a Settings bundle with a Root.plist. To fetch, update, and/or observe settings you will need to add the settings you would like to use to the Preference Items array in your Settings.bundle/Root.plist.

Example:

Settings.bundle/Root.plist

Once you have added one or more preference items, build your project to have SettingsKit generate a Settings.swift file from your Settings.bundle/Root.plist.

Important — Anytime you change the preference items in your Root.plist you will need build your project to generate an updated Settings.swift file.

Add a run script build phase

To allow SettingsKit to auto-generate a Settings enum file you will need to add a run script build phase to your app’s target: Target > Build Phases > + > New Run Script Phase

IMPORTANT Make sure you put the new run script phase above the Compile Sources phase.

Step 1: Copy/paste the following into the script box:

PATH=$(bash -l -c 'echo $PATH')
$PODS_ROOT/SettingsKit/build -p $PROJECT_FILE_PATH -s $SCRIPT_INPUT_FILE_0 -o $SCRIPT_OUTPUT_FILE_0

Step 2: Add the path to your Settings.bundle/Root.plist to Input Files.

Example:

Run script: Input files example

Step 3: Add the path to where you would like the generated Settings.swift file to be live (i.e. where you put your app’s source files).

Example:

Run script: Output files example

When you are done with all of the above steps, your SettingsKit run script phase should look something like this:

Run script phase example

Finally, build (⌘B) your project. If the project builds successfully, you should now see a new Settings.swift file in your project. Feel free to move it to any group in your project.

From now on, everytime you build, SettingsKit will update the Settings.swift file to match the Preference Items you have configured in your Settings.bundle/Root.plist. You should never need to manually edit Settings.swift.

Author

Dan Trenz (@dtrenz) c/o Detroit Labs

License

SettingsKit is available under the Apache License, Version 2.0. See the LICENSE file for more info.