2016-07-03 18:45:13 +02:00
|
|
|
import React from 'react';
|
2017-05-23 16:16:31 +02:00
|
|
|
import _t from 'counterpart-riot';
|
2016-06-12 13:32:46 +02:00
|
|
|
import AutocompleteProvider from './AutocompleteProvider';
|
|
|
|
import MatrixClientPeg from '../MatrixClientPeg';
|
2016-06-20 10:22:55 +02:00
|
|
|
import Fuse from 'fuse.js';
|
2016-08-17 13:57:19 +02:00
|
|
|
import {PillCompletion} from './Components';
|
2016-09-07 12:33:58 +02:00
|
|
|
import {getDisplayAliasForRoom} from '../Rooms';
|
2016-08-17 13:57:19 +02:00
|
|
|
import sdk from '../index';
|
2016-06-12 13:32:46 +02:00
|
|
|
|
2016-09-16 12:08:29 +02:00
|
|
|
const ROOM_REGEX = /(?=#)(\S*)/g;
|
2016-06-12 13:32:46 +02:00
|
|
|
|
2016-06-20 10:22:55 +02:00
|
|
|
let instance = null;
|
|
|
|
|
2016-06-12 13:32:46 +02:00
|
|
|
export default class RoomProvider extends AutocompleteProvider {
|
|
|
|
constructor() {
|
2016-06-21 12:16:20 +02:00
|
|
|
super(ROOM_REGEX, {
|
2016-07-03 18:45:13 +02:00
|
|
|
keys: ['displayName', 'userId'],
|
2016-06-21 12:16:20 +02:00
|
|
|
});
|
2016-06-21 01:35:23 +02:00
|
|
|
this.fuse = new Fuse([], {
|
2016-07-03 18:45:13 +02:00
|
|
|
keys: ['name', 'roomId', 'aliases'],
|
2016-06-21 01:35:23 +02:00
|
|
|
});
|
2016-06-12 13:32:46 +02:00
|
|
|
}
|
|
|
|
|
2016-09-13 12:11:52 +02:00
|
|
|
async getCompletions(query: string, selection: {start: number, end: number}, force = false) {
|
2016-08-17 13:57:19 +02:00
|
|
|
const RoomAvatar = sdk.getComponent('views.avatars.RoomAvatar');
|
|
|
|
|
2016-06-12 13:32:46 +02:00
|
|
|
let client = MatrixClientPeg.get();
|
|
|
|
let completions = [];
|
2016-09-13 12:11:52 +02:00
|
|
|
const {command, range} = this.getCurrentCommand(query, selection, force);
|
2016-07-03 18:45:13 +02:00
|
|
|
if (command) {
|
2016-06-21 01:35:23 +02:00
|
|
|
// the only reason we need to do this is because Fuse only matches on properties
|
|
|
|
this.fuse.set(client.getRooms().filter(room => !!room).map(room => {
|
|
|
|
return {
|
2016-07-04 19:04:58 +02:00
|
|
|
room: room,
|
2016-06-21 01:35:23 +02:00
|
|
|
name: room.name,
|
2016-07-03 18:45:13 +02:00
|
|
|
aliases: room.getAliases(),
|
2016-06-21 01:35:23 +02:00
|
|
|
};
|
|
|
|
}));
|
2016-06-21 12:16:20 +02:00
|
|
|
completions = this.fuse.search(command[0]).map(room => {
|
2016-07-04 19:04:58 +02:00
|
|
|
let displayAlias = getDisplayAliasForRoom(room.room) || room.roomId;
|
2016-06-12 13:32:46 +02:00
|
|
|
return {
|
2016-07-04 19:04:58 +02:00
|
|
|
completion: displayAlias,
|
2016-07-03 18:45:13 +02:00
|
|
|
component: (
|
2016-08-17 13:57:19 +02:00
|
|
|
<PillCompletion initialComponent={<RoomAvatar width={24} height={24} room={room.room} />} title={room.name} description={displayAlias} />
|
2016-07-03 18:45:13 +02:00
|
|
|
),
|
|
|
|
range,
|
2016-06-12 13:32:46 +02:00
|
|
|
};
|
2016-09-13 14:32:33 +02:00
|
|
|
}).filter(completion => !!completion.completion && completion.completion.length > 0).slice(0, 4);
|
2016-06-12 13:32:46 +02:00
|
|
|
}
|
2016-09-13 12:11:52 +02:00
|
|
|
return completions;
|
2016-06-12 13:32:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
getName() {
|
2017-05-23 16:16:31 +02:00
|
|
|
return '💬 ' + _t('Rooms');
|
2016-06-12 13:32:46 +02:00
|
|
|
}
|
2017-01-20 15:22:27 +01:00
|
|
|
|
2016-06-20 10:22:55 +02:00
|
|
|
static getInstance() {
|
2016-07-03 18:45:13 +02:00
|
|
|
if (instance == null) {
|
2016-06-20 10:22:55 +02:00
|
|
|
instance = new RoomProvider();
|
2016-07-03 18:45:13 +02:00
|
|
|
}
|
2017-01-20 15:22:27 +01:00
|
|
|
|
2016-06-20 10:22:55 +02:00
|
|
|
return instance;
|
|
|
|
}
|
2016-08-17 13:57:19 +02:00
|
|
|
|
|
|
|
renderCompletions(completions: [React.Component]): ?React.Component {
|
2016-08-22 21:06:31 +02:00
|
|
|
return <div className="mx_Autocomplete_Completion_container_pill">
|
|
|
|
{completions}
|
|
|
|
</div>;
|
2016-08-17 13:57:19 +02:00
|
|
|
}
|
2016-09-13 12:11:52 +02:00
|
|
|
|
|
|
|
shouldForceComplete(): boolean {
|
|
|
|
return true;
|
|
|
|
}
|
2016-06-12 13:32:46 +02:00
|
|
|
}
|