initial version of autocomplete

This commit is contained in:
Aviral Dasgupta 2016-06-01 16:54:21 +05:30
parent a145ab7e28
commit b979a16199
7 changed files with 164 additions and 1 deletions

View file

@ -0,0 +1,67 @@
import React from 'react';
import {getCompletions} from '../../../autocomplete/Autocompleter';
export default class Autocomplete extends React.Component {
constructor(props) {
super(props);
this.state = {
completions: []
};
}
componentWillReceiveProps(props, state) {
getCompletions(props.query)[0].then(completions => {
console.log(completions);
this.setState({
completions
});
});
}
render() {
const pinElement = document.querySelector(this.props.pinSelector);
if(!pinElement) return null;
const position = pinElement.getBoundingClientRect();
const style = {
position: 'fixed',
border: '1px solid gray',
background: 'white',
borderRadius: '4px'
};
this.props.pinTo.forEach(direction => {
console.log(`${direction} = ${position[direction]}`);
style[direction] = position[direction];
});
const renderedCompletions = this.state.completions.map((completion, i) => {
return (
<div key={i} class="mx_Autocomplete_Completion">
<strong>{completion.title}</strong>
<em>{completion.subtitle}</em>
<span style={{color: 'gray', float: 'right'}}>{completion.description}</span>
</div>
);
});
return (
<div className="mx_Autocomplete" style={style}>
{renderedCompletions}
</div>
);
}
}
Autocomplete.propTypes = {
// the query string for which to show autocomplete suggestions
query: React.PropTypes.string.isRequired,
// CSS selector indicating which element to pin the autocomplete to
pinSelector: React.PropTypes.string.isRequired,
// attributes on which the autocomplete should match the pinElement
pinTo: React.PropTypes.array.isRequired
};

View file

@ -20,6 +20,7 @@ var MatrixClientPeg = require('../../../MatrixClientPeg');
var Modal = require('../../../Modal');
var sdk = require('../../../index');
var dis = require('../../../dispatcher');
import Autocomplete from './Autocomplete';
module.exports = React.createClass({
@ -45,6 +46,12 @@ module.exports = React.createClass({
opacity: React.PropTypes.number,
},
getInitialState: function () {
return {
autocompleteQuery: ''
};
},
onUploadClick: function(ev) {
this.refs.uploadInput.click();
},
@ -117,6 +124,12 @@ module.exports = React.createClass({
});
},
onInputContentChanged(content: String) {
this.setState({
autocompleteQuery: content
})
},
render: function() {
var me = this.props.room.getMember(MatrixClientPeg.get().credentials.userId);
var uploadInputStyle = {display: 'none'};
@ -170,7 +183,8 @@ module.exports = React.createClass({
controls.push(
<MessageComposerInput key="controls_input" tabComplete={this.props.tabComplete}
onResize={this.props.onResize} room={this.props.room} />,
onResize={this.props.onResize} room={this.props.room}
onContentChanged={(content) => this.onInputContentChanged(content) } />,
uploadButton,
hangupButton,
callButton,
@ -191,6 +205,8 @@ module.exports = React.createClass({
{controls}
</div>
</div>
<Autocomplete query={this.state.autocompleteQuery} pinSelector=".mx_RoomView_statusArea" pinTo={['top', 'left', 'width']} />
</div>
);
}

View file

@ -73,6 +73,8 @@ module.exports = React.createClass({
// js-sdk Room object
room: React.PropTypes.object.isRequired,
onContentChanged: React.PropTypes.func
},
componentWillMount: function() {
@ -276,6 +278,8 @@ module.exports = React.createClass({
{
this.resizeInput();
}
this.props.onContentChanged && this.props.onContentChanged(this.refs.textarea.value);
},
onEnter: function(ev) {