function custom_breadcrumbs_taxonomy_vocabulary_form in Custom Breadcrumbs 7.2
Same name and namespace in other branches
- 6.2 custom_breadcrumbs_taxonomy/custom_breadcrumbs_taxonomy.admin.inc \custom_breadcrumbs_taxonomy_vocabulary_form()
Vocabulary Form.
Form builder; Displays an edit form for a custom breadcrumb taxonomy vocabulary record.
See also
custom_breadcrumbs_form_validate()
custom_breadcrumbs_form_submit()
1 string reference to 'custom_breadcrumbs_taxonomy_vocabulary_form'
- custom_breadcrumbs_taxonomy_menu in custom_breadcrumbs_taxonomy/
custom_breadcrumbs_taxonomy.module - Implements hook_menu().
File
- custom_breadcrumbs_taxonomy/
custom_breadcrumbs_taxonomy.admin.inc, line 101 - Administration pages for custom_breadcrumbs_taxonomy.
Code
function custom_breadcrumbs_taxonomy_vocabulary_form($form, &$form_state, $type) {
$form = array();
$bid = arg(5);
$breadcrumb = NULL;
if (isset($bid)) {
drupal_set_title(t('Edit Custom Breadcrumb for Taxonomy Vocabulary'));
$breadcrumbs = custom_breadcrumbs_load_breadcrumbs('custom_breadcrumbs_taxonomy', 'custom_breadcrumbs_taxonomy_vocabulary', array(
'bid' => $bid,
));
$breadcrumb = array_pop($breadcrumbs);
}
else {
drupal_set_title(t('Add Custom Breadcrumb for Taxonomy Vocabulary'));
}
// Get a list of all vocabularies.
$vocabularies = taxonomy_get_vocabularies();
$excluded = variable_get('custom_breadcrumbs_taxonomy_excluded_vocabs', array());
$options = array();
foreach ($vocabularies as $vid => $vocabulary) {
if (!in_array($vocabulary->vid, $excluded)) {
$options[$vid] = $vocabulary->name;
}
}
$form['vid'] = array(
'#type' => 'select',
'#title' => t('Vocabulary'),
'#options' => $options,
'#required' => TRUE,
'#description' => t('Select the taxonomy vocabulary to apply this breadcrumb to. <a href="@excluded">Excluded vocabularies</a> will not be listed here.', array(
'@excluded' => url('admin/config/user-interface/custom-breadcrumbs'),
)),
'#default_value' => isset($breadcrumb->vid) ? $breadcrumb->vid : NULL,
'#weight' => -10,
);
module_load_include('inc', 'custom_breadcrumbs', 'custom_breadcrumbs.admin');
$form += custom_breadcrumbs_common_form_elements($bid, $breadcrumb);
$taxonomy_breadcrumbs_mode = variable_get('custom_breadcrumbs_taxonomy_use_hierarchy', TRUE);
if ($taxonomy_breadcrumbs_mode) {
// Limit one title and path per taxonomy vocabulary.
$form['titles'] = array(
'#type' => 'textfield',
'#title' => t('Title'),
'#required' => FALSE,
'#description' => t('Specify the Title to use for the vocabulary breadcrumb. Leave blank to use the vocabulary name. Disable the <em>use taxonomy hierarchy</em> option on the <a href="@link">Custom Breadcrumbs Settings</a> page if you would prefer to specify several titles/paths for the breadcrumb.', array(
'@link' => url('admin/config/user-interface/custom-breadcrumbs'),
)),
'#default_value' => isset($breadcrumb->titles) ? $breadcrumb->titles : NULL,
);
$form['paths'] = array(
'#type' => 'textfield',
'#title' => t('Path'),
'#required' => TRUE,
'#description' => t('Specify the Drupal path that the taxonomy vocabulary will be linked to. Currently operating in taxonomy breadcrumbs mode. Disable the <em>use taxonomy hierarchy</em> option on the <a href="@link">Custom Breadcrumbs Settings</a> page if you would prefer to specify several titles/paths for the breadcrumb.', array(
'@link' => url('admin/config/user-interface/custom-breadcrumbs'),
)),
'#default_value' => isset($breadcrumb->paths) ? $breadcrumb->paths : NULL,
);
}
if (module_exists('token')) {
$form['help']['tokens']['#token_types'][] = 'term';
}
$form['#module'] = 'custom_breadcrumbs_taxonomy';
$form['#infokey'] = 'taxonomy_vocabulary';
$form['#submit'][] = 'custom_breadcrumbs_form_submit';
$form['#validate'][] = 'custom_breadcrumbs_form_validate';
return $form;
}