/bisu

Bisu - A localization automation service

Primary LanguageRuby

Bisu 홀

Status Gem

Bisu manages your app iOS, Android and RoR localization files for you. No more copy+paste induced errors!

It works with the following sources out of the box:

Installation

gem install bisu

Usage

  1. Open terminal in app project base
  2. Run: bisu
  3. That's it!*

*given that someone already configured Bisu

Setup your configuration file

  1. Create in your project base folder a translatable.yml:
type: <iOS|Android|RoR>

dictionary:
  (see options below)

translate:
  - in: path/to/1st/file.translatable
    out: path/to/%{locale}/strings.xml
    out_en: path/to/default/strings.xml
  - in: path/to/2nd/file.translatable
    out: path/to/2nd-%{locale}/strings.xml

languages:
  - locale: en
    language: en # the language as it appears in the dictionary
  - locale: en-US
    language: en-us
    fallback_language: en
  - locale: pt
    language: pt

Sources

URL
dictionary:
  type: url
  url: <A-GET-URL>
Tolgee
dictionary:
  type: tolgee
  api_key: <TOLGEE-API-KEY>
  host: <TOLGEE-CUSTOM-HOST> (default: app.tolgee.io)
Google Sheets
  1. First "Publish to the web" your Google Sheet
  2. Share only the sheet that contains the translations
  3. Make sure you CSV format
  4. First column should contain the translation keys
  5. First row should contain the locale for each language
dictionary:
  type: google_sheet
  url: <GOOGLE-DRIVE-SHEET-CSV-URL>
  keys_column: <GOOGLE-DRIVE-KEY-COLUMN-TITLE>
OneSky
dictionary:
  type: one_sky
  api_key: <ONE-SKY-API-KEY>
  api_secret: <ONE-SKY-API-SECRET>
  project_id: <ONE-SKY-PROJECT-ID>
  file_name: <ONE-SKY-FILE-NAME>

Create translatable file templates

Create a *.translatable version for your platform specific localization files:

iOS

example: Localizable.strings.translatable

"delete" = "$general.delete$";
"cancel" = "$general.cancel$";
"close" = "$general.close$";
"requestName" = "$request.name{user_name: %@}$";
Android

example: strings.xml.translatable

<?xml version="1.0" encoding="utf-8"?>

<resources>
    <string name="delete">$general.delete$</string>
    <string name="cancel">$general.cancel$</string>
    <string name="close">$general.close$</string>
    <string name="request_name">$request.name{user_name: %s}$</string>
</resources>
Ruby on Rails

example: config/locales/yml.translatable

$specialKLocale$:
  resources:
    delete: $general.delete$
    cancel: $general.cancel$
    close: $general.close$
  messages:
    request_name: $request.name$

Translatable options

Parameters

Given a key with params such as "Missing ${attribute} value"

  • $some-key-with-params{param: %s}$: Missing $s value
  • $some-key-with-params//ignore-params$: Missing ${attribute} value

Formated strings (special characters)

"%" character (iOS only)

When it should be localized as given such as "Perfect: 100 (%)"

  • $some-key-with-percentage$: Perfect: 100%

When it should be localized as a formated string such as "Perfect: %{percentage} (%)"

  • $some-key-with-percentage{percentage: %d}//formatted-string$: Perfect: %d (%%) (note the double %)

Locale (useful for Rails localization files)

  • $specialKLocale$: the respective locale of this file
  • $specialKLanguage$: the respective language on the translation platform

Special comments

  • $specialKComment1$: This file was automatically generated based on a translation template.
  • $specialKComment2$: Remember to CHANGE THE TEMPLATE and not this file!