Reputation: 37
I'm setting up a React app to utilize React Router. The URL changes when I click the Volunteers header on the left, but the component does not render. How should I set this up?
I've tried to put the Routes in the SidePanel component, but I don't want the components to be rendered by React Router to be children of SidePanel, but siblings.
My App Component:
// system imports
import React from "react";
import { BrowserRouter, Route} from "react-router-dom";
// custom components
import SidePanel from "./SidePanel.js";
import VolunteerCombo from "./VolunteerCombo.js";
import RegistrantsCombo from "./RegistrantsCombo.js";
import Assignments from "./Assignments.js";
import ActionLog from "./ActionLog.js";
// css files
import "../css/App.css";
import "../css/ActivePanel.css";
import "../css/MenuPanel.css";
export class App extends React.Component {
constructor(props) {
super(props);
}
render() {
return (
<div className="main_container">
<SidePanel/>
<BrowserRouter>
<Route path="/volunteers" component={VolunteerCombo}></Route>
<Route path="/registrants" component={RegistrantsCombo}></Route>
<Route path="/assignments" component={Assignments}></Route>
<Route path="/action_log" component={ActionLog}></Route>
</BrowserRouter>
</div>
);
}
}
And my SidePanel Component:
// system imports
import React from "react";
import { BrowserRouter, Route, Link } from "react-router-dom";
// custom components
// css files
import "../css/SidePanel.css";
class SidePanel extends React.Component {
constructor(props) {
super(props);
this.state = {
title: ""
};
}
render() {
return (
<div className="side_panel">
<BrowserRouter>
<h3 style={{paddingTop: "3%"}}>Chase Grainger</h3>
<p className="ui button">Log Out</p>
<div className="ui divider"></div>
<Link to="/volunteers">
<h4 className="side_button">Volunteers</h4>
</Link>
<h4 className="side_button">Registrants</h4>
<h4 className="side_button">Assignments Mode</h4>
<div className="ui divider"></div>
<h4 className="side_button">Action Log</h4>
</BrowserRouter>
</div>
);
}
}
export default SidePanel;
I expected my VolunteerCombo component to show up when I clicked Volunteers on the left side, but the component did not render although the URL changed.
Upvotes: 0
Views: 65
Reputation: 481
First of all, you need to have one BrowserRouter. SidePanel also needs to under BrowserRouter.
So overall, you need to have one more component.
<BrowserRouter>
<Route path="/" component={Layout} />
</BrowserRouter>
in Layout.js
<div>
<SidePanel />
<Switch>
...your routes
</Switch>
</div>
And use withRouter HOC for SidePanel.
Upvotes: 1