====== Мультиязычность в Limb2 (I18N и L10N) ======
Для обращения с различными строками l10ns и i18n Limb использует классы 'locale' и 'strings' (папка 'LIMB_DIR/core/lib/locale/').
* класс locale используется для дат, валют и форматирования числовых данных. ini файлы для различных местных настроек сохраняются в папке LIMB_DIR/core/locale
* класс strings используется для выбора локализованных строк. ini файлы с локализованными строками расположены в:
* PROJECT_DIR/core/strings
* LIMB_DIR/core/strings
==== настройки L10N ====
Вы можете найти настроечные файлы l10n в каталоге 'LIMB_DIR/core/locale/'. В настоящее время поддерживаются 2:
en.ini и ru.ini.
Эти файлы содержат некоторые специфичные для l10n вещи: название страны, название языка, формат даты, дни недели, названия месяцев, кодировку страниц и т.д.
==== I18N strings ====
В настоящее время имеются локализованные строки для английского и русского языков.
Типичный пример использования класса strings:
echo strings :: get($string_name,[$file_name='common'],[$locale_id=null]);
if $locale_id is not specified current MANAGEMENT_LOCALE_ID is used
$file_name is mapped to physical file by schema(order is preserved):
* 'PROJECT_DIR/core/strings' . $file_name . '_' . $locale_id . '.ini'
* 'LIMB_DIR/core/strings' . $file_name . '_' . $locale_id . '.ini'
Если ни один файл не найден возникает критическая ошибка.
Общий формат для ini файла локализации:
[constants]
attribute1 = ...
attribute2 = ...
...
Локализационные ini файлы поддерживают простое настледование через раздел [extends]. Вы должны задать в нем свойство 'filename', что бы позволить классу strings обработать вопросы наследования. Простой пример, содержимое файла ad_en.ini:
[constants]
create_ad_block = Добавить рекламный блок
ad_block_creation = Создание рекламного блока
ad_block_edition = Редактирование рекламного блока
edit_ad_block = Редактировать блок
==== Локализационные константы в деталях ====
Limb использует две константы для работы с локализацией:
* **CONTENT_LOCALE_ID** - текущая локализация для контентных объектов
* **MANAGEMENT_LOCALE_ID** - локализация текущего пользователя. Она используется для локализованных сообщений управления, ошибок валидации, имен действий и так далее.
Каждый объект сайта в Limb имеет свою локализацию (например, 'en' или 'ru') Она сохраняется в таблице sys_site_object (смотри URL db_organization_chart).
По умолчанию каждый новый объект наследует id локализации от своего предка.
В настоящее время мы не имеем красивый пользовательский интерфейс для установки id локализации для объекта сайта (это есть в планах).
CONTENT_LOCALE_ID определяется на основе id локализации запрашиваемого объекта.
Есть небольшая уловка с определением MANAGEMENT_LOCALE_ID:
константа MANAGEMENT_LOCALE_ID сохраняется в пользовательской сессии. Если
MANAGEMENT_LOCALE_ID не определена (в случае нового пользователя, или после выхода ), то MANAGEMENT_LOCALE_ID определяется как CONTENT_LOCALE_ID.
Пользователь может выбрать предпочитаемую локализацию MANAGEMENT_LOCALE_ID во время процедуры проверки пароля:
{{ limb2:en::login_form.gif }}
Также возможно переключить MANAGEMENT_LOCALE_ID используя форму в правом верхнем углу административной части сайта:
{{ limb2:en::change_language_form.gif }}
Спсок доступных локализаций определяется глобальной переменной в файле setup.php из папки PROJECT_DIR. Корректный пример:
$AVAILABLE_LOCALES = array('ru', 'en');
Давайте посмотрим как и где эти локализационные константы используются:
* MANAGEMENT_LOCALE_ID - значение по умолчанию в strings :: get(...)
* CONTENT_LOCALE_ID - значение по умолчанию в locale :: instance();
* Тэг по умолчанию MANAGEMENT_LOCALE_ID
* Тэг по умолчанию CONTENT_LOCALE_ID
* Тэг по умолчанию CONTENT_LOCALE_ID
* Любой тэг формы (т.к. INPUT, BUTTON и т.д.) имеет атрибуты locale_type, locale_value, locale_file с задаными значениями локализации, по умолчанию MANAGEMENT_LOCALE_ID
* отображает кодировку страницы, использует только MANAGEMENT_LOCALE_ID
* Все ошибки проверки (валидации) форм отображаются с использованием MANAGEMENT_LOCALE_ID
Все это предназначено для создания многоязычных сайтов на основе Limb.