languageicons.module in Language Icons 6
Same filename and directory in other branches
Icons for language links.
This is a spin off from the Internationalization (i18n) package.
File
languageicons.moduleView source
<?php
/**
* @file
* Icons for language links.
*
* This is a spin off from the Internationalization (i18n) package.
*/
/**
* Implementation of hook_theme().
*/
function languageicons_theme() {
return array(
'languageicons_icon' => array(
'arguments' => array(
'language' => NULL,
'title' => NULL,
),
),
'languageicons_place' => array(
'arguments' => array(
'text' => NULL,
'icon' => NULL,
'separator' => ' ',
),
),
);
}
/**
* Implementation of hook_help().
*/
function languageicons_help($path, $arg) {
switch ($path) {
case 'admin/help#languageicons':
$output = '<p>' . t('This module manages language icons for multilingual sites:') . '</p>';
$output .= '<ul>';
$output .= '<li>' . t('Automatically adds icons to language links') . '</li>';
$output .= '<li>' . t('Provides related theme functions') . '</li>';
$output .= '</ul>';
$output .= '<p>' . t('For more information please read the <a href="@i18n">on-line help pages</a>.', array(
'@i18n' => 'http://drupal.org/node/31631',
)) . '</p>';
return $output;
case 'admin/settings/languageicons':
$output .= '<p>' . t('To enable multilingual support for specific content types go to !configure_content_types.', array(
'!configure_content_types' => l(t('configure content types'), 'admin/content/types'),
)) . '</p>';
return $output;
}
}
/**
* Implementation of hook_menu().
*/
function languageicons_menu() {
// Direct copy of the Configure tab from locale module to
// make space for the "Localization sharing" tab below.
$items['admin/settings/language/configure/language'] = array(
'title' => 'Language negotiation',
'page callback' => 'locale_inc_callback',
'page arguments' => array(
'drupal_get_form',
'locale_languages_configure_form',
),
'access arguments' => array(
'administer languages',
),
'weight' => -10,
'type' => MENU_DEFAULT_LOCAL_TASK,
);
$items['admin/settings/language/configure/icons'] = array(
'title' => 'Icons',
'page callback' => 'drupal_get_form',
'page arguments' => array(
'languageicons_admin_settings',
),
'weight' => 10,
'type' => MENU_LOCAL_TASK,
'access arguments' => array(
'administer languages',
),
'file' => 'languageicons.admin.inc',
);
return $items;
}
/**
* Implementation of hook_translation_link_alter().
*
* Adds language icons to normal translation links.
*/
function languageicons_translation_link_alter(&$links, $path) {
if (variable_get('languageicons_show_block', 1)) {
foreach (array_keys($links) as $langcode) {
languageicons_link_add($links[$langcode]);
}
}
}
/**
* Implementation of hook_link_alter().
*
* Adds language icons to node links.
*/
function languageicons_link_alter(&$links, $node) {
if (variable_get('languageicons_show_node', 1) && !empty($node->tnid) && ($translations = module_invoke('translation', 'node_get_translations', $node->tnid))) {
$languages = language_list();
foreach ($translations as $langcode => $translation) {
$index = 'node_translation_' . $langcode;
if (!empty($links[$index])) {
languageicons_link_add($links[$index]);
}
}
}
}
/**
* Add language icon to link.
*
* The language icon may be a different language as the destination page, can be passed in 'language_icon'.
*/
function languageicons_link_add(&$link, $title = NULL) {
$language = isset($link['language_icon']) ? $link['language_icon'] : $link['language'];
$title = $title ? $title : $link['title'];
if ($icon = theme('languageicons_icon', $language, $title)) {
$link['title'] = theme('languageicons_place', $link['title'], $icon);
$link['html'] = TRUE;
}
}
/**
* Theme language icon.
*
* This function can be overridden for no language icons.
*/
function theme_languageicons_icon($language, $title = NULL) {
if ($path = variable_get('languageicons_path', drupal_get_path('module', 'languageicons') . '/flags/*.png')) {
$src = base_path() . str_replace('*', $language->language, $path);
$title = $title ? $title : $language->native;
$attribs = array(
'class' => 'language-icon',
'alt' => $title,
);
if ($size = variable_get('languageicons_size', '16x12')) {
list($width, $height) = explode('x', $size);
$attribs += array(
'width' => $width,
'height' => $height,
);
}
return "<img src='{$src}' " . drupal_attributes($attribs) . ' />';
}
}
/**
* Theme language icon and text.
*
* @ingroup themeable
*/
function theme_languageicons_place($text, $icon, $separator = ' ') {
switch (variable_get('languageicons_placement', 'before')) {
case 'after':
return $text . $separator . $icon;
case 'replace':
return $icon;
case 'before':
default:
return $icon . $separator . $text;
}
}
Functions
Name | Description |
---|---|
languageicons_help | Implementation of hook_help(). |
languageicons_link_add | Add language icon to link. |
languageicons_link_alter | Implementation of hook_link_alter(). |
languageicons_menu | Implementation of hook_menu(). |
languageicons_theme | Implementation of hook_theme(). |
languageicons_translation_link_alter | Implementation of hook_translation_link_alter(). |
theme_languageicons_icon | Theme language icon. |
theme_languageicons_place | Theme language icon and text. |