2015-07-21 06:11:24 +03:00
|
|
|
/*
|
2016-01-07 07:17:56 +03:00
|
|
|
Copyright 2015, 2016 OpenMarket Ltd
|
2015-07-21 06:11:24 +03:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var React = require('react');
|
|
|
|
|
2015-09-22 21:09:23 +03:00
|
|
|
var MatrixClientPeg = require('matrix-react-sdk/lib/MatrixClientPeg');
|
|
|
|
var Modal = require('matrix-react-sdk/lib/Modal');
|
2015-09-22 20:49:04 +03:00
|
|
|
var sdk = require('matrix-react-sdk')
|
2015-09-22 21:09:23 +03:00
|
|
|
var dis = require('matrix-react-sdk/lib/dispatcher');
|
2015-07-21 06:11:24 +03:00
|
|
|
|
|
|
|
module.exports = React.createClass({
|
|
|
|
displayName: 'RoomDirectory',
|
|
|
|
|
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
|
|
|
publicRooms: [],
|
|
|
|
roomAlias: '',
|
2015-07-28 00:31:24 +03:00
|
|
|
loading: true,
|
2015-07-21 06:11:24 +03:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
componentDidMount: function() {
|
|
|
|
var self = this;
|
|
|
|
MatrixClientPeg.get().publicRooms(function (err, data) {
|
|
|
|
if (err) {
|
2015-07-28 00:31:24 +03:00
|
|
|
self.setState({ loading: false });
|
2015-07-21 06:11:24 +03:00
|
|
|
console.error("Failed to get publicRooms: %s", JSON.stringify(err));
|
2015-11-30 17:11:28 +03:00
|
|
|
var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
|
2015-07-21 06:11:24 +03:00
|
|
|
Modal.createDialog(ErrorDialog, {
|
|
|
|
title: "Failed to get public room list",
|
|
|
|
description: err.message
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
self.setState({
|
2015-07-28 00:31:24 +03:00
|
|
|
publicRooms: data.chunk,
|
|
|
|
loading: false,
|
2015-07-21 06:11:24 +03:00
|
|
|
});
|
|
|
|
self.forceUpdate();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
joinRoom: function(roomId) {
|
2015-07-28 00:31:24 +03:00
|
|
|
var self = this;
|
|
|
|
self.setState({ loading: true });
|
2015-07-21 06:11:24 +03:00
|
|
|
// XXX: check that JS SDK suppresses duplicate attempts to join the same room
|
|
|
|
MatrixClientPeg.get().joinRoom(roomId).done(function() {
|
|
|
|
dis.dispatch({
|
|
|
|
action: 'view_room',
|
|
|
|
room_id: roomId
|
|
|
|
});
|
|
|
|
}, function(err) {
|
|
|
|
console.error("Failed to join room: %s", JSON.stringify(err));
|
2015-11-30 17:11:28 +03:00
|
|
|
var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
|
2015-07-21 06:11:24 +03:00
|
|
|
Modal.createDialog(ErrorDialog, {
|
|
|
|
title: "Failed to join room",
|
|
|
|
description: err.message
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
getRows: function(filter) {
|
|
|
|
if (!this.state.publicRooms) return [];
|
|
|
|
|
|
|
|
var rooms = this.state.publicRooms.filter(function(a) {
|
|
|
|
// FIXME: if incrementally typing, keep narrowing down the search set
|
2015-07-28 00:31:24 +03:00
|
|
|
// incrementally rather than starting over each time.
|
2015-07-23 20:24:34 +03:00
|
|
|
return (a.aliases[0].search(filter) >= 0 && a.num_joined_members > 0);
|
2015-07-21 06:11:24 +03:00
|
|
|
}).sort(function(a,b) {
|
2015-07-23 20:24:34 +03:00
|
|
|
return a.num_joined_members - b.num_joined_members;
|
2015-07-21 06:11:24 +03:00
|
|
|
});
|
|
|
|
var rows = [];
|
|
|
|
var self = this;
|
2016-01-07 17:43:12 +03:00
|
|
|
var guestRead, guestJoin;
|
2015-07-21 06:11:24 +03:00
|
|
|
for (var i = 0; i < rooms.length; i++) {
|
2015-07-28 00:31:24 +03:00
|
|
|
var name = rooms[i].name || rooms[i].aliases[0];
|
2016-01-07 17:43:12 +03:00
|
|
|
guestRead = null;
|
|
|
|
guestJoin = null;
|
|
|
|
|
|
|
|
if (rooms[i].world_readable) {
|
|
|
|
guestRead = (
|
|
|
|
<img src="img/members.svg"
|
|
|
|
alt="World Readable" title="World Readable" width="12" height="12" />
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (rooms[i].guest_can_join) {
|
|
|
|
guestJoin = (
|
|
|
|
<img src="img/leave.svg"
|
|
|
|
alt="Guests can join" title="Guests can join" width="12" height="12" />
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-07-23 20:24:34 +03:00
|
|
|
// <img src={ MatrixClientPeg.get().getAvatarUrlForRoom(rooms[i].room_id, 40, 40, "crop") } width="40" height="40" alt=""/>
|
2015-07-21 06:11:24 +03:00
|
|
|
rows.unshift(
|
2015-07-23 20:24:34 +03:00
|
|
|
<tbody key={ rooms[i].room_id }>
|
|
|
|
<tr onClick={self.joinRoom.bind(null, rooms[i].room_id)}>
|
2016-01-07 17:43:12 +03:00
|
|
|
<td className="mx_RoomDirectory_name">{ name } {guestRead} {guestJoin}</td>
|
2015-07-23 20:24:34 +03:00
|
|
|
<td>{ rooms[i].aliases[0] }</td>
|
|
|
|
<td>{ rooms[i].num_joined_members }</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td className="mx_RoomDirectory_topic" colSpan="3">{ rooms[i].topic }</td>
|
|
|
|
</tr>
|
|
|
|
</tbody>
|
2015-07-21 06:11:24 +03:00
|
|
|
);
|
|
|
|
}
|
|
|
|
return rows;
|
|
|
|
},
|
|
|
|
|
|
|
|
onKeyUp: function(ev) {
|
|
|
|
this.forceUpdate();
|
2015-11-10 02:54:10 +03:00
|
|
|
this.setState({ roomAlias : this.refs.roomAlias.value })
|
2015-07-21 06:11:24 +03:00
|
|
|
if (ev.key == "Enter") {
|
2015-11-10 02:54:10 +03:00
|
|
|
this.joinRoom(this.refs.roomAlias.value);
|
2015-07-21 06:11:24 +03:00
|
|
|
}
|
|
|
|
if (ev.key == "Down") {
|
|
|
|
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
render: function() {
|
2015-07-28 00:31:24 +03:00
|
|
|
if (this.state.loading) {
|
2015-11-26 17:25:20 +03:00
|
|
|
var Loader = sdk.getComponent("elements.Spinner");
|
2015-07-28 00:31:24 +03:00
|
|
|
return (
|
|
|
|
<div className="mx_RoomDirectory">
|
|
|
|
<Loader />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-11-27 13:42:25 +03:00
|
|
|
var RoomHeader = sdk.getComponent('rooms.RoomHeader');
|
2015-07-21 06:11:24 +03:00
|
|
|
return (
|
|
|
|
<div className="mx_RoomDirectory">
|
|
|
|
<RoomHeader simpleHeader="Public Rooms" />
|
|
|
|
<div className="mx_RoomDirectory_list">
|
|
|
|
<input ref="roomAlias" placeholder="Join a room (e.g. #foo:domain.com)" className="mx_RoomDirectory_input" size="64" onKeyUp={ this.onKeyUp }/>
|
2015-07-23 20:24:34 +03:00
|
|
|
<div className="mx_RoomDirectory_tableWrapper">
|
|
|
|
<table className="mx_RoomDirectory_table">
|
2015-11-11 04:00:18 +03:00
|
|
|
<thead>
|
|
|
|
<tr><th width="45%">Room</th><th width="45%">Alias</th><th width="10%">Members</th></tr>
|
|
|
|
</thead>
|
2015-07-23 20:24:34 +03:00
|
|
|
{ this.getRows(this.state.roomAlias) }
|
|
|
|
</table>
|
|
|
|
</div>
|
2015-07-21 06:11:24 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|