route example

This commit is contained in:
insanity 2017-07-24 17:39:51 +09:00
parent fa7cb087e8
commit 1a3e1c7fd3
3 changed files with 42 additions and 5 deletions

View File

@ -3,7 +3,7 @@ import { Redirect, RouteComponentProps, RouteProps, Route, Switch } from 'react-
import { Container, Menu, Sidebar, Segment, Icon, Breadcrumb, Grid, Dropdown } from 'semantic-ui-react'; import { Container, Menu, Sidebar, Segment, Icon, Breadcrumb, Grid, Dropdown } from 'semantic-ui-react';
import { Header } from './Header'; import { Header } from './Header';
import { Footer } from './Footer'; import { Footer } from './Footer';
import { TitleBar } from './TitleBar'; import TitleBarContainer from './TitleBarContainer';
import LeftMenu from './LeftMenu'; import LeftMenu from './LeftMenu';
import ProbeDetail from '../../views/monitoring/probe/Detail'; import ProbeDetail from '../../views/monitoring/probe/Detail';
@ -40,7 +40,7 @@ export class ProbeDetailLayout extends React.Component<Props, State> {
<LeftMenu /> <LeftMenu />
<Segment vertical style={{ margin: '0 0 0 210px', padding: '0' }}> <Segment vertical style={{ margin: '0 0 0 210px', padding: '0' }}>
<Header /> <Header />
<TitleBar title='Probe Details' sub={sub} /> <TitleBarContainer sub={sub}/>
<Switch> <Switch>
<Route exact={true} path={`${this.props.match.url}/:id`} component={ProbeDetail} /> <Route exact={true} path={`${this.props.match.url}/:id`} component={ProbeDetail} />
<Route exact={true} path={`${this.props.match.url}/:id/history`} component={ProbeHistory} /> <Route exact={true} path={`${this.props.match.url}/:id/history`} component={ProbeHistory} />

View File

@ -1,6 +1,19 @@
import * as React from 'react'; import * as React from 'react';
import { Grid, Container, Breadcrumb, Header, Menu, Input, Segment } from 'semantic-ui-react'; import { Grid, Container, Breadcrumb, Header, Menu, Input, Segment } from 'semantic-ui-react';
import { Redirect } from 'react-router-dom';
export interface StateProps {
sub: any;
}
export interface DispatchProps {
onRedirect(path: string): void;
}
export type Props = StateProps & DispatchProps;
export interface State {
}
export class TitleBar extends React.Component<any, any> { export class TitleBar extends React.Component<any, any> {
@ -10,9 +23,9 @@ export class TitleBar extends React.Component<any, any> {
}; };
} }
public handleMenu(menu:any): JSX.Element { public handleMenu(menu:any): any {
console.log(menu.path); console.log(menu.path);
return <Redirect to={menu.path} />; this.props.onRedirect(menu.path);
} }
public renderSubMenus(): JSX.Element { public renderSubMenus(): JSX.Element {

View File

@ -0,0 +1,24 @@
import { connect, Dispatch } from 'react-redux';
import {
TitleBar,
StateProps as StateProps,
DispatchProps as DispatchProps,
} from './TitleBar';
import { push as routerPush } from 'react-router-redux';
export function mapStateToProps(state: any, ownProps: any): StateProps {
return {
sub: ownProps.sub,
};
}
export function mapDispatchToProps(dispatch: Dispatch<any>): DispatchProps {
return {
onRedirect: (path: string) => {
dispatch(routerPush(path));
},
};
}
export default connect(mapStateToProps, mapDispatchToProps)(TitleBar);