=== xili-language === Contributors: MS dev.xiligroup.com Donate link: http://dev.xiligroup.com/ Tags: theme,post,plugin,posts,page,category,admin,multilingual, bilingual, taxonomy,dictionary,.mo file,.po file,localization, widget, language, international, i18n, l10n, wpmu, multisite Requires at least: 2.9 Tested up to: 3.0 Stable tag: 1.7.0 xili-language provides for a multilingual website an automatic selection of language (.mo) in theme according to the language of current post(s). == Description == **xili-language provides for a bilingual (or multilingual) website an automatic selection of language (.mo) in theme according to the language of current post(s) or page. Theme's behaviour can be fully personalized through hooks and api** * xili-language plugin provides an automatic selection of language in theme according to the language of displayed post, series of posts, page or articles. *If the post is in gaelic, the texts of the theme will be in gaelic if the author checks the post as gaelic and if the theme contains the right .mo file for this target language.* * xili-language select *on the fly* the .mo files present in the theme's folder. * Themes with *localization* can be easily transformed for realtime multilingual sites. * **NEW:** With now WordPress 3.0, the default theme named **twentyten** can be used without php coding for a multilingual site [as shown here](http://multilingual.wpmu.xilione.com). xili-language plugin works on mono or multisite mode. * xili-language is dedicated for theme's creator or webmaster with knowledges in CMS and WP and having (or not) tools to create .mo language files. Through API (hook), the plugin add automatic tools (or links or filters) for sidebar or top menus. Categories or Archives lists are translated also. * xili-language provides also series of functions which can be *hooked* in the functions.php file of the theme that you create i.e. for a multilingual cms like website. TRILOGY FOR MULTILINGUAL CMS SITE : [xili-language](http://wordpress.org/extend/plugins/xili-language/), [xili-tidy-tags](http://wordpress.org/extend/plugins/xili-tidy-tags/), [xili-dictionary](http://wordpress.org/extend/plugins/xili-dictionary/) * With [xili-tidy-tags](http://wordpress.org/extend/plugins/xili-tidy-tags/), it is now possible to display sub-selection (cloud) of **tags** according language. With [xili-dictionary](http://wordpress.org/extend/plugins/xili-dictionary/) plugin (beta), it is easier to create or update online, via admin UI, the files .mo of each language. * xili-language plugin **does not create addition tables in the database**. xili-language simply makes proper use of the taxonomy tables and postmeta table offered by WordPress to define language and link items between them. Because xili-language plugin does not modify deeply the post edit UI, it is possible to use **iPhone / iPod Touch** Wordpress app to prepare and draft the post. * **Documentation**: A new [table](http://dev.xiligroup.com/?p=1432) summarizes all the technical features (widgets, template tags, functions and hooks) of this powerful plugin for personalized CMS created by webmaster. * Check out the [screenshots](http://wordpress.org/extend/plugins/xili-language/screenshots/) to see it in action. = roadmap = * the readme file is under complete rewritting. * multilingual features tested with new post-type introduced by WP 3.0. will be documented for webmasters (please send an email). = 1.7.0 = * some functions are improved through new hooks (front-page selection). * fixes unexpected rewritting (when permalinks is set) and fixes query of category without languages. * **For developers:** `xiliml_cur_lang_head` filter is now obsolete and replace by `xiliml_curlang_action_wp` - see code source - the mechanism for frontpage (home recent posts list or page) is changed and don't now use redundant queries. * **For developers:** if you use `xili_language_list` hook action to create your own list - verify it if you use page as frontpage because 'hlang' querytag is now obsolete. * **Latest version compatible with WP 2.9.x** = 1.6.0 - 1.6.1 = * Add new features to manage sticky posts ( [see this post in demo website](http://multilingual.wpmu.xilione.com/) ) * Fixes refresh of THEME_TEXTDOMAIN for old WP 2.9.x * Improvements mainly for WP 3.0 * more functions to transform without coding site based on famous new twentyten theme. (article later) * possible to complete top nav menu with languages list for website home selection in two ways. * new functions for developpers/webmasters: `xili_get_listlanguages()`, see source. * example of language's definition (popup) to add new language. * Language list widget: list of available options added (hookable also). * some parts of source rewritten. = xili-language and template tags = * xili-language "*translates*" template tags and permits some variations for webmasters: The most current template tags don't need special work: `wp_list_categories()`, `wp_title()`,... `wp_get_archives` Possible that very special permalinks need to use hook named `xiliml_get_archives_link`. - Sub selection of archives for `wp_get_archives()` with &lang= [see installation notes](http://wordpress.org/extend/plugins/xili-language/installation/). `wp_list_pages()` with optional query tag &lang= * xili-language "*provides*" new template tags (or widgets) to solve issues from WP core or add new features for CMS: `xili_language_list()` - outside loop (sidebar) display the languages of the site (used also by widget) `xiliml_the_category()` - replace the_category() template tag of WP Core improved `xiliml_the_others_posts()` function and theme tag to be used in multilingual category loop and by option (array) to return an array of linked posts in other languages (useful for CMS webmasters) (array of lang and id ) - the id is easily transformable in permalink with function `get_permalink()` when using this array. * widget for recent comments that can subselect those for current language. (a function `xiliml_recent_comments()` is also available if you want to create a template tag with resulting objects array). = Technical infos = **Prerequisite:** Verify that your theme is international compatible (translatable terms like `_e('the term','mytheme')` and no displayed texts 'hardcoded' (example in theme 'default-i18n' of WP). * Based on class and oop - New settings UI according to new rules and style of WP 2.7 (meta_boxes, js) - *ONLY USE WITH Wordpress 2.7 and more* - Hooks (Action, Filter) usable in your functions.php. * Optional improving hooking ways to be compatible with l10n cache of Johan's plugin see line 2200. **CMS:** * Contains features dedicated to multilingual theme's creators and webmasters. **Documentation**: A new [table](http://dev.xiligroup.com/?p=1432) summarizes all the technical features (widgets, template tags, functions and hooks) of this powerful plugin for personalized CMS created by webmaster. * Some new php functions, a folder to include functions shared by themes (not necessary to put functions in functions.php of the current theme); example with a shortcode to insert link inside content toward another post in a language. A post explaining these improvements can be found [here](http://dev.xiligroup.com/?cat=480&lang=en_us). * Provides infos about **text direction** *ltr* ou *rtl* of languages (arabic, hebraic,...) of theme and of each post in loop see note [direction in installation](http://wordpress.org/extend/plugins/xili-language/installation/) * unique id for category link hook [see expert's corner posts](http://dev.xiligroup.com/?p=1045) * fixes unexpected like tags metabox added by WP 28 ( see [trac #10437](http://core.trac.wordpress.org/ticket/10437) ). * hooks to define header metas or language attributes in html tag. **More infos and docs** * other texts and more descriptions [here](http://dev.xiligroup.com/xili-language/ "why xili-language ?") = Compatibility = xili-language is compatible with the plugin [xili-dictionary](http://dev.xiligroup.com/?p=312 "why xili-dictionary ?") which is able to deliver .mo files on the fly with the WP admin UI (and .po files translatable by other translators). [xili-dictionary](http://dev.xiligroup.com/xili-dictionary/ "xili-dictionary posts") used a specific taxonomy without adding tables in WP database. xili-language is full compatible with the plugin [xilitheme-select](http://wordpress.org/extend/plugins/xilitheme-select/ "xilitheme-select") to be used with iPhone, iPod Touch or other mobiles. xili-language is compatible with the plugin [xili-tidy-tags](http://dev.xiligroup.com/xili-tidy-tags/ ). xili-tidy-tags lets you create multiple group of tags. That way, you can have a tag cloud for tags in English, another cloud for French tags, another for Spanish ones, and so on. You can also use the plugin for more than multilingual blogs. Basically, you can create any group of tags you want. More informations on the site [dev.xiligroup.com](http://dev.xiligroup.com/ "xiligroup plugins") Check out the [screenshots](http://wordpress.org/extend/plugins/xili-language/screenshots/) to see it in action. == Installation == 1. Upload the folder containing `xili-language.php` and language files to the `/wp-content/plugins/` directory, 2. Verify that your theme is international compatible - translatable terms like `_e('the term','mytheme')` and no text hardcoded - 3. define domain name of your theme - see note at end list below, 4. Activate the plugin through the *'Plugins'* menu in WordPress, 5. Go to the dashboard settings tab - language - and adapt default values if necessary by adding your languages in the catalog. You can set the order (1,2,3...) of the series. (used in `language_attributes()` template_tag). 6. Modify each post by setting (checking) the language flag in xili-language box at the right of the post editing window before publishing. 7. If you are webmaster and want to add lot of personalizations in your theme, visit [expert's corner](http://dev.xiligroup.com/?cat=480&lang=en_us). = SPECIAL NOTE FOR VERSION >= 1.5.0 and WP 3.0 = Nothing to do in functions.php : only verify that the theme is localizable and functions.php contains a function `load_theme_textdomain();` and that the theme's folder contains .mo files (in root or a sub-folder) for each languages of your website. "twentyten" default WP theme is compatible. Plugin is backward compatible for theme of monosite. But if you upgrade, it is better to restore your theme with default `load_theme_textdomain();`. Delete lines concerned by constants THEME_TEXTDOMAIN and languages sub-folder THEME_LANGS_FOLDER. NOTE FOR THEMES DESIGNER : If your theme is compatible both for newest (>3.0-apha) and older versions, add some conditional lines. NOTE FOR COMMENT FORM IN WP 3.0: Today with WP3.0, comments form language is based on default language of admin UI and not on theme's language. xili-language solves this features. So you need to add this terms msgid in the .po of your theme for translation used by xili-language. In latest version, xili-dictionary adds this option to avoid tedious copy and paste ! ` Name Email Website Comment You must be logged in to post a comment. Logged in as %2$s. Log out? Your email address will not be published. Required fields are marked * You may use these HTML tags and attributes: Leave a Reply Leave a Reply to %s Cancel reply Post Comment ` = SPECIAL NOTE FOR VERSION >= 1.5.0 and WP 2.9.x = Example with 'fusion' theme that offers localization: Only encapsule the `load_theme_textdomain()` like in that example for a theme named fusion: ` if (!class_exists('xili_language')) { // class in not (!) present... load_theme_textdomain('fusion', get_template_directory() . '/lang'); } ` Example with a theme theme that offer localization but not permit automatic detection (no terms with domain inside index.php) : replace `function init_language(){ load_theme_textdomain('thedomain', get_template_directory() . '/lang'); }` by `function init_language(){ if (class_exists('xili_language')) { define('THEME_TEXTDOMAIN','thedomain'); } else { load_theme_textdomain('thedomain', get_template_directory() . '/lang'); } }` see the [post](http://dev.xiligroup.com/?p=427 "Transform a theme with localization"). = Browser detection for visitors or authors = To change the language of the frontpage according to the language of the visitor's browser, check the popup in right small box in settings. To change the default language of a new post according to the language of the author's browser, check the popup in right small box in settings. = text direction, since 0.9.9 = Examples *for theme's designer* of functions to keep text **direction** of theme and of current post : `
... ` example in loop : ` ID) : array()); ?>
` minimal example in css : ` .rtl {direction: rtl; text-align:right !important; font-size:130% !important;} .ltr {direction: ltr; text-align:left !important;} ` **Caution** : *multilingual theme with both ltr and rtl texts needs a rigourous structure of the css !* = Archives selection = Archives tags is a very complex template tag in his background and not very easy source hookable. So we decided to add few features : by adding query in vars of the function, it will be possible to display a monthly list of archives for a selected language - `wp_get_archives('..your.vars..&lang=fr_fr')` - or the current the theme language - `wp_get_archives('..your.vars..&lang=')` -. The displayed list of links will be translated and link restrited to display only archives of this language. == Frequently Asked Questions == = What about WPMU and the trilogy ? = [xili-language](http://wordpress.org/extend/plugins/xili-language/), [xili-tidy-tags](http://wordpress.org/extend/plugins/xili-tidy-tags/), [xili-dictionary](http://wordpress.org/extend/plugins/xili-dictionary/) Since WP 3.0-alpha, if multisite is activated, the trilogy is now compatible and will include progressively some improvements dedicaded especially for WPMU context. Future specific docs will be available for registered webmasters. = How to see post or page ID in dashbord ? = *Reveal IDs for WP Admin* is an efficient plugin [found](http://wordpress.org/extend/plugins/reveal-ids-for-wp-admin-25/) in WP repository. Now since 1.6.0, IDs are displayed in sidebox UI of post edit window. = Since 1.4.1, after the translated lines, the parenthesis containing root languages *disappear* in sidebar categories list ? = Yes, only translated cat name remains. But, if you want to recover the old behaviour, you can add **graceful to hooking features of xili_language** by adding this lines of codes inside the functions.php file of the current theme. ` function my_rules_for_cat_language ($content, $category = null, $curlang='') { if (!is_admin()) : /*to detect admin UI*/ $new_cat_name = __($category->name,the_theme_domain()); if ($new_cat_name != $content) : $new_cat_name .= " (". $content .") "; endif else : $new_cat_name = $content; endif; return $new_cat_name; } add_filter('xiliml_cat_language','my_rules_for_cat_language',2,3); ` = Where can I see websites using this plugin ? = dev.xiligroup.com [here](http://dev.xiligroup.com/?p=187 "why xili-language ?") and www.xiliphone.mobi [here](http://www.xiliphone.mobi "a theme for mobile") also usable with mobile as iPhone. As multisite demo, visit the working site made with twentyone default theme: [as shown here](http://multilingual.wpmu.xilione.com) And as you can see in [stats](http://wordpress.org/extend/plugins/xili-language/stats/), hundreds of sites use xili-language. = For commercial websites, is it possible to buy support ? = Yes, use contact form [here](http://dev.xiligroup.com/?page_id=10). = What is gold functions ?, is it possible to buy them ? = Some gold functions (in xilidev-libraries) are explained [here](http://dev.xiligroup.com/?p=1111) and some belong to pro services for commercial websites. Yes, use contact form [here](http://dev.xiligroup.com/?page_id=10). = Support Forum or contact form ? = Effectively, prefer [forum](http://forum2.dev.xiligroup.com/) to obtain some support. = Does xiligroup provide free themes ? = No yet, but a lot of well designed themes like fusion or Arclite are very easily adaptable ( or the author incorporates automatic detection of xili-language as presented [here](http://dev.xiligroup.com/?p=427) ). And [xili-dictionary](http://wordpress.org/extend/plugins/xili-dictionary/) avoids to use poEdit to update .mo files with contents of terms of your database (categories, ...) == Screenshots == 1. an example of wp-content/themes folder 2. the admin settings UI 3. the language setting in post writting UI 4. coding extract with 'international' text in 'xiliphone' theme 5. xili-dictionary: Admin Tools UI - functionalities windows 6. xili-language: Admin Tools UI - set homepage and author according his browser's language. 7. xili-tidy-tags: Admin Tools UI - see this compatible plugin to group tags according languages 8. xili-language widget: Admin widgets UI - since 0.9.9.6, "multiple" languages list widget 11. xili-language: Special Admin UI sidebox - infos about theme's content for multilingual settings. 12. xili-language: Post Edit UI - when clicking Add New, a new browser window is open and links input are prefilled. 13. xili-language widgets: the new "multiple" widget to display list of recent posts in a choosen language. 14. xili-language: Post Edit UI - Check option to auto search will be useful for editor when working on existing posts and with multiple authors. == Changelog == = 1.7.0 = * new front-page mechanisms, ready for other post_types, better queries join * **latest version compatible with 2.9.x** (too much tests and options) = 1.6.x = * Add sticky_posts IDs array translation (Jacob's suggestion) - fixes refresh theme_textdomain for old WP 2.9.x) * DB queries reducing: xili_get_listlanguages() = list of language objects in settings (updated only when changed) * In WP 3.0, possible to complete top nav menu with lang list and more = 1.5.2, 3, 4, 5 = * WP 3.0 (mono or multisite): incorporates automatic detection of theme domain and his new default theme 'twentyten' * A demo in multisite mode with WP 3.0 and 'twentyten' is [here](http://multilingual.wpmu.xilione.com). * remains compatible for previous versions WP 2.9.x * some fixes - see changes log. = 1.3.x to 1.4.2a = * Rename two filters for compatibility with filters renamed by WP3.0. Incorporate posts edit UI modifications of WP3.0. * no unwanted message in homepage when theme-domain is not defined - plugin must be activated AFTER theme domain settings. * improved template_tags : xiliml_the_category, xiliml_the_other_posts (see source doc) * Browser's window title now translated for categories (`wp_title()`). Option in post edit UI to auto-search linked posts in other languages - [see this post](http://dev.xiligroup.com/?p=1498). * New option to adapt the home query according rules defined by chief editor. If home page loop is filled by most recent posts (via index or home.php), formerly, by default xili-language is able to choose the theme's language but not to sub-select the loop (without php coding). Now when checking in Settings *'Modify home query'* - no need to be a php developer. * New widget for **recent posts** (able to choose language). This new widget solves conflicts or issues occuring when WP default widget is present (contains an *obscur* `wp_reset_query`). Also a choice of language of this list of recent posts is possible - not necessary the same of the current page. And you can install multiple widgets. **Replace WP Recent Posts widget by this one named** - *List of recent posts* - * New functions to change and restore loop's language query-tag (see functions [table](http://dev.xiligroup.com/?p=1432) ). * Better dashboard post UI to create linked post (and page): *from one post, it possible to create linked post in another language and the links are prefilled. Just need to save draft to save the links between root and translated posts filled by authors.* [See](http://dev.xiligroup.com/?p=1498) * fixes lost languages's link when trash or untrash (WP 2.9.1). = summary of main features improved in previous releases up to 1.2.1 = *(this chapter is rewritten for 1.4.1 - see readme in [previous versions](http://wordpress.org/extend/plugins/xili-language/download/) to read the chronology)* = 1.4.1 = wp_title translation for categories, () suppressed in cats list display -see FAQ-, auto-search linked posts option = 1.4.0 = Option to modify home query according rules by chief editor. Fixes gold functions. New Recent Posts Widget. = 1.3.1 = Just to correct a minor omission - Add New works now for linked pages. = 1.3.0 = new functions for CMS usages. Better Post Edit UI. Fixes some issues when trash/untrash. = 1.2.1 = fixes some directories issues in (rare) xamp servers - Some improvements in post edit UI. = 1.1.8 - 1.1.9 = new features for theme's developers - see code lines - Fix title of `wp_get_archives` links with current permalinks. = 1.1 = improve `xiliml_the_others_posts` function optionally to return an array of linked posts = 1.0.2 = fix unexpected like tags metabox added by WP 28 in post edit UI - tracs #10437 = 1.0 = * New ways to define default language of front-page, * also compatible with new recent WP 2.8. * Some fixes. Unique id for category link hook = 0.9.9.6 = ready for new multiple widgets - fixed filter by in class = 0.9.9.5 = php doc enhanced, link to modify linked posts = 0.9.9.4 = Recent commments, 'Get_archives' translatable, some fixes or improvements... = 0.9.9.3 = sub selection of pages for `wp_list_pages()` with `&lang=` , some fixes = 0.9.9 = give dir of lang ltr or rtl, fixes for cat popup in post edit admin UI, fixes quick-edit update (0.9.9.1 fixes internal `get_cur_language()` that now deliver array. 0.9.9.2 fixe class of metabox has-right-sidebar for 2.8, W3C) = 0.9.8.3 = (dashboard) for new post, pre-set default language of author according his browser's language. = 0.9.8.2 = better query (`get_terms_of_groups_lite`) - fixes W3C xml:lang = 0.9.8.1 = Counting only published posts and pages, add filter for widget's titles, in admin UI link to posts of one language, compatible with xili-tidy-tags plugin. = 0.9.8 = data model now include future sub-group and sorting of languages. = 0.9.7.6 = Add new hooks to define header metas or language attributes in html tag... = 0.9.7.5 = Add detection of browser language, fixes W3C errors, record undefined state of post,... = 0.9.7.4 = Add a box in post admin edit UI to easily set link to similar posts in other languages. = 0.9.7.1 = fixes, add subfolder for langs in theme - add new tag for theme : `the_xili_local_time()` = 0.9.7 = OOP and CLASS coding - New settings UI according to new rules and style of WP 2.7 (`meta_boxes`, js). = 0.9.6 = New settings UI according to new rules and style of WP 2.7 (meta_boxes, js) = 0.9.4 = fixes and hooks from plugin to functions defined in functions.php = 0.9.3 = third public release (beta) some fixes and display language in post/page lists = 0.9.2 = second public release (beta) ready to include xili-dictionary plugin (tools) = 0.9.0 = first public release (beta) © 20100713 - MS - dev.xiligroup.com == Upgrade Notice == As usually, don't forget to backup the database before major upgrade or testing no-current version. Upgrading can be easily procedeed through WP admin UI or through ftp. Verify you install latest version of trilogy (xili-language, xili-tidy-tags, xili-dictionary). == More infos == = What about plugin settings UI localization ? = It is simple, if you have translated the settings UI of plugin in your mother language, you send us a message through the contact form that contains the link to your site where you have add the .po and .mo files. Don't forget to fill the header of the .po file with your name and email. If all is ok, the files will be added to the xili-language wp plugins repository. Because I am not able to verify the content, you remain responsible of your translation. = What happens if frontpage is a page ? = Since 0.9.9.4, the plugin incorporates now features that are formerly possible through the hookable functions of xili-language. The page as frontpage must have its clones in each other languages. Like for posts, if the user's browser is not in the default language, xili-language will display the page in the corresponding language if set by the editor. [home page of website dev.xiligroup.com](http://dev.xiligroup.com/) uses this feature. New mechanism with 3.0 and version 1.7.0 The plugin post is frequently updated [dev.xiligroup.com](http://dev.xiligroup.com/xili-language/ "Why xili-language ?") See also the [Wordpress plugins forum](http://wordpress.org/tags/xili-language/) and [dev.xiligroup Forum](http://forum.dev.xiligroup.com/). © 2008-2010 - MS - dev.xiligroup.com