2015-07-20 02:51:58 +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';
|
|
|
|
|
|
|
|
var React = require('react');
|
|
|
|
|
|
|
|
var MatrixClientPeg = require("../../../../src/MatrixClientPeg");
|
2015-07-20 12:37:48 +02:00
|
|
|
var MemberInfoController = require("../../../../src/controllers/molecules/MemberInfo");
|
2015-08-13 20:30:02 +02:00
|
|
|
var ComponentBroker = require('../../../../src/ComponentBroker');
|
|
|
|
var MemberAvatar = ComponentBroker.get('atoms/MemberAvatar');
|
2015-07-20 02:51:58 +02:00
|
|
|
|
|
|
|
module.exports = React.createClass({
|
|
|
|
displayName: 'MemberInfo',
|
2015-07-20 12:37:48 +02:00
|
|
|
mixins: [MemberInfoController],
|
|
|
|
|
2015-07-20 02:51:58 +02:00
|
|
|
render: function() {
|
2015-09-22 01:16:45 +02:00
|
|
|
var interactButton, kickButton, banButton, muteButton, giveModButton;
|
|
|
|
if (this.props.member.userId === MatrixClientPeg.get().credentials.userId) {
|
|
|
|
interactButton = <div className="mx_ContextualMenu_field" onClick={this.onLeaveClick}>Leave room</div>;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
interactButton = <div className="mx_ContextualMenu_field" onClick={this.onChatClick}>Start chat</div>;
|
|
|
|
}
|
|
|
|
|
2015-07-21 12:26:02 +02:00
|
|
|
if (this.state.can.kick) {
|
2015-09-21 19:22:29 +02:00
|
|
|
kickButton = <div className="mx_ContextualMenu_field" onClick={this.onKick}>
|
2015-07-21 12:26:02 +02:00
|
|
|
Kick
|
|
|
|
</div>;
|
|
|
|
}
|
|
|
|
if (this.state.can.ban) {
|
2015-09-21 19:22:29 +02:00
|
|
|
banButton = <div className="mx_ContextualMenu_field" onClick={this.onBan}>
|
2015-07-21 12:26:02 +02:00
|
|
|
Ban
|
|
|
|
</div>;
|
|
|
|
}
|
|
|
|
if (this.state.can.mute) {
|
|
|
|
var muteLabel = this.state.muted ? "Unmute" : "Mute";
|
2015-09-21 19:22:29 +02:00
|
|
|
muteButton = <div className="mx_ContextualMenu_field" onClick={this.onMuteToggle}>
|
2015-07-21 12:26:02 +02:00
|
|
|
{muteLabel}
|
|
|
|
</div>;
|
|
|
|
}
|
2015-07-21 14:24:59 +02:00
|
|
|
if (this.state.can.modifyLevel) {
|
|
|
|
var giveOpLabel = this.state.isTargetMod ? "Revoke Mod" : "Make Mod";
|
2015-09-21 19:22:29 +02:00
|
|
|
giveModButton = <div className="mx_ContextualMenu_field" onClick={this.onModToggle}>
|
2015-07-21 14:24:59 +02:00
|
|
|
{giveOpLabel}
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
|
2015-07-20 02:51:58 +02:00
|
|
|
return (
|
2015-09-21 19:22:29 +02:00
|
|
|
<div>
|
2015-09-22 01:16:45 +02:00
|
|
|
{interactButton}
|
2015-07-21 12:26:02 +02:00
|
|
|
{muteButton}
|
|
|
|
{kickButton}
|
|
|
|
{banButton}
|
2015-07-21 14:24:59 +02:00
|
|
|
{giveModButton}
|
2015-07-20 02:51:58 +02:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|