Skip to content

batuhansk/UserDefault

Repository files navigation

UserDefault

UserDefault wrapper enables you to use UserDefaults in the simplest way with the power of @propertyWrapper.

Primitive types of Swift which conforms Codable protocol internally are supported. (String, Int, Float, Double, Data, Bool, Date, URL)

Installation

Swift Package Manager:

To integrate using Apple's Swift package manager, add the following as a dependency to your Package.swift:

dependencies: [
    .package(url: "https://github.com/strawb3rryx7/UserDefault.git", from: "master")
]

Manually

Just drag the UserDefault.swift file into your project directory. It's all done.

Usage

import UserDefault

struct Defaults {
    @UserDefault("is_discount_provided", defaultValue: false)
    static var isDiscountProvided: Bool
}

How to Modify?

Well, that's pretty simple. You only have to access the variable through the Defaults struct, and set it the value.

Defaults.isDiscountProvided = true

In addition, Custom models which conforms Codable protocol can be stored too.

Custom models

struct User: Codable {
    let firstName: String
    let lastName: String
}

struct Defaults {
    @UserDefault("default_user")
    static var defaultUser: User?
}

You can specify any UserDefaults suite for each one. If you want to store on standard suite, no needed to specify it. Default is UserDefaults.standard.

Usage of custom UserDefaults suite

struct Contact: Codable {
    let firstName: String
    let lastName: String
    let phoneNumber: String
}

private let appSuite = UserDefaults(suiteName: "com.strawb3rryx7.userdefault.appsuite")!
private let customSuite = UserDefaults(suiteName: "com.strawb3rryx7.userdefault.customsuite")!

struct Defaults {
    @UserDefault("primary_contact", suite: appSuite)
    static var primaryContact: Contact?
  
    @UserDefault("has_seen_purchase_screen", defaultValue: false, suite: customSuite)
    static var hasSeenPurchaseScreen: Bool
}

Releases

No releases published

Packages

No packages published

Languages