AALocalizationKit 1.5.1

AALocalizationKit 1.5.1

Maintained by Engr. Ahsan Ali.



  • By
  • EngrAhsanAli

Table of Contents

#AALocalizationKit

Swift 5.0 Carthage compatible CocoaPods License MIT Build Status License MIT CocoaPods

##Description

AALocalizationKit is really helpful to maintain multiple languages in the application with their custom language fonts and an ability to change the language within your application!

##Demonstration

AALocalizationKit is easily configured framework to configure multiple languages in the iOS application.

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

##Requirements

  • iOS 10.0+
  • Xcode 11.0+
  • Swift 5+

Installation

AALocalizationKit can be installed using CocoaPods, Carthage, or manually.

##CocoaPods

AALocalizationKit is available through CocoaPods. To install CocoaPods, run:

$ gem install cocoapods

Then create a Podfile with the following contents:

source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '10.0'
use_frameworks!

target '<Your Target Name>' do
pod 'AALocalizationKit'
end

Finally, run the following command to install it:

$ pod install

##Carthage

To install Carthage, run (using Homebrew):

$ brew update
$ brew install carthage

Then add the following line to your Cartfile:

github "EngrAhsanAli/AALocalizationKit" "master"

Then import the library in all files where you use it:

import AALocalizationKit

##Manual Installation

If you prefer not to use either of the above mentioned dependency managers, you can integrate AALocalizationKit into your project manually by adding the files contained in the Classes folder to your project.

#Getting Started

Just need to configure the supporting languages for Localization within your the iOS application in you AppDelegate didFinishLaunchingWithOptions method.

Following is the example to configure this with following languages support.

Usage:

func configureAALK() {
    let languageFont: [AALanguage : [UIFont.Weight : String]] = [
        .ar : [.regular: "Jomhuria"],
        
        .zhHans : [.regular: "Chibrush"],
        
        .fr : [.regular: "MuchaFrenchCapitals"],
        
        .de : [.regular: "LemonadeStand"],
        
        .en : [.regular: "Roboto-Regular",
               .medium: "Roboto-Medium",
               .bold: "Roboto-Bold"],
        
        .ja : [.regular: "NotoSerifJP-Regular",
               .medium: "NotoSerifJP-Medium",
               .bold: "NotoSerifJP-Bold"]
    ]
            
    AALK.configuration.languageFont = languageFont
    AALK.configuration.defaultFont = "Roboto"
}

Now just update the language in your view controller

let languageNames = AALK.bundleLanguageNames // get all bundle languages
let lang = AALK.languages[index] // where index is the language index for specific langauge
AALK.currentLanguage = lang // Set the language within your application

/// NOW YOU JUST NEED TO RECALL YOUR VIEW OR VIEW CONTROLLER TO SEE THE CHANGES

#Contributions & License

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

Pull requests are welcome! The best contributions will consist of substitutions or configurations for classes/methods known to block the main thread during a typical app lifecycle.

I would love to know if you are using AALocalizationKit in your app, send an email to Engr. Ahsan Ali