import React, { Component } from 'react';
import PropTypes from 'prop-types';
import ReactCSSTransitionGroup from 'react-transition-group/CSSTransitionGroup';
import CustomizeGas from '../gas-customization/gas-modal-page-container';
export default class Sidebar extends Component {
static propTypes = {
sidebarOpen: PropTypes.bool,
hideSidebar: PropTypes.func,
sidebarShouldClose: PropTypes.bool,
transitionName: PropTypes.string,
type: PropTypes.string,
sidebarProps: PropTypes.object,
onOverlayClose: PropTypes.func,
};
renderOverlay() {
const { onOverlayClose } = this.props;
return (
{
onOverlayClose?.();
this.props.hideSidebar();
}}
/>
);
}
renderSidebarContent() {
const { type, sidebarProps = {} } = this.props;
const { transaction = {}, onSubmit } = sidebarProps;
switch (type) {
case 'customize-gas':
return (
);
default:
return null;
}
}
componentDidUpdate(prevProps) {
if (!prevProps.sidebarShouldClose && this.props.sidebarShouldClose) {
this.props.hideSidebar();
}
}
render() {
const { transitionName, sidebarOpen, sidebarShouldClose } = this.props;
return (
{sidebarOpen && !sidebarShouldClose
? this.renderSidebarContent()
: null}
{sidebarOpen && !sidebarShouldClose ? this.renderOverlay() : null}
);
}
}