diff options
Diffstat (limited to 'devtools/client/shared/components/Sidebar.js')
-rw-r--r-- | devtools/client/shared/components/Sidebar.js | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/devtools/client/shared/components/Sidebar.js b/devtools/client/shared/components/Sidebar.js new file mode 100644 index 0000000000..bf9ef9938d --- /dev/null +++ b/devtools/client/shared/components/Sidebar.js @@ -0,0 +1,98 @@ +/* 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 { + createFactory, + PureComponent, +} = require("resource://devtools/client/shared/vendor/react.js"); +const PropTypes = require("resource://devtools/client/shared/vendor/react-prop-types.js"); + +const SidebarToggle = createFactory( + require("resource://devtools/client/shared/components/SidebarToggle.js") +); +const Tabs = createFactory( + require("resource://devtools/client/shared/components/tabs/Tabs.js").Tabs +); + +class Sidebar extends PureComponent { + static get propTypes() { + return { + children: PropTypes.oneOfType([PropTypes.array, PropTypes.element]) + .isRequired, + onAfterChange: PropTypes.func, + onAllTabsMenuClick: PropTypes.func, + renderOnlySelected: PropTypes.bool, + showAllTabsMenu: PropTypes.bool, + allTabsMenuButtonTooltip: PropTypes.string, + sidebarToggleButton: PropTypes.shape({ + collapsed: PropTypes.bool.isRequired, + collapsePaneTitle: PropTypes.string.isRequired, + expandPaneTitle: PropTypes.string.isRequired, + onClick: PropTypes.func.isRequired, + alignRight: PropTypes.bool, + canVerticalSplit: PropTypes.bool, + }), + activeTab: PropTypes.number, + }; + } + + constructor(props) { + super(props); + this.renderSidebarToggle = this.renderSidebarToggle.bind(this); + } + + renderSidebarToggle() { + if (!this.props.sidebarToggleButton) { + return null; + } + + const { + collapsed, + collapsePaneTitle, + expandPaneTitle, + onClick, + alignRight, + canVerticalSplit, + } = this.props.sidebarToggleButton; + + return SidebarToggle({ + collapsed, + collapsePaneTitle, + expandPaneTitle, + onClick, + alignRight, + canVerticalSplit, + }); + } + + render() { + const { renderSidebarToggle } = this; + const { + children, + onAfterChange, + onAllTabsMenuClick, + renderOnlySelected, + showAllTabsMenu, + allTabsMenuButtonTooltip, + activeTab, + } = this.props; + + return Tabs( + { + onAfterChange, + onAllTabsMenuClick, + renderOnlySelected, + renderSidebarToggle, + showAllTabsMenu, + allTabsMenuButtonTooltip, + activeTab, + }, + children + ); + } +} + +module.exports = Sidebar; |