From c44a1a851eae8836b0ec7bc5c238e61dc9b9d8fd Mon Sep 17 00:00:00 2001 From: Mathias Desloges Date: Wed, 25 Oct 2017 22:12:16 +0200 Subject: [PATCH] refactor router implementation + implement navbar --- src/NavigationBar.js | 21 +++++++++++ src/Page.js | 20 ++++++++--- src/PageManager.js | 85 ++++++++++++++++++++++++++++++++++++++++++++ src/Pages.js | 42 ---------------------- src/index.js | 18 +++++++--- 5 files changed, 135 insertions(+), 51 deletions(-) create mode 100644 src/NavigationBar.js create mode 100644 src/PageManager.js delete mode 100644 src/Pages.js diff --git a/src/NavigationBar.js b/src/NavigationBar.js new file mode 100644 index 0000000..4f96ee1 --- /dev/null +++ b/src/NavigationBar.js @@ -0,0 +1,21 @@ +import React from 'react' + +import { Link } from 'react-router-dom'; + +export default ({ pages }) => { + return ( + + ) +} \ No newline at end of file diff --git a/src/Page.js b/src/Page.js index 8c1c5a8..12af1c5 100644 --- a/src/Page.js +++ b/src/Page.js @@ -1,12 +1,24 @@ import React, { Component } from 'react'; +import { Route } from 'react-router-dom'; -class Page extends Component { +export class Page extends Component { render() { const props = this.props return ( -
{props.name}
- ); +
+

{props.name}

+ { props.children } +
+ ) } } -export default Page; +const RoutePage = (props) => { + return ( + ( + + )} /> + ) +} + +export default RoutePage; diff --git a/src/PageManager.js b/src/PageManager.js new file mode 100644 index 0000000..bd627c1 --- /dev/null +++ b/src/PageManager.js @@ -0,0 +1,85 @@ +import React, { Component } from 'react'; + +import { withRouter, Switch } from 'react-router-dom' +import { BrowserRouter as Router } from 'react-router-dom'; + +import { TransitionGroup, CSSTransition } from 'react-transition-group' + +import Page from './Page' +import NavigationBar from './NavigationBar' + +import './App.css'; + +export class PageManager extends Component { + state = { + direction: 0 + } + + componentWillReceiveProps(nextProps) { + const findPage = (ref, elem) => { + return elem.indexOf(ref) === 0; + }; + const pageOrder = React.Children.map(this.props.children, (child) => child.props.path) + + console.log(pageOrder) + + let indexCurrent = pageOrder.findIndex( + findPage.bind(this, this.props.location.pathname) + ); + let indexNext = pageOrder.findIndex( + findPage.bind(this, nextProps.location.pathname) + ); + + // indexCurrent = indexCurrent !== -1 ? indexCurrent : index404; + // indexNext = indexNext !== -1 ? indexNext : index404; + + this.setState({ + direction: indexNext - indexCurrent + }); + } + + render() { + const { children, location } = this.props + const currentKey = location.pathname.split("/")[1] || "/"; + const timeout = { enter: 500, exit: 500 }; + let pages = [] + const routes = React.Children.map(children, child => { + if (child.type === Page) { + pages.push({ name: child.props.name, path: child.props.path }) + return child + } else { + return null + } + }) + const navbars = children.filter(child => { + return child.type === NavigationBar + }) + return ( + = 0 ? "right" : "left")}> + +
+ + { routes } + +
+
+ { React.Children.map(navbars, (navbar) => { + return React.cloneElement(navbar, { pages }) + }) } +
+ ); + } +} + +const PageManagerWithRouter = withRouter(PageManager) + +export default props => ( + + + +); diff --git a/src/Pages.js b/src/Pages.js deleted file mode 100644 index 147dfd7..0000000 --- a/src/Pages.js +++ /dev/null @@ -1,42 +0,0 @@ -import React, { Component } from 'react'; - -import { BrowserRouter as Router, Route } from 'react-router-dom' - -import { TransitionGroup } from 'react-transition-group' - -import './App.css'; - -const transitionStyles = { - entering: { opacity: 0 }, - entered: { opacity: 1 }, -}; - -const firstChild = props => { - const childrenArray = React.Children.toArray(props.children); - return childrenArray[0] || null; -}; - -class Pages extends Component { - render() { - const { children } = this.props - return ( -
{ - React.Children.map(children, (child, i) => { - console.log(child.props.exact, child.props.path) - return ( - ( - - {match && React.cloneElement(child, { ...rest })} - - ) - } /> - ) - }) - }
- ); - } -} - -export default Pages; diff --git a/src/index.js b/src/index.js index 324d48b..3a94e33 100644 --- a/src/index.js +++ b/src/index.js @@ -1,13 +1,21 @@ import React from 'react'; import ReactDOM from 'react-dom'; + import './index.css'; -import Pages from './Pages'; + +import PageManager from './PageManager'; import Page from './Page'; +import NavigationBar from './NavigationBar'; + import registerServiceWorker from './registerServiceWorker'; ReactDOM.render( - - - - , document.getElementById('root')); +
+ + + + + +
+ , document.getElementById('root')); registerServiceWorker();