52 lines
1.1 KiB
JavaScript
52 lines
1.1 KiB
JavaScript
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
|
|
/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
|
|
/* 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";
|
|
|
|
// React & Redux
|
|
const {
|
|
createClass,
|
|
DOM: dom,
|
|
PropTypes,
|
|
} = require("devtools/client/shared/vendor/react");
|
|
|
|
const { l10n } = require("devtools/client/webconsole/new-console-output/utils/messages");
|
|
|
|
const CollapseButton = createClass({
|
|
|
|
displayName: "CollapseButton",
|
|
|
|
propTypes: {
|
|
onClick: PropTypes.func.isRequired,
|
|
open: PropTypes.bool.isRequired,
|
|
title: PropTypes.string,
|
|
},
|
|
|
|
getDefaultProps: function () {
|
|
return {
|
|
title: l10n.getStr("messageToggleDetails")
|
|
};
|
|
},
|
|
|
|
render: function () {
|
|
const { open, onClick, title } = this.props;
|
|
|
|
let classes = ["theme-twisty"];
|
|
|
|
if (open) {
|
|
classes.push("open");
|
|
}
|
|
|
|
return dom.a({
|
|
className: classes.join(" "),
|
|
onClick,
|
|
title: title,
|
|
});
|
|
}
|
|
});
|
|
|
|
module.exports = CollapseButton;
|