| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 | 
							- <?php
 
- /**
 
-  * @file
 
-  * Variable API module. Definition for Drupal core variables
 
-  */
 
- /**
 
-  * Implements hook_variable_info().
 
-  */
 
- function locale_variable_info($options) {
 
-   // This variable will be altered by translation module. See translation.variable.inc
 
-   $variables['language_content_type_[node_type]'] = array(
 
-     'type' => 'multiple',
 
-     'title' => t('Multilingual support'),
 
-     'repeat' => array(
 
-       'type' => 'enable',
 
-        // Set options here so translation module can add some more
 
-       'options' => array(t('Disabled'), t('Enabled')),
 
-     ),
 
-     'description' => t('Enable multilingual support for this content type. If enabled, a language selection field will be added to the editing form, allowing you to select from one of the <a href="!languages">enabled languages</a>. If disabled, new posts are saved with the default language. Existing content will not be affected by changing this option.', array('!languages' => url('admin/config/regional/language', $options)), $options),
 
-     'group' => 'node_type_settings',
 
-   );
 
-   $variables['language_default'] = array(
 
-     'title' => t('Site default language'),
 
-     'type' => 'select',
 
-     'group' => 'regional_settings',
 
-     'options callback' => 'locale_variable_options_language',
 
-     'format callback' => 'locale_variable_language_default_format',
 
-     'element callback' => 'locale_variable_language_default_element',
 
-     'default callback' => 'locale_variable_language_default',
 
-   );
 
-   return $variables;
 
- }
 
- /**
 
-  * Implements hook_variable_type_info().
 
-  */
 
- function locale_variable_type_info() {
 
-   // Language code
 
-   $type['language'] = array(
 
-     'title' => t('Language'),
 
-     'options callback' => 'locale_variable_options_language',
 
-     'type' => 'select',
 
-   );
 
-   return $type;
 
- }
 
- /**
 
-  * Callback for all languages
 
-  */
 
- function locale_variable_options_language($variable, $options) {
 
-   return locale_language_list('name', TRUE);
 
- }
 
- /**
 
-  * Form element for site default language
 
-  */
 
- function locale_variable_language_default_element($variable, $options) {
 
-   $element = variable_form_element_options($variable, $options);
 
-   // Default needs to be language code for the radios to work.
 
-   $element['#default_value'] = $element['#default_value']->language;
 
-   // Since 'value callback' is useless as it is run before validation, we use validate
 
-   // callback to transform language code into an object.
 
-   $element['#element_validate'][] = 'locale_variable_language_element_validate';
 
-   return $element;
 
- }
 
- /**
 
-  * Get language default.
 
-  */
 
- function locale_variable_language_default($variable, $options) {
 
-   return language_default();
 
- }
 
- /**
 
-  * Format language object variable
 
-  */
 
- function locale_variable_language_default_format($variable, $options = array()) {
 
-   return !empty($variable['value']) ? check_plain($variable['value']->name) : t('None');
 
- }
 
- /**
 
-  * Replace language code by language object on submission.
 
-  *
 
-  * This runs alter default element validation so we know it is a valid checkbox option.
 
-  */
 
- function locale_variable_language_element_validate($element, &$form_state, $form) {
 
-   $languages = language_list();
 
-   $language = $languages[$element['#value']];
 
-   form_set_value($element, $language, $form_state);
 
- }
 
 
  |