mirror of https://github.com/vector-im/riot-web
				
				
				
			
		
			
				
	
	
		
			260 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			260 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
| /*
 | |
| Copyright 2015, 2016 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 sdk = require('matrix-react-sdk');
 | |
| var Matrix = require("matrix-js-sdk");
 | |
| var dis = require('matrix-react-sdk/lib/dispatcher');
 | |
| var MatrixClientPeg = require("matrix-react-sdk/lib/MatrixClientPeg");
 | |
| var rate_limited_func = require('matrix-react-sdk/lib/ratelimitedfunc');
 | |
| var Modal = require('matrix-react-sdk/lib/Modal');
 | |
| var AccessibleButton = require('matrix-react-sdk/lib/components/views/elements/AccessibleButton');
 | |
| 
 | |
| module.exports = React.createClass({
 | |
|     displayName: 'RightPanel',
 | |
| 
 | |
|     propTypes: {
 | |
|         userId: React.PropTypes.string, // if showing an orphaned MemberInfo page, this is set
 | |
|         roomId: React.PropTypes.string, // if showing panels for a given room, this is set
 | |
|         collapsed: React.PropTypes.bool, // currently unused property to request for a minimized view of the panel
 | |
|     },
 | |
| 
 | |
|     Phase : {
 | |
|         MemberList: 'MemberList',
 | |
|         FilePanel: 'FilePanel',
 | |
|         NotificationPanel: 'NotificationPanel',
 | |
|         MemberInfo: 'MemberInfo',
 | |
|     },
 | |
| 
 | |
|     componentWillMount: function() {
 | |
|         this.dispatcherRef = dis.register(this.onAction);
 | |
|         var cli = MatrixClientPeg.get();
 | |
|         cli.on("RoomState.members", this.onRoomStateMember);
 | |
|     },
 | |
| 
 | |
|     componentWillUnmount: function() {
 | |
|         dis.unregister(this.dispatcherRef);
 | |
|         if (MatrixClientPeg.get()) {
 | |
|             MatrixClientPeg.get().removeListener("RoomState.members", this.onRoomStateMember);
 | |
|         }
 | |
|     },
 | |
| 
 | |
|     getInitialState: function() {
 | |
|         if (this.props.userId) {
 | |
|             var member = new Matrix.RoomMember(null, this.props.userId);
 | |
|             return {
 | |
|                 phase: this.Phase.MemberInfo,
 | |
|                 member: member,
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             return {
 | |
|                 phase: this.Phase.MemberList
 | |
|             }
 | |
|         }
 | |
|     },
 | |
| 
 | |
|     onMemberListButtonClick: function() {
 | |
|         this.setState({ phase: this.Phase.MemberList });
 | |
|     },
 | |
| 
 | |
|     onFileListButtonClick: function() {
 | |
|         this.setState({ phase: this.Phase.FilePanel });
 | |
|     },
 | |
| 
 | |
|     onNotificationListButtonClick: function() {
 | |
|         this.setState({ phase: this.Phase.NotificationPanel });
 | |
|     },
 | |
| 
 | |
|     onCollapseClick: function() {
 | |
|         dis.dispatch({
 | |
|             action: 'hide_right_panel',
 | |
|         });
 | |
|     },
 | |
| 
 | |
|     onInviteButtonClick: function() {
 | |
|         if (MatrixClientPeg.get().isGuest()) {
 | |
|             dis.dispatch({action: 'view_set_mxid'});
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         // call ChatInviteDialog
 | |
|         dis.dispatch({
 | |
|             action: 'view_invite',
 | |
|             roomId: this.props.roomId,
 | |
|         });
 | |
|     },
 | |
| 
 | |
|     onRoomStateMember: function(ev, state, member) {
 | |
|         // redraw the badge on the membership list
 | |
|         if (this.state.phase == this.Phase.MemberList && member.roomId === this.props.roomId) {
 | |
|             this._delayedUpdate();
 | |
|         }
 | |
|         else if (this.state.phase === this.Phase.MemberInfo && member.roomId === this.props.roomId &&
 | |
|                 member.userId === this.state.member.userId) {
 | |
|             // refresh the member info (e.g. new power level)
 | |
|             this._delayedUpdate();
 | |
|         }
 | |
|     },
 | |
| 
 | |
|     _delayedUpdate: new rate_limited_func(function() {
 | |
|         this.forceUpdate();
 | |
|     }, 500),
 | |
| 
 | |
|     onAction: function(payload) {
 | |
|         if (payload.action === "view_user") {
 | |
|             dis.dispatch({
 | |
|                 action: 'show_right_panel',
 | |
|             });
 | |
|             if (payload.member) {
 | |
|                 this.setState({
 | |
|                     phase: this.Phase.MemberInfo,
 | |
|                     member: payload.member,
 | |
|                 });
 | |
|             }
 | |
|             else {
 | |
|                 this.setState({
 | |
|                     phase: this.Phase.MemberList
 | |
|                 });
 | |
|             }
 | |
|         }
 | |
|         else if (payload.action === "view_room") {
 | |
|             if (this.state.phase === this.Phase.MemberInfo) {
 | |
|                 this.setState({
 | |
|                     phase: this.Phase.MemberList
 | |
|                 });
 | |
|             }
 | |
|         }
 | |
|     },
 | |
| 
 | |
|     render: function() {
 | |
|         var MemberList = sdk.getComponent('rooms.MemberList');
 | |
|         var NotificationPanel = sdk.getComponent('structures.NotificationPanel');
 | |
|         var FilePanel = sdk.getComponent('structures.FilePanel');
 | |
|         var TintableSvg = sdk.getComponent("elements.TintableSvg");
 | |
|         var buttonGroup;
 | |
|         var inviteGroup;
 | |
|         var panel;
 | |
| 
 | |
|         var filesHighlight;
 | |
|         var membersHighlight;
 | |
|         var notificationsHighlight;
 | |
|         if (!this.props.collapsed) {
 | |
|             if (this.state.phase == this.Phase.MemberList || this.state.phase === this.Phase.MemberInfo) {
 | |
|                 membersHighlight = <div className="mx_RightPanel_headerButton_highlight"></div>;
 | |
|             }
 | |
|             else if (this.state.phase == this.Phase.FilePanel) {
 | |
|                 filesHighlight = <div className="mx_RightPanel_headerButton_highlight"></div>;
 | |
|             }
 | |
|             else if (this.state.phase == this.Phase.NotificationPanel) {
 | |
|                 notificationsHighlight = <div className="mx_RightPanel_headerButton_highlight"></div>;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         var membersBadge;
 | |
|         if ((this.state.phase == this.Phase.MemberList || this.state.phase === this.Phase.MemberInfo) && this.props.roomId) {
 | |
|             var cli = MatrixClientPeg.get();
 | |
|             var room = cli.getRoom(this.props.roomId);
 | |
|             var user_is_in_room;
 | |
|             if (room) {
 | |
|                 membersBadge = room.getJoinedMembers().length;
 | |
|                 user_is_in_room = room.hasMembershipState(
 | |
|                     MatrixClientPeg.get().credentials.userId, 'join'
 | |
|                 );
 | |
|             }
 | |
| 
 | |
|             if (user_is_in_room) {
 | |
|                 inviteGroup =
 | |
|                     <AccessibleButton className="mx_RightPanel_invite" onClick={ this.onInviteButtonClick } >
 | |
|                         <div className="mx_RightPanel_icon" >
 | |
|                             <TintableSvg src="img/icon-invite-people.svg" width="35" height="35" />
 | |
|                         </div>
 | |
|                         <div className="mx_RightPanel_message">Invite to this room</div>
 | |
|                     </AccessibleButton>;
 | |
|             }
 | |
| 
 | |
|         }
 | |
| 
 | |
|         if (this.props.roomId) {
 | |
|             buttonGroup =
 | |
|                     <div className="mx_RightPanel_headerButtonGroup">
 | |
|                         <AccessibleButton className="mx_RightPanel_headerButton"
 | |
|                                 title="Members" onClick={ this.onMemberListButtonClick }>
 | |
|                             <div className="mx_RightPanel_headerButton_badge">{ membersBadge ? membersBadge : <span> </span>}</div>
 | |
|                             <TintableSvg src="img/icons-people.svg" width="25" height="25"/>
 | |
|                             { membersHighlight }
 | |
|                         </AccessibleButton>
 | |
|                         <AccessibleButton
 | |
|                                 className="mx_RightPanel_headerButton mx_RightPanel_filebutton"
 | |
|                                 title="Files" onClick={ this.onFileListButtonClick }>
 | |
|                             <div className="mx_RightPanel_headerButton_badge"> </div>
 | |
|                             <TintableSvg src="img/icons-files.svg" width="25" height="25"/>
 | |
|                             { filesHighlight }
 | |
|                         </AccessibleButton>
 | |
|                         <AccessibleButton
 | |
|                                 className="mx_RightPanel_headerButton mx_RightPanel_notificationbutton"
 | |
|                                 title="Notifications" onClick={ this.onNotificationListButtonClick }>
 | |
|                             <div className="mx_RightPanel_headerButton_badge"> </div>
 | |
|                             <TintableSvg src="img/icons-notifications.svg" width="25" height="25"/>
 | |
|                             { notificationsHighlight }
 | |
|                         </AccessibleButton>
 | |
|                         <div className="mx_RightPanel_headerButton mx_RightPanel_collapsebutton" title="Hide panel" onClick={ this.onCollapseClick }>
 | |
|                             <TintableSvg src="img/minimise.svg" width="10" height="16"/>
 | |
|                         </div>
 | |
|                     </div>;
 | |
|         }
 | |
| 
 | |
|         if (!this.props.collapsed) {
 | |
|             if(this.props.roomId && this.state.phase == this.Phase.MemberList) {
 | |
|                 panel = <MemberList roomId={this.props.roomId} key={this.props.roomId} />
 | |
|             }
 | |
|             else if(this.state.phase == this.Phase.MemberInfo) {
 | |
|                 var MemberInfo = sdk.getComponent('rooms.MemberInfo');
 | |
|                 panel = <MemberInfo member={this.state.member} key={this.props.roomId || this.props.userId} />
 | |
|             }
 | |
|             else if (this.state.phase == this.Phase.NotificationPanel) {
 | |
|                 panel = <NotificationPanel />
 | |
|             }
 | |
|             else if (this.state.phase == this.Phase.FilePanel) {
 | |
|                 panel = <FilePanel roomId={this.props.roomId} />
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if (!panel) {
 | |
|             panel = <div className="mx_RightPanel_blank"></div>;
 | |
|         }
 | |
| 
 | |
|         var classes = "mx_RightPanel mx_fadable";
 | |
|         if (this.props.collapsed) {
 | |
|             classes += " collapsed";
 | |
|         }
 | |
| 
 | |
|         return (
 | |
|             <aside className={classes} style={{ opacity: this.props.opacity }}>
 | |
|                 <div className="mx_RightPanel_header">
 | |
|                     { buttonGroup }
 | |
|                 </div>
 | |
|                 { panel }
 | |
|                 <div className="mx_RightPanel_footer">
 | |
|                     { inviteGroup }
 | |
|                 </div>
 | |
|             </aside>
 | |
|         );
 | |
|     }
 | |
| });
 |