2015-07-07 15:39:21 +08:00
|
|
|
window['css-animation'] = require('css-animation');
|
2015-08-20 19:52:56 +08:00
|
|
|
window['react-router'] = require('react-router');
|
2015-07-21 16:05:13 +08:00
|
|
|
var antd = require('antd');
|
2015-07-14 20:16:05 +08:00
|
|
|
|
|
|
|
var $ = require('jquery');
|
|
|
|
var React = require('react');
|
|
|
|
|
2015-09-11 14:57:32 +08:00
|
|
|
InstantClickChangeFns.push(function () {
|
|
|
|
// auto complete for components
|
2015-07-14 20:16:05 +08:00
|
|
|
var Select = antd.Select;
|
|
|
|
var Option = Select.Option;
|
|
|
|
// 获取搜索数据
|
2015-09-02 20:50:18 +08:00
|
|
|
var searchData = window.ANT_COMPONENTS.sort(function(a, b){
|
|
|
|
return a.title.localeCompare(b.title);
|
|
|
|
});
|
2015-07-14 20:16:05 +08:00
|
|
|
|
|
|
|
var AutoComplete = React.createClass({
|
|
|
|
getOptions() {
|
|
|
|
return searchData.map(function (s) {
|
2015-07-22 20:57:27 +08:00
|
|
|
return <Option sData={s} key={s.title} text={'跳转到 ' + s.title}>
|
2015-07-14 20:16:05 +08:00
|
|
|
<strong>{s.title}</strong>
|
2015-07-21 16:05:13 +08:00
|
|
|
|
2015-07-30 15:33:45 +08:00
|
|
|
<span className="ant-component-decs">{s.desc}</span>
|
2015-07-14 20:16:05 +08:00
|
|
|
</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() {
|
2015-08-26 22:16:20 +08:00
|
|
|
return <Select combobox style={{width: '100%'}}
|
2015-07-15 20:47:04 +08:00
|
|
|
onSelect={this.handleSelect}
|
2015-07-22 20:57:27 +08:00
|
|
|
optionLabelProp="text"
|
2015-08-22 14:39:05 +08:00
|
|
|
dropdownClassName="autoComplete"
|
2015-07-15 20:47:04 +08:00
|
|
|
searchPlaceholder="搜索组件..."
|
2015-07-14 20:16:05 +08:00
|
|
|
filterOption={this.filterOption}>{this.getOptions()}</Select>;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
React.render(<AutoComplete/>, document.getElementById('autoComplete'));
|
|
|
|
});
|
|
|
|
|
2015-07-21 16:05:13 +08:00
|
|
|
module.exports = antd;
|