mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-29 21:59:41 +08:00
46 lines
1.7 KiB
JavaScript
46 lines
1.7 KiB
JavaScript
import React from 'react';
|
|
import { Link } from 'react-router';
|
|
import { FormattedMessage } from 'react-intl';
|
|
import TweenOne from 'rc-tween-one';
|
|
import ScrollOverPack from 'rc-scroll-anim/lib/ScrollOverPack';
|
|
import { Icon, Button } from 'antd';
|
|
import QueueAnim from 'rc-queue-anim';
|
|
|
|
const clientHeight = document.documentElement.clientHeight;
|
|
function onScrollEvent(e) {
|
|
const header = document.getElementById('header');
|
|
if (e.pageY >= clientHeight) {
|
|
if (header.className.indexOf('home-nav-bottom') < 0) {
|
|
header.className += ' home-nav-bottom';
|
|
}
|
|
} else if (header.className.indexOf('home-nav-bottom') >= 0) {
|
|
header.className = header.className.replace(/home-nav-bottom/ig, '');
|
|
}
|
|
}
|
|
|
|
export default function Page1({ location }) {
|
|
return (
|
|
<ScrollOverPack scrollName="page1" className="content-wrapper page"
|
|
playScale={1} replay scrollEvent={onScrollEvent}
|
|
hideProps={{ image: { reverse: true } }}
|
|
>
|
|
<TweenOne key="image" className="image1 image-wrapper"
|
|
animation={{ x: 0, opacity: 1, duration: 550 }}
|
|
style={{ transform: 'translateX(-100px)', opacity: 0 }}
|
|
/>
|
|
<QueueAnim className="text-wrapper" delay={300} key="text" duration={550} leaveReverse>
|
|
<h2 key="h2"><FormattedMessage id="app.home.best-practice" /></h2>
|
|
<p key="p" style={{ maxWidth: 310 }}><FormattedMessage id="app.home.experience" /></p>
|
|
<div key="button">
|
|
<Link to={{ query: location.query, pathname: '/docs/practice/cases' }}>
|
|
<Button type="primary" size="large">
|
|
<FormattedMessage id="app.home.learn-more" />
|
|
<Icon type="right" />
|
|
</Button>
|
|
</Link>
|
|
</div>
|
|
</QueueAnim>
|
|
</ScrollOverPack>
|
|
);
|
|
}
|