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 }
|