// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved. // See License.txt for license information. import SuggestionStore from 'stores/suggestion_store.jsx'; import UserStore from 'stores/user_store.jsx'; import Client from 'utils/web_client.jsx'; import React from 'react'; class SearchUserSuggestion extends React.Component { render() { const {item, isSelection, onClick} = this.props; let className = 'search-autocomplete__item'; if (isSelection) { className += ' selected'; } return (
{item.username}
); } } SearchUserSuggestion.propTypes = { item: React.PropTypes.object.isRequired, isSelection: React.PropTypes.bool, onClick: React.PropTypes.func }; export default class SearchUserProvider { handlePretextChanged(suggestionId, pretext) { const captured = (/\bfrom:\s*(\S*)$/i).exec(pretext); if (captured) { const usernamePrefix = captured[1]; const users = UserStore.getProfiles(); let filtered = []; for (const id of Object.keys(users)) { const user = users[id]; if (user.username.startsWith(usernamePrefix)) { filtered.push(user); } } filtered = filtered.sort((a, b) => a.username.localeCompare(b.username)); const usernames = filtered.map((user) => user.username); SuggestionStore.setMatchedPretext(suggestionId, usernamePrefix); SuggestionStore.addSuggestions(suggestionId, usernames, filtered, SearchUserSuggestion); } } }