forked from mirrors/gecko-dev
Differential Revision: https://phabricator.services.mozilla.com/D42300 --HG-- extra : moz-landing-system : lando
31 lines
1 KiB
JavaScript
31 lines
1 KiB
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 dom = require("devtools/client/shared/vendor/react-dom-factories");
|
|
|
|
const { l10n } = require("devtools/client/webconsole/utils/messages");
|
|
const messageToggleDetails = l10n.getStr("messageToggleDetails");
|
|
|
|
function CollapseButton(props) {
|
|
const { open, onClick, title = messageToggleDetails } = props;
|
|
|
|
return dom.button({
|
|
"aria-expanded": open ? "true" : "false",
|
|
"aria-label": title,
|
|
className: "arrow collapse-button",
|
|
onClick,
|
|
onMouseDown: e => {
|
|
// prevent focus from moving to the disclosure if clicked,
|
|
// which is annoying if on the input
|
|
e.preventDefault();
|
|
// Clearing the text selection to allow the message to collpase.
|
|
e.target.ownerDocument.defaultView.getSelection().removeAllRanges();
|
|
},
|
|
title: title,
|
|
});
|
|
}
|
|
|
|
module.exports = CollapseButton;
|