From 13d220087fa80573faf7f9d165c3f429a55f773a Mon Sep 17 00:00:00 2001 From: SleepWalker Date: Wed, 3 Feb 2016 07:36:00 +0200 Subject: [PATCH] =?UTF-8?q?=D0=95=D1=89=D0=B5=20=D0=BE=D0=B4=D0=BD=D0=B0?= =?UTF-8?q?=20=D0=B2=D0=B5=D1=80=D1=81=D0=B8=D1=8F=20=D0=B0=D0=BD=D0=B8?= =?UTF-8?q?=D0=BC=D0=B0=D1=86=D0=B8=D0=B8=20=D0=B8=20=D0=B1=D0=BE=D0=BB?= =?UTF-8?q?=D0=B5=D0=B5=20=D0=BF=D1=80=D0=B0=D0=B2=D0=B8=D0=BB=D1=8C=D0=BD?= =?UTF-8?q?=D1=8B=D0=B9=20=D0=B0=D0=BB=D0=B3=D0=BE=D1=80=D0=B8=D1=82=D0=BC?= =?UTF-8?q?=20=D0=BF=D0=B5=D1=80=D0=B5=D0=BA=D0=BB=D1=8E=D1=87=D0=B5=D0=BD?= =?UTF-8?q?=D0=B8=D1=8F=20=D0=B2=D0=B5=D1=80=D1=82=D0=B8=D0=BA=D0=B0=D0=BB?= =?UTF-8?q?=D1=8C=D0=BD=D0=BE=D0=B9/=D0=B3=D0=BE=D1=80=D0=B8=D0=B7=D0=BE?= =?UTF-8?q?=D0=BD=D1=82=D0=B0=D0=BB=D1=8C=D0=BD=D0=BE=D0=B9=20=D0=B0=D0=BD?= =?UTF-8?q?=D0=B8=D0=BC=D0=B0=D1=86=D0=B8=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/components/auth/PanelTransition.jsx | 57 +++++++++++++++---------- 1 file changed, 34 insertions(+), 23 deletions(-) diff --git a/src/components/auth/PanelTransition.jsx b/src/components/auth/PanelTransition.jsx index 4262f5b..98a8dd5 100644 --- a/src/components/auth/PanelTransition.jsx +++ b/src/components/auth/PanelTransition.jsx @@ -20,16 +20,25 @@ export default class PanelTransition extends Component { height: {} }; - componentWillReceiveProps() { + componentWillReceiveProps(nextProps) { + var previousRoute = this.props.location; + + var next = nextProps.path; + var prev = previousRoute && previousRoute.pathname; + + var direction = this.getDirection(next, next, prev); + var forceHeight = direction === 'Y' ? 1 : 0; + this.setState({ - forceHeight: window.forceHeight, + forceHeight: forceHeight, previousRoute: this.props.location }); - setTimeout(() => { - this.setState({forceHeight: 0}); - window.forceHeight = 0; - }, 100); + if (forceHeight) { + setTimeout(() => { + this.setState({forceHeight: 0}); + }, 100); + } } render() { @@ -46,11 +55,11 @@ export default class PanelTransition extends Component { Footer, Links, hasBackButton: previousRoute && previousRoute.pathname === Title.type.goBack, - transformSpring: spring(0), - opacitySpring: spring(1) + transformSpring: spring(0, transformSpringConfig), + opacitySpring: spring(1, opacitySpringConfig) }, common: { - heightSpring: spring(this.state.forceHeight || height[path] || 0, heightSpringConfig) + heightSpring: spring(this.state.forceHeight || height[path] || 0, transformSpringConfig) } }} willEnter={this.willEnter} @@ -189,33 +198,21 @@ export default class PanelTransition extends Component { getBody(key, props) { var {transformSpring, opacitySpring, Body} = props; - var {previousRoute} = this.state; var next = this.props.path; var prev = previousRoute && previousRoute.pathname; - var not = (path) => prev !== path && next !== path; - - var map = { - '/login': not('/password') ? 'Y' : 'X', - '/password': not('/login') ? 'Y' : 'X', - '/register': not('/activation') ? 'Y' : 'X', - '/activation': not('/register') ? 'Y' : 'X', - '/oauth/permissions': 'Y' - }; - - var direction = map[key]; + var direction = this.getDirection(key, next, prev); var verticalOrigin = 'top'; - if (direction === 'Y') { + if (direction === 'Y') { // TODO: do not activate animation when nothing was unmounted transformSpring = Math.abs(transformSpring); if (prev === key) { transformSpring *= -1; } verticalOrigin = 'bottom'; - window.forceHeight = 1; } var style = { @@ -235,6 +232,20 @@ export default class PanelTransition extends Component { ); } + getDirection(key, next, prev) { + var not = (path) => prev !== path && next !== path; + + var map = { + '/login': not('/password') ? 'Y' : 'X', + '/password': not('/login') ? 'Y' : 'X', + '/register': not('/activation') ? 'Y' : 'X', + '/activation': not('/register') ? 'Y' : 'X', + '/oauth/permissions': 'Y' + }; + + return map[key]; + } + getFooter(key, props) { var {opacitySpring, Footer} = props;