Skip to content

This library was created to set the localized key of the UI elements directly in the interface builder of xcode. It supports all kind of UI elements for iOS and offers localized keys for all common text properties.

License

Notifications You must be signed in to change notification settings

weiss19ja/LocalizableUI

Repository files navigation

LocalizableUI

CI Status codecov.io Version License Platform

Example

To run the example project, clone the repo, and run pod install from the Example directory first.

Supported UIElements

  • UIBarButtonItem
  • UIButton
  • UILabel
  • UINavigationItem
  • UISegmentedControl
  • UITabBarItem
  • UITableViewCell
  • UITextField
  • UITextView
  • UIView
  • UIViewController
  • UIAlertController
  • UIAlertAction

Requirements

  • iOS 9.0+
  • Xcode 9.0+
  • Swift 4.0+

Communication

  • If you find any useful element missing please open an issue.
  • If you found a bug, open an issue.
  • If you want to contribute, submit a pull request.

Installation

CocoaPods

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

pod 'LocalizableUI'

Carthage

Add github "weiss19ja/LocalizableUI"to your Cartfile.

Swift Package Manager

dependencies: [
    .package(url: "https://github.com/weiss19ja/LocalizableUI.git", from: "0.3.1")
]

Usage

Storyboard

The easiest way to use LocalizableUI is the Storyboard. Here you can enter your Localizable.strings Keys. Label

For the SegmentedControl you can enter an array of Localizable.strings Keys separated by ",". Label

The BackButton can be set in the prior ViewController. Here you can use the ViewController fields in the Storyboard. Label

If you are using an NavigationItem this will override the Title and the BackButton of the ViewController. Label

Code

Localization of Views

It is also possible to set the LocalizableKeys in the Code. This includes all features of the Stotyboard LocalizableKeys

let newLabel = UILabel(frame: frame)
newLabel.localizedKey = "LocalizedKey"
AlertViewController

AlertViews must be configured in the code.

let alertController = UIAlertController(localizedTitle: Constants.titleKey, localizedMessage: Constants.messagekey, preferredStyle: .alert)
let action = UIAlertAction(localzedTitleKey: Constants.buttonKey, style: .cancel, handler: nil)
alertController.addAction(action)
LocalizedKey to text
// #1
let localizedText = LocalizationManager.localizedStringFor("LocalizedKey")
// #2
let localizedText = LocalizationManager.localizedStringFor("LocalizedKey", bundle: bundle, value: "", comment: "")
// #3
let localizedText = "LocalizedKey".localized
Custom View

To localize any class or struct you can simply implement the Localizable Protocol

extension CustomView: Localizable {
    func updateLocalizedStrings() {
    	/// do your localization stuff
        text = LocalizationManager.localizedStringFor("LocalizedKey")
    }
}
Language change manual

You can change the language while the app is active. You simply have to use the LocalizationManager changeLanguage(...) method. All your Views will update without any further adjustments.

do {
	let tableName = "Localizable"
	let bundle = Bundle(for: type(of: self))
	let languageCode = "en"
	try LocalizationManager.sharedInstance.changeLanguage(to: tableName, from: bundle, languageCode: languageCode)
} catch {
	...
}	

Label

Authors

Jan Weiß, Philipp Weiß

License

LocalizableUI is available under the MIT license. See the LICENSE file for more info.

About

This library was created to set the localized key of the UI elements directly in the interface builder of xcode. It supports all kind of UI elements for iOS and offers localized keys for all common text properties.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •