From 9b85757102fbd44e88d0a3909fdf8b90f191b593 Mon Sep 17 00:00:00 2001 From: Vojta Jina Date: Thu, 20 Oct 2011 08:46:09 -0700 Subject: [PATCH] fix($location): rewrite links with nested elements For example: inner text If you click on "text", then the span element is event.target, so we need to traverse the DOM. --- src/service/location.js | 12 ++++++++---- test/service/locationSpec.js | 14 ++++++++++++-- 2 files changed, 20 insertions(+), 6 deletions(-) diff --git a/src/service/location.js b/src/service/location.js index 2ffc55878f68..d1d34e6762be 100644 --- a/src/service/location.js +++ b/src/service/location.js @@ -442,12 +442,16 @@ angularServiceInject('$location', function($browser, $sniffer, $locationConfig, // TODO(vojta): rewrite link when opening in new tab/window (in legacy browser) // currently we open nice url link and redirect then - if (uppercase(event.target.nodeName) != 'A' || event.ctrlKey || event.metaKey || - event.which == 2) return; + if (event.ctrlKey || event.metaKey || event.which == 2) return; - var elm = jqLite(event.target), - href = elm.attr('href'); + var elm = jqLite(event.target); + // traverse the DOM up to find first A tag + while (elm.length && lowercase(elm[0].nodeName) !== 'a') { + elm = elm.parent(); + } + + var href = elm.attr('href'); if (!href || isDefined(elm.attr('ng:ext-link')) || elm.attr('target')) return; // remove same domain from full url links (IE7 always returns full hrefs) diff --git a/test/service/locationSpec.js b/test/service/locationSpec.js index 6cf302fe5cd5..9a7aa94306c9 100644 --- a/test/service/locationSpec.js +++ b/test/service/locationSpec.js @@ -556,10 +556,11 @@ describe('$location', function() { var root, link, extLink, $browser, originalBrowser, lastEventPreventDefault; - function init(linkHref, html5Mode, supportHist, attrs) { + function init(linkHref, html5Mode, supportHist, attrs, content) { var jqRoot = jqLite('
'); attrs = attrs ? ' ' + attrs + ' ' : ''; - link = jqLite('link')[0]; + content = content || 'link'; + link = jqLite('' + content + '')[0]; root = jqRoot.append(link)[0]; jqLite(document.body).append(jqRoot); @@ -670,6 +671,15 @@ describe('$location', function() { }); + it('should rewrite when clicked span inside link', function() { + init('some/link', true, true, '', 'link'); + var span = jqLite(link).find('span'); + + browserTrigger(span, 'click'); + expectRewriteTo('http://host.com/base/some/link'); + }); + + // don't run next tests on IE<9, as browserTrigger does not simulate pressed keys if (!(msie < 9)) {