ant-design/scripts/demo.js

50 lines
1.4 KiB
JavaScript
Raw Normal View History

2015-07-07 15:39:21 +08:00
window['css-animation'] = require('css-animation');
2015-07-09 17:47:21 +08:00
window['react-router'] = window.ReactRouter;
2015-07-14 20:16:05 +08:00
var $ = require('jquery');
var React = require('react');
$(function () {
// auto complete for components
var Select = antd.Select;
var Option = Select.Option;
// 获取搜索数据
var searchData = window.ANT_COMPONENTS;
var AutoComplete = React.createClass({
getOptions() {
return searchData.map(function (s) {
return <Option sData={s} key={s.title}>
<strong>{s.title}</strong>
&nbsp;
<span>{s.desc}</span>
</Option>;
});
},
handleSelect(value) {
location.pathname = '/components/' + value.replace(/([a-z])([A-Z])/g, function (m, m1, m2) {
return m1 + '-' + m2;
}).toLowerCase();
},
filterOption(input, option) {
return option.props.sData.title.toLowerCase().indexOf(input.toLowerCase()) !== -1 || option.props.sData.desc.indexOf(input) !== -1;
},
render() {
return <Select style={{width: 200}}
placeholder="Select Components"
onChange={this.handleSelect}
dropdownMenuStyle={{maxHeight: 200, overflow: 'auto'}}
searchPlaceholder="Filter Components"
renderDropdownToBody={true}
showSearch={true}
filterOption={this.filterOption}>{this.getOptions()}</Select>;
}
});
React.render(<AutoComplete/>, document.getElementById('autoComplete'));
});