summaryrefslogtreecommitdiffstats
path: root/devtools/client/shared/components/Sidebar.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/shared/components/Sidebar.js')
-rw-r--r--devtools/client/shared/components/Sidebar.js98
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..d020e48dda
--- /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("devtools/client/shared/vendor/react");
+const PropTypes = require("devtools/client/shared/vendor/react-prop-types");
+
+const SidebarToggle = createFactory(
+ require("devtools/client/shared/components/SidebarToggle")
+);
+const Tabs = createFactory(
+ require("devtools/client/shared/components/tabs/Tabs").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;