LocalizableUI
data:image/s3,"s3://crabby-images/c4a77/c4a7731458cbc1ccb7c68b9f95326141a0601f50" alt="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.
data:image/s3,"s3://crabby-images/8dedb/8dedb9970bbd48f7a11f5fab584df2da327366ec" alt="Label"
For the SegmentedControl you can enter an array of Localizable.strings Keys separated by “,”.
data:image/s3,"s3://crabby-images/139b2/139b2d39232330de5ba2bbca2fc0d6ff6f508fe8" alt="Label"
The BackButton can be set in the prior ViewController. Here you can use the ViewController fields in the Storyboard.
data:image/s3,"s3://crabby-images/9ee50/9ee5072a977a072503d9c15ce33cda6038ea4df4" alt="Label"
If you are using an NavigationItem this will override the Title and the BackButton of the ViewController.
data:image/s3,"s3://crabby-images/a26b9/a26b987836dd769663d0f07ac131e7b1a767d45c" alt="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 {
...
}
data:image/s3,"s3://crabby-images/a4350/a435059e393287e38e5a19fa415d723788fe9f08" alt="Label"
Authors
Jan Weiß, Philipp Weiß
License
LocalizableUI is available under the MIT license. See the LICENSE file for more info.
LocalizableUI
Example
To run the example project, clone the repo, and run
pod install
from the Example directory first.Supported UIElements
Requirements
Communication
Installation
CocoaPods
LocalizableUI is available through CocoaPods. To install it, simply add the following line to your Podfile:
Carthage
Add
github "weiss19ja/LocalizableUI"
to your Cartfile.Swift Package Manager
Usage
Storyboard
The easiest way to use LocalizableUI is the Storyboard. Here you can enter your Localizable.strings Keys.data:image/s3,"s3://crabby-images/8dedb/8dedb9970bbd48f7a11f5fab584df2da327366ec" alt="Label"
For the SegmentedControl you can enter an array of Localizable.strings Keys separated by “,”.data:image/s3,"s3://crabby-images/139b2/139b2d39232330de5ba2bbca2fc0d6ff6f508fe8" alt="Label"
The BackButton can be set in the prior ViewController. Here you can use the ViewController fields in the Storyboard.data:image/s3,"s3://crabby-images/9ee50/9ee5072a977a072503d9c15ce33cda6038ea4df4" alt="Label"
If you are using an NavigationItem this will override the Title and the BackButton of the ViewController.data:image/s3,"s3://crabby-images/a26b9/a26b987836dd769663d0f07ac131e7b1a767d45c" alt="Label"
Code
Localization of Views
It is also possible to set the LocalizableKeys in the Code. This includes all features of the Stotyboard LocalizableKeys
AlertViewController
AlertViews must be configured in the code.
LocalizedKey to text
Custom View
To localize any class or struct you can simply implement the Localizable Protocol
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.
Authors
Jan Weiß, Philipp Weiß
License
LocalizableUI is available under the MIT license. See the LICENSE file for more info.