Project

applocale

0.01
No release in over 3 years
Low commit activity in last 3 years
Applocale is a localization tool, It can convert file between string and xlsx ,csv, also support download xlsx or csv from google. You can also setup conversion logic for string value of each project. Support ios, android and json format.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.12
~> 5.0
~> 10.0

Runtime

~> 0.8.1
= 1.11.2
~> 3.3, >= 3.3.23
~> 0.19.4
 Project Readme

Applocale

Applocale is a Localization tool,
It can generates localized file for ios, android or in json format
The input resource can be 'google sheet' or 'xlsx' or 'csv'

What's news

0.4.1:

  1. can multiple config file in one project
  2. separate conversion logic in ruby file

Installation

Option1: Install by command:

$ gem install applocale

Option2: by Gemfile:

add this line to your application's Gemfile:

gem 'applocale'

And then execute:

$ bundle

Usage

Commands:
	+ init [platform]  # Create Config File, platform: ios | android | json
	+ reverse          # Convert localization string file to xlsx
		[--skip]  	# Skip Error
	+ update           # Download xlsx and convert to localization strings file
	+ update_local     # Convert local xlsx file to localization string file
	+ version     	   # Show the AppLocale verions
	+ findkey [key]    # Findkey and gen report for ios and convert to xlsx
	+ compare_local    # Compare the local results of two AppLocale files
	    [file1] [file2] # AppLocale files for comparison
	    [--result-file] # Comparison Result file, only support .csv
Optional:
 	[--path]    # Project Path
 	[--config_file]  #Config File Name

Steps:

For GoogleSheet/XLSX/CSV To localization String files:

Step1: create config file in default path 'AppLocale/AppLocaleFile':
	$ applocale init IOS
Step2: edit config file
Step3: Download and convert xlsx to strings file
	$ applocale update

For localization String files To XLSX :

Step1: create config file in default path 'AppLocale/AppLocaleFile':
	$ applocale init IOS
Step2: edit config file
Step3: convert to xlsx 
	$ applocale reverse

*** Note that, the special character handling in xlsx is base on strings file(IOS) format.

ConfigFile:

link: [link]	#download link for xlsx, it support google spreadsheet
platform: [android|ios|json]		#It can be android, ios or json
resource_folder: [resource_folder]  #the folder to store resource, should xlsx or csv
xlsxpath: [xlsxpath]	#local path for save or read xlsx
export_format: [csv|xlsx] # format of downloaded files, default option is xlsx.
google_credentials_path: [google_credentials_path]		#optional: google credentials file path
langlist: 
	[lang1]: [lang1_path]	#localization strings file path for lang1
	[lang2]: [lang2_path]	#localization strings file path for lang2
	[lang3]: [lang3_path]	#localization strings file path for lang3
sheetname:
	[Section1]: #sheetname
		key_str: [header]	#header str for key
		[lang1]: [header]	#header str for lang1
		[lang2]: [header]	#header str for lang2
		[lang3]: [header]	#header str for lang3
	[Section3]: #sheetname
		row: [row]	#first row number
		key: [col]	#col label or number for key
		[lang1]: [col]	#col label or number for lang1
		[lang2]: [col]	#col label or number for lang2
		[lang3]: [col]	#col label or number for lang3
isSkipEmptyKey: [true|false] #whether throw error when key is empty
convertFile: [convertFile path]  #should be convert script, if any customer convert need, enable this param

*** Note that, for format in sheetname, it can be either by header or row and col lable

for example:

link: "https://docs.google.com/spreadsheets/d/1Wy2gN_DSw-TCU2gPCzqvYxLfFG5fyK5rodXs5MLUy8w"
platform: "ios"
resource_folder: "ResourceAOS"
xlsxpath: "string.xlsx"
export_format: "csv"
langlist:
	zh_TW: "IOS/zh_TW.strings"
	zh_CN: "IOS/zh_CN.strings"
	en_US: "IOS/en_US.strings"
sheetname:
	Section1:
		key_str: "Key"
		en_US: "English"
		zh_TW: "Chinese(Traditional)"
		zh_CN: "Chinese(Simplified)"
	Section2:
		key_str: "Key"
		en_US: "English"
		zh_TW: "zh_TW"
		zh_CN: "zh_CN"
	Section3:
		row: "3"
		key: "A"
		en_US: "B"
		zh_TW: "C"
		zh_CN: "D"
isSkipEmptyKey: false
convertFile: "convert_aos.rb"

Customer conversion logic:

class Convert

 # def convent_to_locale(lang, key, before_convert_value, after_convert_value)
 #  return new_value
 # end

 # def parse_from_locale(lang, key, before_convert_value, after_convert_value)
 #     return value
 # end

 # def is_skip_by_key(sheetname, key)
 #     return true
 # end

 # def parse_from_excel_or_csv(sheetname, key, before_convert_value, after_convert_value)
 #     return value
 # end

 # def append_other(lang, target)
 #
 # end

end