List of Time Zones Identifiers for Swift 🌍

Swift License CocoaPods Compatible Carthage Compatible CI codecov Documentation Supports macOS, Ubuntu & Windows Latest release

Overview

This Swift library provides a convenient way to handle time zones through the TimeZoneConvertible protocol and the TimeZoneIdentifier enum. Whether you need the current system time zone, an auto-updating time zone, or specific global time zones, this library has got you covered.

Features

  • Type-safe time zone identifiers.
  • Extendable TimeZoneConvertible protocol.
  • Easy-to-use, Swifty API.

Automatic Updates 🔄

This library is set up with GitHub Actions to automatically update the list of time zone identifiers every day. The updates are compatible across all iOS versions.

The workflow ensures that the list stays current, and any changes are committed directly to the repository. Only the differences (diff) are committed, ensuring that the change history remains clean and easy to follow.

Installation

Swift Package Manager

Add the package dependency to your Package.swift file:

dependencies: [
    .package(url: "https://github.com/nzrsky/TimeZoneIdentifier.git", from: "1.0.0")
]

Then run:

swift build

Usage

First, import the module:

import TimeZoneIdentifiers

Using TimeZoneConvertible

You can use the TimeZoneConvertible protocol to seamlessly convert between types:

let timeZone: TimeZone = TimeZoneIdentifier.current.timezone()

Using TimeZoneIdentifier Enum

The TimeZoneIdentifier enum allows you to easily access different time zones:

let currentZone = TimeZoneIdentifier.current.timezone()
let autoUpdatingZone = TimeZoneIdentifier.autoUpdating.timezone()
let specificZone = TimeZoneIdentifier.africaAbidjan.timezone()

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Made in 🇱🇻 by Alex Nazarov