2016-07-03 18:45:13 +02:00
|
|
|
import React from 'react';
|
2016-06-12 13:32:46 +02:00
|
|
|
import AutocompleteProvider from './AutocompleteProvider';
|
|
|
|
import Q from 'q';
|
|
|
|
import MatrixClientPeg from '../MatrixClientPeg';
|
2016-06-20 10:22:55 +02:00
|
|
|
import Fuse from 'fuse.js';
|
2016-07-03 18:45:13 +02:00
|
|
|
import {TextualCompletion} from './Components';
|
2016-07-04 19:04:58 +02:00
|
|
|
import {getDisplayAliasForRoom} from '../MatrixTools';
|
2016-06-12 13:32:46 +02:00
|
|
|
|
2016-06-21 01:35:23 +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-06-21 12:16:20 +02:00
|
|
|
getCompletions(query: string, selection: {start: number, end: number}) {
|
2016-06-12 13:32:46 +02:00
|
|
|
let client = MatrixClientPeg.get();
|
|
|
|
let completions = [];
|
2016-07-03 18:45:13 +02:00
|
|
|
const {command, range} = this.getCurrentCommand(query, selection);
|
|
|
|
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,
|
|
|
|
roomId: room.roomId,
|
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-07-04 19:04:58 +02:00
|
|
|
<TextualCompletion title={room.name} description={displayAlias} />
|
2016-07-03 18:45:13 +02:00
|
|
|
),
|
|
|
|
range,
|
2016-06-12 13:32:46 +02:00
|
|
|
};
|
2016-07-03 18:45:13 +02:00
|
|
|
}).slice(0, 4);
|
2016-06-12 13:32:46 +02:00
|
|
|
}
|
|
|
|
return Q.when(completions);
|
|
|
|
}
|
|
|
|
|
|
|
|
getName() {
|
|
|
|
return 'Rooms';
|
|
|
|
}
|
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
|
|
|
}
|
2016-06-20 10:22:55 +02:00
|
|
|
|
|
|
|
return instance;
|
|
|
|
}
|
2016-06-12 13:32:46 +02:00
|
|
|
}
|