diff options
Diffstat (limited to 'webapp/components/suggestion/switch_team_provider.jsx')
-rw-r--r-- | webapp/components/suggestion/switch_team_provider.jsx | 96 |
1 files changed, 0 insertions, 96 deletions
diff --git a/webapp/components/suggestion/switch_team_provider.jsx b/webapp/components/suggestion/switch_team_provider.jsx deleted file mode 100644 index ff2a8f24b..000000000 --- a/webapp/components/suggestion/switch_team_provider.jsx +++ /dev/null @@ -1,96 +0,0 @@ -// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved. -// See License.txt for license information. - -import Suggestion from './suggestion.jsx'; -import Provider from './provider.jsx'; - -import AppDispatcher from 'dispatcher/app_dispatcher.jsx'; -import {ActionTypes} from 'utils/constants.jsx'; -import LocalizationStore from 'stores/localization_store.jsx'; - -import React from 'react'; - -// Redux actions -import store from 'stores/redux_store.jsx'; -const getState = store.getState; - -import * as Selectors from 'mattermost-redux/selectors/entities/teams'; - -class SwitchTeamSuggestion extends Suggestion { - render() { - const {item, isSelection} = this.props; - - let className = 'mentions__name'; - if (isSelection) { - className += ' suggestion--selected'; - } - - return ( - <div - onClick={this.handleClick} - className={className} - > - <div className='status'><i className='fa fa-group'/></div> - {item.display_name} - </div> - ); - } -} - -let prefix = ''; - -function quickSwitchSorter(a, b) { - const aDisplayName = a.display_name.toLowerCase(); - const bDisplayName = b.display_name.toLowerCase(); - const aStartsWith = aDisplayName.startsWith(prefix); - const bStartsWith = bDisplayName.startsWith(prefix); - - if (aStartsWith && bStartsWith) { - const locale = LocalizationStore.getLocale(); - - if (aDisplayName !== bDisplayName) { - return aDisplayName.localeCompare(bDisplayName, locale, {numeric: true}); - } - - return a.name.localeCompare(b.name, locale, {numeric: true}); - } else if (aStartsWith) { - return -1; - } - - return 1; -} - -export default class SwitchTeamProvider extends Provider { - handlePretextChanged(suggestionId, teamPrefix) { - if (teamPrefix) { - prefix = teamPrefix; - this.startNewRequest(suggestionId, teamPrefix); - - const allTeams = Selectors.getMyTeams(getState()); - - const teams = allTeams.filter((team) => { - return team.display_name.toLowerCase().indexOf(teamPrefix) !== -1 || - team.name.indexOf(teamPrefix) !== -1; - }); - - const teamNames = teams. - sort(quickSwitchSorter). - map((team) => team.name); - - setTimeout(() => { - AppDispatcher.handleServerAction({ - type: ActionTypes.SUGGESTION_RECEIVED_SUGGESTIONS, - id: suggestionId, - matchedPretext: teamPrefix, - terms: teamNames, - items: teams, - component: SwitchTeamSuggestion - }); - }, 0); - - return true; - } - - return false; - } -} |