diff --git a/content-src/asrouter/components/RichText/RichText.jsx b/content-src/asrouter/components/RichText/RichText.jsx index bf462c29a..f9eab80db 100644 --- a/content-src/asrouter/components/RichText/RichText.jsx +++ b/content-src/asrouter/components/RichText/RichText.jsx @@ -17,7 +17,7 @@ const ALLOWED_TAGS = { * Transform an object (tag name: {url}) into (tag name: anchor) where the url * is used as href, in order to render links inside a Fluent.Localized component. */ -export function convertLinks(links, sendClick, doNotAutoBlock) { +export function convertLinks(links, sendClick, doNotAutoBlock, openNewWindow = false) { if (links) { return Object.keys(links).reduce((acc, linkTag) => { const {action} = links[linkTag]; @@ -25,7 +25,7 @@ export function convertLinks(links, sendClick, doNotAutoBlock) { const url = action ? false : safeURI(links[linkTag].url); acc[linkTag] = ( + {props.text} ); diff --git a/content-src/asrouter/templates/SubmitFormSnippet/SubmitFormSnippet.jsx b/content-src/asrouter/templates/SubmitFormSnippet/SubmitFormSnippet.jsx index 61575d56c..727aa39a6 100644 --- a/content-src/asrouter/templates/SubmitFormSnippet/SubmitFormSnippet.jsx +++ b/content-src/asrouter/templates/SubmitFormSnippet/SubmitFormSnippet.jsx @@ -89,6 +89,7 @@ export class SubmitFormSnippet extends React.PureComponent { localization_id="disclaimer_html" links={content.links} doNotAutoBlock={true} + openNewWindow={true} sendClick={this.props.sendClick} />

); } @@ -105,6 +106,7 @@ export class SubmitFormSnippet extends React.PureComponent { localization_id="privacy_html" links={content.links} doNotAutoBlock={true} + openNewWindow={true} sendClick={this.props.sendClick} />

diff --git a/lib/ASRouter.jsm b/lib/ASRouter.jsm index 059faf048..6e530345e 100644 --- a/lib/ASRouter.jsm +++ b/lib/ASRouter.jsm @@ -928,7 +928,7 @@ class _ASRouter { target.browser.ownerGlobal.OpenBrowserWindow({private: true}); break; case ra.OPEN_URL: - target.browser.ownerGlobal.openLinkIn(action.data.args, "tabshifted", { + target.browser.ownerGlobal.openLinkIn(action.data.args, action.data.where || "current", { private: false, triggeringPrincipal: Services.scriptSecurityManager.createNullPrincipal({}), }); @@ -948,7 +948,7 @@ class _ASRouter { case ra.SHOW_FIREFOX_ACCOUNTS: const url = await FxAccounts.config.promiseSignUpURI("snippets"); // We want to replace the current tab. - target.browser.ownerGlobal.openLinkIn(url, "tabshifted", { + target.browser.ownerGlobal.openLinkIn(url, "current", { private: false, triggeringPrincipal: Services.scriptSecurityManager.createNullPrincipal({}), }); diff --git a/lib/OnboardingMessageProvider.jsm b/lib/OnboardingMessageProvider.jsm index 68df56d40..f118b30f3 100644 --- a/lib/OnboardingMessageProvider.jsm +++ b/lib/OnboardingMessageProvider.jsm @@ -38,7 +38,7 @@ const ONBOARDING_MESSAGES = async () => ([ button_label: {string_id: "onboarding-button-label-try-now"}, button_action: { type: "OPEN_URL", - data: {args: "https://screenshots.firefox.com/#tour"}, + data: {args: "https://screenshots.firefox.com/#tour", where: "tabshifted"}, }, }, trigger: {id: "firstRun"}, @@ -73,7 +73,7 @@ const ONBOARDING_MESSAGES = async () => ([ button_label: {string_id: "onboarding-button-label-try-now"}, button_action: { type: "OPEN_URL", - data: {args: "https://addons.mozilla.org/en-US/firefox/addon/ghostery/"}, + data: {args: "https://addons.mozilla.org/en-US/firefox/addon/ghostery/", where: "tabshifted"}, }, }, targeting: "providerCohorts.onboarding == 'ghostery'", @@ -91,7 +91,7 @@ const ONBOARDING_MESSAGES = async () => ([ button_label: {string_id: "onboarding-button-label-get-started"}, button_action: { type: "OPEN_URL", - data: {args: await FxAccountsConfig.promiseEmailFirstURI("onboarding")}, + data: {args: await FxAccountsConfig.promiseEmailFirstURI("onboarding"), where: "tabshifted"}, }, }, targeting: "attributionData.campaign == 'non-fx-button' && attributionData.source == 'addons.mozilla.org'", diff --git a/test/unit/asrouter/ASRouter.test.js b/test/unit/asrouter/ASRouter.test.js index c134a1c16..47b9b428f 100644 --- a/test/unit/asrouter/ASRouter.test.js +++ b/test/unit/asrouter/ASRouter.test.js @@ -840,7 +840,7 @@ describe("ASRouter", () => { }); it("should call openLinkIn with the correct params on OPEN_URL", async () => { let [testMessage] = Router.state.messages; - testMessage.button_action = {type: "OPEN_URL", data: {args: "some/url.com"}}; + testMessage.button_action = {type: "OPEN_URL", data: {args: "some/url.com", where: "tabshifted"}}; const msg = fakeExecuteUserAction(testMessage.button_action); await Router.onMessage(msg); @@ -873,7 +873,7 @@ describe("ASRouter", () => { assert.calledOnce(msg.target.browser.ownerGlobal.openLinkIn); assert.calledWith(msg.target.browser.ownerGlobal.openLinkIn, - "some/url", "tabshifted", {"private": false, "triggeringPrincipal": undefined}); + "some/url", "current", {"private": false, "triggeringPrincipal": undefined}); }); }); diff --git a/test/unit/asrouter/RichText.test.jsx b/test/unit/asrouter/RichText.test.jsx index 6e27fd043..9b1420217 100644 --- a/test/unit/asrouter/RichText.test.jsx +++ b/test/unit/asrouter/RichText.test.jsx @@ -43,6 +43,14 @@ describe("convertLinks", () => { assert.propertyVal(result.cta.props, "data-args", cta.args); assert.propertyVal(result.cta.props, "onClick", stub); }); + it("should follow openNewWindow prop", () => { + const cta = {url: "https://foo.com"}; + const newWindow = convertLinks({cta}, sandbox.stub(), false, true); + const sameWindow = convertLinks({cta}, sandbox.stub(), false); + + assert.propertyVal(newWindow.cta.props, "target", "_blank"); + assert.propertyVal(sameWindow.cta.props, "target", ""); + }); it("should allow for custom elements & styles", () => { const wrapper = mount(}} text="foo" localization_id="text" />);