diff options
author | Moonchild <mcwerewolf@gmail.com> | 2018-07-07 15:18:51 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-07 15:18:51 +0200 |
commit | 0c5085ace12dec8cb6dc503507363dc4b19f93e3 (patch) | |
tree | d9f4cf028e9eb14059f8f2d1b2c5c76408ec8ce9 /toolkit/components/reader/AboutReader.jsm | |
parent | cbd52d48fa2524beb37b506b55a315b49f026a1e (diff) | |
parent | 6a8ba478553625a31b47e726d04c608d955c6b93 (diff) | |
download | UXP-0c5085ace12dec8cb6dc503507363dc4b19f93e3.tar UXP-0c5085ace12dec8cb6dc503507363dc4b19f93e3.tar.gz UXP-0c5085ace12dec8cb6dc503507363dc4b19f93e3.tar.lz UXP-0c5085ace12dec8cb6dc503507363dc4b19f93e3.tar.xz UXP-0c5085ace12dec8cb6dc503507363dc4b19f93e3.zip |
Merge pull request #606 from Ascrod/master
Updates to Reader and Narrator components.
Diffstat (limited to 'toolkit/components/reader/AboutReader.jsm')
-rw-r--r-- | toolkit/components/reader/AboutReader.jsm | 31 |
1 files changed, 16 insertions, 15 deletions
diff --git a/toolkit/components/reader/AboutReader.jsm b/toolkit/components/reader/AboutReader.jsm index fb82e5789..c5d04476d 100644 --- a/toolkit/components/reader/AboutReader.jsm +++ b/toolkit/components/reader/AboutReader.jsm @@ -200,9 +200,6 @@ AboutReader.prototype = { } else if (!target.closest(".dropdown-popup")) { this._closeDropdowns(); } - if (target.tagName == "A" && !target.classList.contains("reader-domain")) { - this._linkClicked(aEvent); - } break; case "scroll": this._closeDropdowns(true); @@ -720,6 +717,21 @@ AboutReader.prototype = { } }, + _fixLocalLinks() { + // We need to do this because preprocessing the content through nsIParserUtils + // gives back a DOM with a <base> element. That influences how these URLs get + // resolved, making them no longer match the document URI (which is + // about:reader?url=...). To fix this, make all the hash URIs absolute. This + // is hacky, but the alternative of removing the base element has potential + // security implications if Readability has not successfully made all the URLs + // absolute, so we pick just fixing these in-document links explicitly. + let localLinks = this._contentElement.querySelectorAll("a[href^='#']"); + for (let localLink of localLinks) { + // Have to get the attribute because .href provides an absolute URI. + localLink.href = this._doc.documentURI + localLink.getAttribute("href"); + } + }, + _formatReadTime(slowEstimate, fastEstimate) { let displayStringKey = "aboutReader.estimatedReadTimeRange1"; @@ -790,6 +802,7 @@ AboutReader.prototype = { false, articleUri, this._contentElement); this._contentElement.innerHTML = ""; this._contentElement.appendChild(contentFragment); + this._fixLocalLinks(); this._maybeSetTextDirection(article); this._foundLanguage(article.language); @@ -978,18 +991,6 @@ AboutReader.prototype = { }, /* - * Override link handling for same-page references so we don't exit Reader View. - */ - _linkClicked(event) { - var originalUrl = Services.io.newURI(this._getOriginalUrl(), null, null); - var targetUrl = Services.io.newURI(event.target.href, null, null); - if (originalUrl.specIgnoringRef == targetUrl.specIgnoringRef) { - event.preventDefault(); - this._goToReference(targetUrl.ref); - } - }, - - /* * Scroll reader view to a reference */ _goToReference(ref) { |