FilePanel: Refactor out the file panel and convert the methods to async ones.

This commit is contained in:
Damir Jelić 2020-01-14 11:20:56 +01:00
parent 491cef4f92
commit d30c46a641

View file

@ -40,17 +40,13 @@ const FilePanel = createReactClass({
};
},
componentDidMount: function() {
this.updateTimelineSet(this.props.roomId);
async componentDidMount() {
await this.updateTimelineSet(this.props.roomId);
},
updateTimelineSet: function(roomId) {
async fetchFileEventsServer(room) {
const client = MatrixClientPeg.get();
const room = client.getRoom(roomId);
this.noRoom = !room;
if (room) {
const filter = new Matrix.Filter(client.credentials.userId);
filter.setDefinition(
{
@ -66,16 +62,28 @@ const FilePanel = createReactClass({
);
// FIXME: we shouldn't be doing this every time we change room - see comment above.
client.getOrCreateFilter("FILTER_FILES_" + client.credentials.userId, filter).then(
(filterId)=>{
// TODO: Remove this stale comment? Which comment above?
const filterId = await client.getOrCreateFilter("FILTER_FILES_" + client.credentials.userId, filter)
filter.filterId = filterId;
const timelineSet = room.getOrCreateFilteredTimelineSet(filter);
return timelineSet;
},
async updateTimelineSet(roomId: string) {
const client = MatrixClientPeg.get();
const room = client.getRoom(roomId);
this.noRoom = !room;
if (room) {
try {
let timelineSet = await this.fetchFileEventsServer(room)
this.setState({ timelineSet: timelineSet });
},
(error)=>{
} catch (error) {
console.error("Failed to get or create file panel filter", error);
},
);
}
} else {
console.error("Failed to add filtered timelineSet for FilePanel as no room!");
}