Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/johnvuko/jt-translator-ios
Remotely manage your translations on iOS
https://github.com/johnvuko/jt-translator-ios
i18n ios swift translate translation translations
Last synced: 3 months ago
JSON representation
Remotely manage your translations on iOS
- Host: GitHub
- URL: https://github.com/johnvuko/jt-translator-ios
- Owner: johnvuko
- License: mit
- Created: 2016-07-26T09:32:08.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2016-09-23T09:37:11.000Z (over 8 years ago)
- Last Synced: 2024-07-22T10:48:15.971Z (6 months ago)
- Topics: i18n, ios, swift, translate, translation, translations
- Language: Swift
- Size: 5.86 KB
- Stars: 8
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# JTTranslator
![Version](https://img.shields.io/cocoapods/v/JTTranslator.svg)
![License](https://img.shields.io/cocoapods/l/JTTranslator.svg)
![Platform](https://img.shields.io/cocoapods/p/JTTranslator.svg)JTTranslator is an easy to way to manage your translations on iOS without building a new version of your app, which allow you to update your translations after having released on the AppStore.
It's work with [Translator](https://translator.eivo.fr), a platform for manage your translations on iOS and Android.
## Installation
With [CocoaPods](http://cocoapods.org), add this line to your Podfile.
pod 'JTTranslator', '~> 1.0'
## Usage
You have to initialize `JTTranslator` with your API KEY to download your translations.
The `start` method will automatically load the last downloaded versions of your translations and try to update them.In your AppDelegate, just add:
```swift
import JTTranslator@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
JTTranslator.start(apiKey: "YOUR_API_KEY")
}
}
```The easiest way is to replace every call to `NSLocalizedString` by a global method which I call `tr`. This method try to get the translations from `JTTranslator` and the translation if is not found, it will fallback on `NSLocalizedString`.
If you want to do like me, you have to create this global method:
```swift
func tr (_ key: String) -> String {
return JTTranslator.tr(key: key) ?? NSLocalizedString(key, comment: "")
}
```For example, in this case if you want to manage the translations for a `UILabel`, you will have to do something like:
```swift
let label = UILabel()
label.text = tr("the_translation_key_you_choose")
```You can also force to update the translations by calling `JTTranslator.update()`.
## Author
- [Jonathan Tribouharet](https://github.com/jonathantribouharet) ([@johntribouharet](https://twitter.com/johntribouharet))
## License
JTTranslator is released under the MIT license. See the LICENSE file for more info.