2016-01-06 15:38:36 +08:00
|
|
|
|
const React = require('react');
|
|
|
|
|
const ReactDOM = require('react-dom');
|
2016-01-07 16:52:27 +08:00
|
|
|
|
import { QueueAnim, Icon, Button } from '../index';
|
|
|
|
|
import ScrollOverPack from 'rc-scroll-anim/lib/ScrollOverPack';
|
2016-01-19 14:18:57 +08:00
|
|
|
|
import ScrollLink from 'rc-scroll-anim/lib/ScrollLink';
|
|
|
|
|
import ScrollElement from 'rc-scroll-anim/lib/ScrollElement';
|
2016-01-20 15:51:44 +08:00
|
|
|
|
import scrollScreen from 'rc-scroll-anim/lib/ScrollScreen';
|
2016-01-20 19:15:49 +08:00
|
|
|
|
import ScrollEvent from 'rc-scroll-anim/lib/EventDispatcher';
|
|
|
|
|
import mapped from 'rc-scroll-anim/lib/Mapped';
|
2016-01-07 16:52:27 +08:00
|
|
|
|
import TweenOne from 'rc-tween-one';
|
2016-01-07 16:56:45 +08:00
|
|
|
|
|
2016-01-20 19:43:02 +08:00
|
|
|
|
module.exports = function() {
|
|
|
|
|
InstantClickChangeFns.push(function() {
|
2016-01-14 02:37:52 +08:00
|
|
|
|
if (!document.getElementById('banner')) {
|
2016-01-20 19:15:49 +08:00
|
|
|
|
// componentWillUnmount 不会触发, 手动删掉事件;
|
|
|
|
|
ScrollEvent._listeners = {};
|
|
|
|
|
mapped.unMount();
|
2016-01-14 02:37:52 +08:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
// 导航处理
|
|
|
|
|
function scrollNavEvent() {
|
|
|
|
|
const scrollTop = document.body.scrollTop || document.documentElement.scrollTop;
|
|
|
|
|
const clientHeight = document.documentElement.clientHeight;
|
|
|
|
|
if (scrollTop >= clientHeight) {
|
|
|
|
|
header.className = header.className.indexOf('home-nav-bottom') >= 0 ? header.className : header.className + ' home-nav-bottom';
|
|
|
|
|
} else {
|
|
|
|
|
header.className = header.className.replace(/home-nav-bottom/ig, '');
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
$(window).off('scroll.scrollNavEvent');
|
|
|
|
|
$(window).on('scroll.scrollNavEvent', scrollNavEvent);
|
2016-01-21 15:03:42 +08:00
|
|
|
|
|
2016-01-19 14:18:57 +08:00
|
|
|
|
// list point
|
2016-01-21 15:03:42 +08:00
|
|
|
|
class Link extends React.Component {
|
|
|
|
|
componentDidMount() {
|
|
|
|
|
// 整屏滚动;
|
|
|
|
|
scrollScreen.init({docHeight: 4746});
|
|
|
|
|
}
|
2016-01-19 14:18:57 +08:00
|
|
|
|
|
2016-01-21 15:03:42 +08:00
|
|
|
|
render() {
|
|
|
|
|
return (
|
|
|
|
|
<div>
|
|
|
|
|
<ScrollLink className="list-point" location="banner"/>
|
|
|
|
|
<ScrollLink className="list-point" location="page1"/>
|
|
|
|
|
<ScrollLink className="list-point" location="page2"/>
|
|
|
|
|
<ScrollLink className="list-point" location="page3"/>
|
|
|
|
|
<ScrollLink className="list-point" location="page4"/>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
ReactDOM.render(<Link />, document.getElementById('list'));
|
2016-01-19 14:18:57 +08:00
|
|
|
|
|
2016-01-21 15:03:42 +08:00
|
|
|
|
// banner
|
2016-01-14 02:37:52 +08:00
|
|
|
|
class Banner extends React.Component {
|
|
|
|
|
constructor() {
|
|
|
|
|
super(...arguments);
|
|
|
|
|
}
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
typeFunc(a) {
|
|
|
|
|
if (a.key === 'line') {
|
|
|
|
|
return 'right';
|
|
|
|
|
} else if (a.key === 'button') {
|
|
|
|
|
return 'bottom';
|
|
|
|
|
}
|
|
|
|
|
return 'left';
|
|
|
|
|
}
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
render() {
|
|
|
|
|
return (
|
2016-01-19 14:18:57 +08:00
|
|
|
|
<ScrollElement scrollName="banner" style={{height: '100%'}}>
|
2016-01-14 02:37:52 +08:00
|
|
|
|
<QueueAnim className="banner-text-wrapper" type={this.typeFunc} delay={300}>
|
|
|
|
|
<h2 key="h2">ANT <p>DESIGN</p></h2>
|
|
|
|
|
<p key="content">一个 UI 设计语言</p>
|
|
|
|
|
<span className="line" key="line"/>
|
|
|
|
|
<a key="button" href="/docs/spec/introduce"><Icon type="smile-circle"/>开始探索</a>
|
|
|
|
|
</QueueAnim>
|
|
|
|
|
<TweenOne className='down' vars={[{opacity: 1},{y: 10, duration: 800, yoyo: true, repeat: -1}]}>
|
|
|
|
|
<Icon type="down"/>
|
|
|
|
|
</TweenOne>
|
2016-01-19 14:18:57 +08:00
|
|
|
|
</ScrollElement>
|
2016-01-14 02:37:52 +08:00
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
ReactDOM.render(<Banner />, document.getElementById('banner'));
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
// page1
|
2016-01-21 15:03:42 +08:00
|
|
|
|
class Page1 extends React.Component {
|
|
|
|
|
render() {
|
|
|
|
|
return (
|
|
|
|
|
<ScrollOverPack scrollName="page1" className="content-wrapper" playScale={1} replay>
|
|
|
|
|
<TweenOne key="image" className="image1 image-wrapper" vars={{x: 0, opacity: 1, duration: 550}}
|
2016-01-26 20:08:45 +08:00
|
|
|
|
style={{transform: 'translateX(-100px)', opacity: 0}} hideProps={{type: 'reverse'}}/>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
<QueueAnim className="text-wrapper" delay={300} key="text" duration={550} leaveReverse
|
2016-01-26 20:08:45 +08:00
|
|
|
|
hideProps={{child: null}}>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
<h2 key="h2">最佳实践</h2>
|
|
|
|
|
<p key="p" style={{maxWidth: 310}}>近一年的中后台设计实践,积累了大量的优秀案例。</p>
|
|
|
|
|
<div key="button"><Button type="primary" size="large"
|
|
|
|
|
onClick={()=>{window.location.href='/docs/practice/cases'}}>了解更多<Icon
|
|
|
|
|
type="right"/></Button></div>
|
|
|
|
|
</QueueAnim>
|
|
|
|
|
</ScrollOverPack>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
ReactDOM.render(<Page1 />, document.getElementById('page1'));
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
//page2
|
2016-01-21 15:03:42 +08:00
|
|
|
|
class Page2 extends React.Component {
|
|
|
|
|
render() {
|
|
|
|
|
return (
|
|
|
|
|
<ScrollOverPack scrollName="page2" className="content-wrapper" playScale={1} replay>
|
|
|
|
|
<QueueAnim className="text-wrapper left-text" delay={300} key="text" duration={550} type='bottom'
|
|
|
|
|
leaveReverse
|
2016-01-26 20:08:45 +08:00
|
|
|
|
hideProps={{child: null}}>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
<h2 key="h2">设计模式</h2>
|
|
|
|
|
<p key="p" style={{maxWidth: 260}}>总结中后台设计中反复出现的问题,并提供相应的解决方案。</p>
|
|
|
|
|
<div key="button"><Button type="primary" size="large"
|
|
|
|
|
onClick={()=>{window.location.href='/docs/pattern/navigation'}}>了解更多<Icon
|
|
|
|
|
type="right"/></Button>
|
|
|
|
|
</div>
|
|
|
|
|
</QueueAnim>
|
|
|
|
|
<TweenOne key="image" className="image2 image-wrapper" vars={{x: 0, opacity: 1, delay: 300, duration: 550}}
|
2016-01-26 20:08:45 +08:00
|
|
|
|
style={{transform: 'translateX(100px)', opacity: 0}} hideProps={{type: 'reverse'}}/>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
</ScrollOverPack>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
ReactDOM.render(<Page2 />, document.getElementById('page2'));
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
// page3
|
2016-01-21 15:03:42 +08:00
|
|
|
|
class Page3 extends React.Component {
|
|
|
|
|
render() {
|
|
|
|
|
return (
|
|
|
|
|
<ScrollOverPack scrollName="page3" className="content-wrapper" playScale={1} replay>
|
|
|
|
|
<TweenOne key="image" className="image3 image-wrapper" vars={{x: 0, opacity: 1, duration: 550}}
|
2016-01-26 20:08:45 +08:00
|
|
|
|
style={{transform: 'translateX(-100px)', opacity: 0}} hideProps={{type: 'reverse'}}/>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
<QueueAnim className="text-wrapper" delay={300} key="text" duration={550} leaveReverse style={{top: '40%'}}
|
2016-01-26 20:08:45 +08:00
|
|
|
|
hideProps={{child: null}}>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
<h2 key="h2">丰富的基础组件</h2>
|
|
|
|
|
<p key="p" style={{maxWidth: 280}}>丰富、灵活、实用的基础组件,为业务产品提供强有力的设计支持。</p>
|
|
|
|
|
<div key="button"><Button type="primary" size="large"
|
|
|
|
|
onClick={()=>{window.location.href='/docs/react/introduce'}}>了解更多<Icon
|
|
|
|
|
type="right"/></Button></div>
|
|
|
|
|
</QueueAnim>
|
|
|
|
|
</ScrollOverPack>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
ReactDOM.render(<Page3/>, document.getElementById('page3'));
|
2016-01-07 16:52:27 +08:00
|
|
|
|
|
2016-01-14 02:37:52 +08:00
|
|
|
|
// page4
|
2016-01-21 15:03:42 +08:00
|
|
|
|
class Page4 extends React.Component {
|
|
|
|
|
render(){
|
|
|
|
|
return (
|
|
|
|
|
<ScrollOverPack scrollName="page4" className="content-wrapper" playScale={1}>
|
|
|
|
|
<QueueAnim className="text-wrapper-bottom" delay={300} key="text" duration={550} leaveReverse type="bottom"
|
2016-01-26 20:08:45 +08:00
|
|
|
|
hideProps={{child: null}}>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
<h2 key="h2">微小·确定·幸福</h2>
|
|
|
|
|
<p key="p">这是一套致力于提升『用户』和『设计者』使用体验的中后台设计语言。</p>
|
|
|
|
|
</QueueAnim>
|
|
|
|
|
<TweenOne key="image" className="image4 bottom-wrapper" vars={{y: 0, opacity: 1, duration: 550, delay: 550}}
|
2016-01-26 20:08:45 +08:00
|
|
|
|
style={{transform: 'translateY(50px)', opacity: 0}} hideProps={{type: 'reverse'}}/>
|
2016-01-21 15:03:42 +08:00
|
|
|
|
</ScrollOverPack>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
ReactDOM.render(<Page4 />, document.getElementById('page4'));
|
2016-01-14 02:37:52 +08:00
|
|
|
|
});
|
2016-01-21 15:03:42 +08:00
|
|
|
|
};
|