43 lines
932 B
JavaScript
43 lines
932 B
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 CollapseButton = createClass({
|
|
|
|
displayName: "CollapseButton",
|
|
|
|
propTypes: {
|
|
open: PropTypes.bool.isRequired,
|
|
title: PropTypes.string.isRequired,
|
|
},
|
|
|
|
render: function () {
|
|
const { title, open, onClick } = this.props;
|
|
|
|
let classes = ["theme-twisty"];
|
|
|
|
if (open) {
|
|
classes.push("open");
|
|
}
|
|
|
|
return dom.a({
|
|
className: classes.join(" "),
|
|
onClick: onClick,
|
|
title
|
|
});
|
|
}
|
|
});
|
|
|
|
module.exports.CollapseButton = CollapseButton;
|