You are here

languageicons.module in Language Icons 6

Same filename and directory in other branches
  1. 8 languageicons.module
  2. 6.2 languageicons.module
  3. 7 languageicons.module

Icons for language links.

This is a spin off from the Internationalization (i18n) package.

File

languageicons.module
View 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

Namesort descending 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.