annotate sites/all/modules/menu_attributes/menu_attributes.module @ 11:b0ee71395280

deleted .DS_Store files
author danieleb <danielebarchiesi@me.com>
date Mon, 28 Oct 2013 16:12:13 +0000
parents b74b41bb73f0
children
rev   line source
danielebarchiesi@2 1 <?php
danielebarchiesi@2 2
danielebarchiesi@2 3 /**
danielebarchiesi@2 4 * @file
danielebarchiesi@2 5 * Alters the menu item form to allow the administrator to specify additional
danielebarchiesi@2 6 * attributes for the menu link
danielebarchiesi@2 7 */
danielebarchiesi@2 8
danielebarchiesi@2 9 /**
danielebarchiesi@2 10 * Implements hook_permission().
danielebarchiesi@2 11 */
danielebarchiesi@2 12 function menu_attributes_permission() {
danielebarchiesi@2 13 return array(
danielebarchiesi@2 14 'administer menu attributes' => array(
danielebarchiesi@2 15 'title' => t('Administer menu attributes'),
danielebarchiesi@2 16 'description' => t('Administer menu attributes.'),
danielebarchiesi@2 17 ),
danielebarchiesi@2 18 );
danielebarchiesi@2 19 }
danielebarchiesi@2 20
danielebarchiesi@2 21 /**
danielebarchiesi@2 22 * Implements hook_menu_link_alter().
danielebarchiesi@2 23 */
danielebarchiesi@2 24 function menu_attributes_menu_link_alter(&$item, $menu) {
danielebarchiesi@2 25 if (isset($item['options']['attributes']) && is_array($item['options']['attributes'])) {
danielebarchiesi@2 26 // Filter out blank attributes.
danielebarchiesi@2 27 foreach ($item['options']['attributes'] as $key => $value) {
danielebarchiesi@2 28 if ((is_array($value) && empty($value)) || is_string($value) && !drupal_strlen($value)) {
danielebarchiesi@2 29 unset($item['options']['attributes'][$key]);
danielebarchiesi@2 30 }
danielebarchiesi@2 31 }
danielebarchiesi@2 32
danielebarchiesi@2 33 // Convert classes to an array.
danielebarchiesi@2 34 if (isset($item['options']['attributes']['class']) && is_string($item['options']['attributes']['class'])) {
danielebarchiesi@2 35 $item['options']['attributes']['class'] = explode(' ', $item['options']['attributes']['class']);
danielebarchiesi@2 36 }
danielebarchiesi@2 37 }
danielebarchiesi@2 38 }
danielebarchiesi@2 39
danielebarchiesi@2 40 /**
danielebarchiesi@2 41 * Implements hook_menu_attriute_info().
danielebarchiesi@2 42 */
danielebarchiesi@2 43 function menu_attributes_menu_attribute_info() {
danielebarchiesi@2 44 $info['title'] = array(
danielebarchiesi@2 45 'label' => t('Title'),
danielebarchiesi@2 46 'description' => t('The description displayed when hovering over the link.'),
danielebarchiesi@2 47 'form' => array(
danielebarchiesi@2 48 '#type' => 'textarea',
danielebarchiesi@2 49 '#rows' => 2,
danielebarchiesi@2 50 ),
danielebarchiesi@2 51 );
danielebarchiesi@2 52 $info['id'] = array(
danielebarchiesi@2 53 'label' => t('ID'),
danielebarchiesi@2 54 'description' => t('Specifies a unique ID for the link.'),
danielebarchiesi@2 55 );
danielebarchiesi@2 56 $info['name'] = array(
danielebarchiesi@2 57 'label' => t('Name'),
danielebarchiesi@2 58 );
danielebarchiesi@2 59 $info['rel'] = array(
danielebarchiesi@2 60 'label' => t('Relationship'),
danielebarchiesi@2 61 'description' => t("Specifies the relationship between the current page and the link. Enter 'nofollow' here to nofollow this link."),
danielebarchiesi@2 62 );
danielebarchiesi@2 63 $info['class'] = array(
danielebarchiesi@2 64 'label' => t('Classes'),
danielebarchiesi@2 65 'description' => t('Enter additional classes to be added to the link.'),
danielebarchiesi@2 66 );
danielebarchiesi@2 67 $info['style'] = array(
danielebarchiesi@2 68 'label' => t('Style'),
danielebarchiesi@2 69 'description' => t('Enter additional styles to be applied to the link.'),
danielebarchiesi@2 70 );
danielebarchiesi@2 71 $info['target'] = array(
danielebarchiesi@2 72 'label' => t('Target'),
danielebarchiesi@2 73 'description' => t('Specifies where to open the link. Using this attribute breaks XHTML validation.'),
danielebarchiesi@2 74 'form' => array(
danielebarchiesi@2 75 '#type' => 'select',
danielebarchiesi@2 76 '#options' => array(
danielebarchiesi@2 77 '' => 'None (i.e. same window)',
danielebarchiesi@2 78 '_blank' => 'New window (_blank)',
danielebarchiesi@2 79 '_top' => 'Top window (_top)',
danielebarchiesi@2 80 '_self' => 'Same window (_self)',
danielebarchiesi@2 81 '_parent' => 'Parent window (_parent)',
danielebarchiesi@2 82 ),
danielebarchiesi@2 83 ),
danielebarchiesi@2 84 );
danielebarchiesi@2 85 $info['accesskey'] = array(
danielebarchiesi@2 86 'label' => t('Access Key'),
danielebarchiesi@2 87 'description' => t('Specifies a <a href="@accesskey">keyboard shortcut</a> to access this link.', array('@accesskey' => url('http://en.wikipedia.org/wiki/Access_keys'))),
danielebarchiesi@2 88 'form' => array(
danielebarchiesi@2 89 '#maxlength' => 1,
danielebarchiesi@2 90 '#size' => 1,
danielebarchiesi@2 91 ),
danielebarchiesi@2 92 );
danielebarchiesi@2 93 return $info;
danielebarchiesi@2 94 }
danielebarchiesi@2 95
danielebarchiesi@2 96 /**
danielebarchiesi@2 97 * Fetch an array of menu attributes.
danielebarchiesi@2 98 */
danielebarchiesi@2 99 function menu_attributes_get_menu_attribute_info() {
danielebarchiesi@2 100 $attributes = module_invoke_all('menu_attribute_info');
danielebarchiesi@2 101 drupal_alter('menu_attribute_info', $attributes);
danielebarchiesi@2 102
danielebarchiesi@2 103 // Merge in defaul values.
danielebarchiesi@2 104 foreach ($attributes as $attribute => &$info) {
danielebarchiesi@2 105 $info += array(
danielebarchiesi@2 106 'form' => array(),
danielebarchiesi@2 107 'enabled' => variable_get("menu_attributes_{$attribute}_enable", 1),
danielebarchiesi@2 108 'default' => '',
danielebarchiesi@2 109 );
danielebarchiesi@2 110 $info['form'] += array(
danielebarchiesi@2 111 '#type' => 'textfield',
danielebarchiesi@2 112 '#title' => $info['label'],
danielebarchiesi@2 113 '#description' => isset($info['description']) ? $info['description'] : '',
danielebarchiesi@2 114 '#default_value' => variable_get("menu_attributes_{$attribute}_default", $info['default']),
danielebarchiesi@2 115 );
danielebarchiesi@2 116 }
danielebarchiesi@2 117
danielebarchiesi@2 118 return $attributes;
danielebarchiesi@2 119 }
danielebarchiesi@2 120
danielebarchiesi@2 121 /**
danielebarchiesi@2 122 * Implements hook_form_FORM_ID_alter().
danielebarchiesi@2 123 *
danielebarchiesi@2 124 * Adds menu attribute options to the edit menu item form.
danielebarchiesi@2 125 *
danielebarchiesi@2 126 * @see menu_edit_item()
danielebarchiesi@2 127 * @see _menu_attributes_form_alter()
danielebarchiesi@2 128 * @see menu_attributes_form_menu_edit_item_submit()
danielebarchiesi@2 129 */
danielebarchiesi@2 130 function menu_attributes_form_menu_edit_item_alter(&$form, $form_state) {
danielebarchiesi@2 131 $item = $form['original_item']['#value'];
danielebarchiesi@2 132 _menu_attributes_form_alter($form, $item, $form);
danielebarchiesi@2 133 }
danielebarchiesi@2 134
danielebarchiesi@2 135 /**
danielebarchiesi@2 136 * Implements hook_form_FORM_ID_alter().
danielebarchiesi@2 137 *
danielebarchiesi@2 138 * Adds menu attribute options to the node's edit menu item form.
danielebarchiesi@2 139 *
danielebarchiesi@2 140 * @see _menu_attributes_form_alter()
danielebarchiesi@2 141 */
danielebarchiesi@2 142 function menu_attributes_form_node_form_alter(&$form, $form_state) {
danielebarchiesi@2 143 if (isset($form['menu']['link'])) {
danielebarchiesi@2 144 $item = $form['#node']->menu;
danielebarchiesi@2 145 _menu_attributes_form_alter($form['menu']['link'], $item, $form);
danielebarchiesi@2 146 $form['menu']['link']['options']['attributes']['#type'] = 'container';
danielebarchiesi@2 147 }
danielebarchiesi@2 148 }
danielebarchiesi@2 149
danielebarchiesi@2 150 /**
danielebarchiesi@2 151 * Add the menu attributes to a menu item edit form.
danielebarchiesi@2 152 *
danielebarchiesi@2 153 * @param $form
danielebarchiesi@2 154 * The menu item edit form passed by reference.
danielebarchiesi@2 155 * @param $item
danielebarchiesi@2 156 * The optional existing menu item for context.
danielebarchiesi@2 157 */
danielebarchiesi@2 158 function _menu_attributes_form_alter(array &$form, array $item = array(), array &$complete_form) {
danielebarchiesi@2 159 // Restrict access to the new form elements.
danielebarchiesi@2 160 $form['options']['attributes']['#access'] = user_access('administer menu attributes');
danielebarchiesi@2 161
danielebarchiesi@2 162 $form['options']['#tree'] = TRUE;
danielebarchiesi@2 163 $form['options']['#weight'] = 50;
danielebarchiesi@2 164
danielebarchiesi@2 165 // Unset the previous value so that the new values get saved.
danielebarchiesi@2 166 unset($form['options']['#value']['attributes']);
danielebarchiesi@2 167
danielebarchiesi@2 168 $form['options']['attributes'] = array(
danielebarchiesi@2 169 '#type' => 'fieldset',
danielebarchiesi@2 170 '#title' => t('Menu item attributes'),
danielebarchiesi@2 171 '#collapsible' => TRUE,
danielebarchiesi@2 172 '#collapsed' => FALSE,
danielebarchiesi@2 173 '#tree' => TRUE,
danielebarchiesi@2 174 );
danielebarchiesi@2 175
danielebarchiesi@2 176 $attributes = menu_attributes_get_menu_attribute_info();
danielebarchiesi@2 177 foreach ($attributes as $attribute => $info) {
danielebarchiesi@2 178 // Merge in the proper default value.
danielebarchiesi@2 179 if (isset($item['options']['attributes'][$attribute])) {
danielebarchiesi@2 180 // If the menu link already has this attribute, use it.
danielebarchiesi@2 181 $info['form']['#default_value'] = $item['options']['attributes'][$attribute];
danielebarchiesi@2 182 // Convert the classes array to a string for the form.
danielebarchiesi@2 183 if ($attribute == 'class' && is_array($info['form']['#default_value'])) {
danielebarchiesi@2 184 $info['form']['#default_value'] = implode(' ', $info['form']['#default_value']);
danielebarchiesi@2 185 }
danielebarchiesi@2 186 }
danielebarchiesi@2 187 elseif ($item['mlid']) {
danielebarchiesi@2 188 // If this is an existing link, use the raw default (usually empty).
danielebarchiesi@2 189 $info['form']['#default_value'] = $info['default'];
danielebarchiesi@2 190 }
danielebarchiesi@2 191 $form['options']['attributes'][$attribute] = $info['form'] + array(
danielebarchiesi@2 192 '#access' => $info['enabled'],
danielebarchiesi@2 193 );
danielebarchiesi@2 194 }
danielebarchiesi@2 195
danielebarchiesi@2 196 // Add form values for the reset of $item['options'] and
danielebarchiesi@2 197 // $item['options']['attributes'] so the values will carry over during save.
danielebarchiesi@2 198 foreach ($item['options'] as $key => $value) {
danielebarchiesi@2 199 if ($key !== 'attributes' && !isset($form['options'][$key])) {
danielebarchiesi@2 200 $form['options'][$key] = array(
danielebarchiesi@2 201 '#type' => 'value',
danielebarchiesi@2 202 '#value' => $value,
danielebarchiesi@2 203 );
danielebarchiesi@2 204 }
danielebarchiesi@2 205 }
danielebarchiesi@2 206 if (isset($item['options']['attributes'])) {
danielebarchiesi@2 207 foreach ($item['options']['attributes'] as $key => $value) {
danielebarchiesi@2 208 if (!isset($form['options']['attributes'][$key])) {
danielebarchiesi@2 209 $form['options']['attributes'][$key] = array(
danielebarchiesi@2 210 '#type' => 'value',
danielebarchiesi@2 211 '#value' => $value,
danielebarchiesi@2 212 );
danielebarchiesi@2 213 }
danielebarchiesi@2 214 }
danielebarchiesi@2 215 }
danielebarchiesi@2 216
danielebarchiesi@2 217 // Hide the 'description' field since we will be using our own 'title' field.
danielebarchiesi@2 218 if (isset($form['description'])) {
danielebarchiesi@2 219 $form['description']['#access'] = FALSE;
danielebarchiesi@2 220
danielebarchiesi@2 221 // Because this form uses a special $form['description'] field which is
danielebarchiesi@2 222 // really the 'title' attribute, we need to add special pre-submit handling
danielebarchiesi@2 223 // to ensure our field gets saved as the title attribute.
danielebarchiesi@2 224 array_unshift($complete_form['#submit'], '_menu_attributes_form_submit');
danielebarchiesi@2 225 }
danielebarchiesi@2 226
danielebarchiesi@2 227 $form['options']['attributes']['#access'] = (bool) element_get_visible_children($form['options']['attributes']);
danielebarchiesi@2 228 }
danielebarchiesi@2 229
danielebarchiesi@2 230 /**
danielebarchiesi@2 231 * Form submit handler for menu item links.
danielebarchiesi@2 232 *
danielebarchiesi@2 233 * Move the title attributes value into the 'description' value so that it
danielebarchiesi@2 234 * will get properly saved.
danielebarchiesi@2 235 */
danielebarchiesi@2 236 function _menu_attributes_form_submit($form, &$form_state) {
danielebarchiesi@2 237 if (isset($form_state['values']['menu']['options']['attributes']['title'])) {
danielebarchiesi@2 238 $form_state['values']['menu']['description'] = $form_state['values']['menu']['options']['attributes']['title'];
danielebarchiesi@2 239 }
danielebarchiesi@2 240 elseif (isset($form_state['values']['options']['attributes']['title'])) {
danielebarchiesi@2 241 $form_state['values']['description'] = $form_state['values']['options']['attributes']['title'];
danielebarchiesi@2 242 }
danielebarchiesi@2 243 }
danielebarchiesi@2 244
danielebarchiesi@2 245 /**
danielebarchiesi@2 246 * Implements hook_form_FORM_ID_alter().
danielebarchiesi@2 247 *
danielebarchiesi@2 248 * Alters the menu settings form with our menu attribute settings.
danielebarchiesi@2 249 *
danielebarchiesi@2 250 * @see menu_configure_form()
danielebarchiesi@2 251 */
danielebarchiesi@2 252 function menu_attributes_form_menu_configure_alter(&$form, $form_state) {
danielebarchiesi@2 253 if (!user_access('administer menu attributes')) {
danielebarchiesi@2 254 return;
danielebarchiesi@2 255 }
danielebarchiesi@2 256
danielebarchiesi@2 257 $form['attributes_title'] = array(
danielebarchiesi@2 258 '#type' => 'item',
danielebarchiesi@2 259 '#title' => t('Menu item attribute options'),
danielebarchiesi@2 260 );
danielebarchiesi@2 261 $form['attributes_vertical_tabs'] = array(
danielebarchiesi@2 262 '#type' => 'vertical_tabs',
danielebarchiesi@2 263 '#attached' => array(
danielebarchiesi@2 264 'js' => array(drupal_get_path('module', 'menu_attributes') . '/menu_attributes.js'),
danielebarchiesi@2 265 ),
danielebarchiesi@2 266 );
danielebarchiesi@2 267
danielebarchiesi@2 268 $attributes = menu_attributes_get_menu_attribute_info();
danielebarchiesi@2 269 foreach ($attributes as $attribute => $info) {
danielebarchiesi@2 270 $form['attributes'][$attribute] = array(
danielebarchiesi@2 271 '#type' => 'fieldset',
danielebarchiesi@2 272 '#title' => $info['label'],
danielebarchiesi@2 273 '#group' => 'attributes_vertical_tabs',
danielebarchiesi@2 274 '#description' => $info['form']['#description'],
danielebarchiesi@2 275 );
danielebarchiesi@2 276 $form['attributes'][$attribute]["menu_attributes_{$attribute}_enable"] = array(
danielebarchiesi@2 277 '#type' => 'checkbox',
danielebarchiesi@2 278 '#title' => t('Enable the @attribute attribute.', array('@attribute' => drupal_strtolower($info['label']))),
danielebarchiesi@2 279 '#default_value' => $info['enabled'],
danielebarchiesi@2 280 );
danielebarchiesi@2 281 $form['attributes'][$attribute]["menu_attributes_{$attribute}_default"] = array(
danielebarchiesi@2 282 '#title' => t('Default'),
danielebarchiesi@2 283 '#description' => '',
danielebarchiesi@2 284 '#states' => array(
danielebarchiesi@2 285 'invisible' => array(
danielebarchiesi@2 286 'input[name="menu_attributes_' . $attribute . '_enable"]' => array('checked' => FALSE),
danielebarchiesi@2 287 ),
danielebarchiesi@2 288 ),
danielebarchiesi@2 289 ) + $info['form'];
danielebarchiesi@2 290 }
danielebarchiesi@2 291 }