fune/devtools/client/shared/components/MdnLink.js
J. Ryan Stinnett fa78307d48 Bug 1466534 - Centralize DevTools link handling. r=jdescottes
This adds a `openContentLink` helper meant for any link controlled by web
content.  If there is an associated toolbox open, the toolbox's tab is used to
supply a triggering principal for the link.

MozReview-Commit-ID: 45l5yAPGpZr

--HG--
extra : rebase_source : 61a1d471d6792d148932488e854e16de60dea44b
2018-06-11 23:42:19 -07:00

35 lines
885 B
JavaScript

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
const PropTypes = require("devtools/client/shared/vendor/react-prop-types");
const dom = require("devtools/client/shared/vendor/react-dom-factories");
const { a } = dom;
loader.lazyRequireGetter(this, "openDocLink", "devtools/client/shared/link", true);
function MDNLink({ url, title }) {
return (
a({
className: "devtools-button learn-more-link",
title,
onClick: (e) => onLearnMoreClick(e, url),
})
);
}
MDNLink.displayName = "MDNLink";
MDNLink.propTypes = {
url: PropTypes.string.isRequired,
};
function onLearnMoreClick(e, url) {
e.stopPropagation();
e.preventDefault();
openDocLink(url);
}
module.exports = MDNLink;