diff options
Diffstat (limited to 'includes/common.inc')
-rw-r--r-- | includes/common.inc | 42 |
1 files changed, 38 insertions, 4 deletions
diff --git a/includes/common.inc b/includes/common.inc index b15dccd2f..62c5d22eb 100644 --- a/includes/common.inc +++ b/includes/common.inc @@ -5206,10 +5206,44 @@ function drupal_pre_render_conditional_comments($elements) { * @return * The passed in elements containing a rendered link in '#markup'. */ -function drupal_pre_render_link($elements) { - $options = isset($elements['#options']) ? $elements['#options'] : array(); - $elements['#markup'] = l($elements['#title'], $elements['#href'], $options); - return $elements; +function drupal_pre_render_link($element) { + // By default, link options to pass to l() are normally set in #options. + $element += array('#options' => array()); + // However, within the scope of renderable elements, #attributes is a valid + // way to specify attributes, too. Take them into account, but do not override + // attributes from #options. + if (isset($element['#attributes'])) { + $element['#options'] += array('attributes' => array()); + $element['#options']['attributes'] += $element['#attributes']; + } + + // This #pre_render callback can be invoked from inside or outside of a Form + // API context, and depending on that, a HTML ID may be already set in + // different locations. #options should have precedence over Form API's #id. + // #attributes have been taken over into #options above already. + if (isset($element['#options']['attributes']['id'])) { + $element['#id'] = $element['#options']['attributes']['id']; + } + elseif (isset($element['#id'])) { + $element['#options']['attributes']['id'] = $element['#id']; + } + + // Conditionally invoke ajax_pre_render_element(), if #ajax is set. + if (isset($element['#ajax']) && !isset($element['#ajax_processed'])) { + // If no HTML ID was found above, automatically create one. + if (!isset($element['#id'])) { + $element['#id'] = $element['#options']['attributes']['id'] = drupal_html_id('ajax-link'); + } + // If #ajax['path] was not specified, use the href as AJAX request URL. + if (!isset($element['#ajax']['path'])) { + $element['#ajax']['path'] = $element['#href']; + $element['#ajax']['options'] = $element['#options']; + } + $element = ajax_pre_render_element($element); + } + + $element['#markup'] = l($element['#title'], $element['#href'], $element['#options']); + return $element; } /** |