2015-06-23 17:41:25 +02:00
|
|
|
/*
|
|
|
|
Copyright 2015 OpenMarket Ltd
|
|
|
|
|
|
|
|
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';
|
|
|
|
|
2015-06-19 13:53:48 +02:00
|
|
|
var React = require('react');
|
|
|
|
|
2015-06-23 15:40:50 +02:00
|
|
|
var MatrixClientPeg = require("../../../../src/MatrixClientPeg");
|
2015-06-22 15:48:58 +02:00
|
|
|
|
2015-06-23 15:40:50 +02:00
|
|
|
var ComponentBroker = require('../../../../src/ComponentBroker');
|
2015-07-21 12:26:08 +02:00
|
|
|
var Modal = require("../../../../src/Modal");
|
2015-06-24 14:28:44 +02:00
|
|
|
var classNames = require("classnames");
|
2015-07-20 04:02:04 +02:00
|
|
|
var filesize = require('filesize');
|
2015-07-21 12:02:36 +02:00
|
|
|
var q = require('q');
|
2015-06-19 13:53:48 +02:00
|
|
|
|
|
|
|
var MessageTile = ComponentBroker.get('molecules/MessageTile');
|
|
|
|
var RoomHeader = ComponentBroker.get('molecules/RoomHeader');
|
|
|
|
var MessageComposer = ComponentBroker.get('molecules/MessageComposer');
|
2015-07-15 17:52:23 +02:00
|
|
|
var CallView = ComponentBroker.get("molecules/voip/CallView");
|
2015-07-20 16:07:51 +02:00
|
|
|
var RoomSettings = ComponentBroker.get("molecules/RoomSettings");
|
2015-07-21 17:12:08 +02:00
|
|
|
var Notifier = ComponentBroker.get('organisms/Notifier');
|
|
|
|
var MatrixToolbar = ComponentBroker.get('molecules/MatrixToolbar');
|
2015-06-23 15:40:50 +02:00
|
|
|
var RoomViewController = require("../../../../src/controllers/organisms/RoomView");
|
2015-06-19 13:53:48 +02:00
|
|
|
|
2015-06-22 15:48:58 +02:00
|
|
|
var Loader = require("react-loader");
|
|
|
|
|
2015-06-19 13:53:48 +02:00
|
|
|
|
|
|
|
module.exports = React.createClass({
|
2015-06-19 17:21:09 +02:00
|
|
|
displayName: 'RoomView',
|
2015-06-19 13:53:48 +02:00
|
|
|
mixins: [RoomViewController],
|
|
|
|
|
2015-07-20 16:07:51 +02:00
|
|
|
onSettingsClick: function() {
|
|
|
|
this.setState({editingRoomSettings: true});
|
|
|
|
},
|
|
|
|
|
|
|
|
onSaveClick: function() {
|
2015-07-21 12:02:36 +02:00
|
|
|
this.setState({
|
|
|
|
editingRoomSettings: false,
|
|
|
|
uploadingRoomSettings: true,
|
|
|
|
});
|
2015-07-20 16:07:51 +02:00
|
|
|
|
|
|
|
var new_name = this.refs.header.getRoomName();
|
|
|
|
var new_topic = this.refs.room_settings.getTopic();
|
|
|
|
var new_join_rule = this.refs.room_settings.getJoinRules();
|
|
|
|
var new_history_visibility = this.refs.room_settings.getHistoryVisibility();
|
2015-07-20 18:31:40 +02:00
|
|
|
var new_power_levels = this.refs.room_settings.getPowerLevels();
|
2015-07-20 16:07:51 +02:00
|
|
|
|
2015-07-21 16:24:10 +02:00
|
|
|
this.uploadNewState(
|
|
|
|
new_name,
|
|
|
|
new_topic,
|
|
|
|
new_join_rule,
|
|
|
|
new_history_visibility,
|
|
|
|
new_power_levels
|
|
|
|
);
|
2015-07-20 16:07:51 +02:00
|
|
|
},
|
|
|
|
|
2015-06-19 13:53:48 +02:00
|
|
|
render: function() {
|
2015-07-14 19:46:15 +02:00
|
|
|
if (!this.state.room) {
|
|
|
|
return (
|
|
|
|
<div />
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-06-22 15:48:58 +02:00
|
|
|
var myUserId = MatrixClientPeg.get().credentials.userId;
|
|
|
|
if (this.state.room.currentState.members[myUserId].membership == 'invite') {
|
|
|
|
if (this.state.joining) {
|
|
|
|
return (
|
|
|
|
<div className="mx_RoomView">
|
|
|
|
<Loader />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
var inviteEvent = this.state.room.currentState.members[myUserId].events.member.event;
|
|
|
|
// XXX: Leaving this intentionally basic for now because invites are about to change totally
|
|
|
|
var joinErrorText = this.state.joinError ? "Failed to join room!" : "";
|
|
|
|
return (
|
|
|
|
<div className="mx_RoomView">
|
|
|
|
<div className="mx_RoomView_invitePrompt">
|
|
|
|
<div>{inviteEvent.user_id} has invited you to a room</div>
|
|
|
|
<button ref="joinButton" onClick={this.onJoinButtonClicked}>Join</button>
|
|
|
|
<div className="error">{joinErrorText}</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} else {
|
2015-06-24 14:28:44 +02:00
|
|
|
var scrollheader_classes = classNames({
|
|
|
|
mx_RoomView_scrollheader: true,
|
|
|
|
loading: this.state.paginating
|
|
|
|
});
|
2015-07-19 17:38:56 +02:00
|
|
|
|
|
|
|
var statusBar = (
|
|
|
|
<div />
|
|
|
|
);
|
|
|
|
|
2015-07-20 04:02:04 +02:00
|
|
|
if (this.state.upload) {
|
|
|
|
var innerProgressStyle = {
|
|
|
|
width: ((this.state.upload.uploadedBytes / this.state.upload.totalBytes) * 100) + '%'
|
|
|
|
};
|
2015-07-19 17:38:56 +02:00
|
|
|
statusBar = (
|
2015-07-20 04:02:04 +02:00
|
|
|
<div className="mx_RoomView_uploadBar">
|
|
|
|
<span className="mx_RoomView_uploadFilename">Uploading {this.state.upload.fileName}</span>
|
|
|
|
<span className="mx_RoomView_uploadBytes">
|
|
|
|
{filesize(this.state.upload.uploadedBytes)} / {filesize(this.state.upload.totalBytes)}
|
|
|
|
</span>
|
|
|
|
<div className="mx_RoomView_uploadProgressOuter">
|
|
|
|
<div className="mx_RoomView_uploadProgressInner" style={innerProgressStyle}></div>
|
|
|
|
</div>
|
2015-07-19 17:38:56 +02:00
|
|
|
</div>
|
|
|
|
);
|
2015-07-20 04:02:04 +02:00
|
|
|
} else {
|
|
|
|
var typingString = this.getWhoIsTypingString();
|
|
|
|
if (typingString) {
|
|
|
|
statusBar = (
|
|
|
|
<div className="mx_RoomView_typingBar">
|
2015-07-20 21:09:24 +02:00
|
|
|
<img src="img/typing.png" width="40" height="40" alt=""/>
|
2015-07-20 04:02:04 +02:00
|
|
|
{typingString}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2015-07-19 17:38:56 +02:00
|
|
|
}
|
|
|
|
|
2015-07-20 16:07:51 +02:00
|
|
|
var roomEdit = null;
|
|
|
|
|
|
|
|
if (this.state.editingRoomSettings) {
|
|
|
|
roomEdit = <RoomSettings ref="room_settings" room={this.state.room} />;
|
|
|
|
}
|
|
|
|
|
2015-07-21 12:02:36 +02:00
|
|
|
if (this.state.uploadingRoomSettings) {
|
|
|
|
roomEdit = <Loader/>;
|
|
|
|
}
|
|
|
|
|
2015-07-21 17:12:08 +02:00
|
|
|
var top_bar;
|
|
|
|
if (!Notifier.isEnabled()) {
|
|
|
|
top_bar = <MatrixToolbar />;
|
|
|
|
}
|
|
|
|
|
2015-06-22 15:48:58 +02:00
|
|
|
return (
|
|
|
|
<div className="mx_RoomView">
|
2015-07-21 17:12:08 +02:00
|
|
|
{top_bar}
|
2015-07-20 16:07:51 +02:00
|
|
|
<RoomHeader ref="header" room={this.state.room} editing={this.state.editingRoomSettings}
|
|
|
|
onSettingsClick={this.onSettingsClick} onSaveClick={this.onSaveClick}/>
|
2015-07-15 14:34:11 +02:00
|
|
|
<div className="mx_RoomView_auxPanel">
|
2015-07-15 17:52:23 +02:00
|
|
|
<CallView room={this.state.room}/>
|
2015-07-20 16:07:51 +02:00
|
|
|
{ roomEdit }
|
2015-07-15 14:34:11 +02:00
|
|
|
</div>
|
2015-07-20 17:24:38 +02:00
|
|
|
<div ref="messageWrapper" className="mx_RoomView_messagePanel" onScroll={ this.onMessageListScroll }>
|
2015-07-13 02:51:24 +02:00
|
|
|
<div className="mx_RoomView_messageListWrapper">
|
|
|
|
<div className="mx_RoomView_MessageList" aria-live="polite">
|
|
|
|
<div className={scrollheader_classes}>
|
2015-07-07 03:10:10 +02:00
|
|
|
</div>
|
2015-07-13 02:51:24 +02:00
|
|
|
{this.getEventTiles()}
|
2015-07-07 03:10:10 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2015-06-22 15:48:58 +02:00
|
|
|
</div>
|
2015-07-18 02:21:56 +02:00
|
|
|
<div className="mx_RoomView_statusArea">
|
|
|
|
<div className="mx_RoomView_statusAreaBox">
|
2015-07-19 17:38:56 +02:00
|
|
|
{statusBar}
|
2015-07-18 02:21:56 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2015-07-20 04:02:04 +02:00
|
|
|
<MessageComposer room={this.state.room} uploadFile={this.uploadFile} />
|
2015-06-22 12:42:09 +02:00
|
|
|
</div>
|
2015-06-22 15:48:58 +02:00
|
|
|
);
|
|
|
|
}
|
2015-06-19 13:53:48 +02:00
|
|
|
},
|
|
|
|
});
|