vaguely skin MemberInfo correctly
							parent
							
								
									430c90f4a4
								
							
						
					
					
						commit
						8e1ab8e6b4
					
				| 
						 | 
				
			
			@ -23,15 +23,15 @@ limitations under the License.
 | 
			
		|||
 | 
			
		||||
module.exports.components = {};
 | 
			
		||||
module.exports.components['structures.CreateRoom'] = require('./components/structures/CreateRoom');
 | 
			
		||||
module.exports.components['structures.login.ForgotPassword'] = require('./components/structures/login/ForgotPassword');
 | 
			
		||||
module.exports.components['structures.login.Login'] = require('./components/structures/login/Login');
 | 
			
		||||
module.exports.components['structures.login.PostRegistration'] = require('./components/structures/login/PostRegistration');
 | 
			
		||||
module.exports.components['structures.login.Registration'] = require('./components/structures/login/Registration');
 | 
			
		||||
module.exports.components['structures.MatrixChat'] = require('./components/structures/MatrixChat');
 | 
			
		||||
module.exports.components['structures.RoomView'] = require('./components/structures/RoomView');
 | 
			
		||||
module.exports.components['structures.ScrollPanel'] = require('./components/structures/ScrollPanel');
 | 
			
		||||
module.exports.components['structures.UploadBar'] = require('./components/structures/UploadBar');
 | 
			
		||||
module.exports.components['structures.UserSettings'] = require('./components/structures/UserSettings');
 | 
			
		||||
module.exports.components['structures.login.ForgotPassword'] = require('./components/structures/login/ForgotPassword');
 | 
			
		||||
module.exports.components['structures.login.Login'] = require('./components/structures/login/Login');
 | 
			
		||||
module.exports.components['structures.login.PostRegistration'] = require('./components/structures/login/PostRegistration');
 | 
			
		||||
module.exports.components['structures.login.Registration'] = require('./components/structures/login/Registration');
 | 
			
		||||
module.exports.components['views.avatars.MemberAvatar'] = require('./components/views/avatars/MemberAvatar');
 | 
			
		||||
module.exports.components['views.avatars.RoomAvatar'] = require('./components/views/avatars/RoomAvatar');
 | 
			
		||||
module.exports.components['views.create_room.CreateRoomButton'] = require('./components/views/create_room/CreateRoomButton');
 | 
			
		||||
| 
						 | 
				
			
			@ -41,6 +41,7 @@ module.exports.components['views.dialogs.ErrorDialog'] = require('./components/v
 | 
			
		|||
module.exports.components['views.dialogs.LogoutPrompt'] = require('./components/views/dialogs/LogoutPrompt');
 | 
			
		||||
module.exports.components['views.dialogs.QuestionDialog'] = require('./components/views/dialogs/QuestionDialog');
 | 
			
		||||
module.exports.components['views.elements.EditableText'] = require('./components/views/elements/EditableText');
 | 
			
		||||
module.exports.components['views.elements.PowerSelector'] = require('./components/views/elements/PowerSelector');
 | 
			
		||||
module.exports.components['views.elements.ProgressBar'] = require('./components/views/elements/ProgressBar');
 | 
			
		||||
module.exports.components['views.elements.TintableSvg'] = require('./components/views/elements/TintableSvg');
 | 
			
		||||
module.exports.components['views.elements.UserSelector'] = require('./components/views/elements/UserSelector');
 | 
			
		||||
| 
						 | 
				
			
			@ -52,10 +53,10 @@ module.exports.components['views.login.LoginHeader'] = require('./components/vie
 | 
			
		|||
module.exports.components['views.login.PasswordLogin'] = require('./components/views/login/PasswordLogin');
 | 
			
		||||
module.exports.components['views.login.RegistrationForm'] = require('./components/views/login/RegistrationForm');
 | 
			
		||||
module.exports.components['views.login.ServerConfig'] = require('./components/views/login/ServerConfig');
 | 
			
		||||
module.exports.components['views.messages.MessageEvent'] = require('./components/views/messages/MessageEvent');
 | 
			
		||||
module.exports.components['views.messages.MFileBody'] = require('./components/views/messages/MFileBody');
 | 
			
		||||
module.exports.components['views.messages.MImageBody'] = require('./components/views/messages/MImageBody');
 | 
			
		||||
module.exports.components['views.messages.MVideoBody'] = require('./components/views/messages/MVideoBody');
 | 
			
		||||
module.exports.components['views.messages.MessageEvent'] = require('./components/views/messages/MessageEvent');
 | 
			
		||||
module.exports.components['views.messages.TextualBody'] = require('./components/views/messages/TextualBody');
 | 
			
		||||
module.exports.components['views.messages.TextualEvent'] = require('./components/views/messages/TextualEvent');
 | 
			
		||||
module.exports.components['views.messages.UnknownBody'] = require('./components/views/messages/UnknownBody');
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -49,10 +49,16 @@ module.exports = React.createClass({
 | 
			
		|||
        this.props.onChange(this.getValue());
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
    onCustomChange: function(event) {
 | 
			
		||||
    onCustomBlur: function(event) {
 | 
			
		||||
        this.props.onChange(this.getValue());
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
    onCustomKeyDown: function(event) {
 | 
			
		||||
        if (event.key == "Enter") {
 | 
			
		||||
            this.props.onChange(this.getValue());
 | 
			
		||||
        }
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
    getValue: function() {
 | 
			
		||||
        var value;
 | 
			
		||||
        if (this.refs.select) {
 | 
			
		||||
| 
						 | 
				
			
			@ -72,7 +78,7 @@ module.exports = React.createClass({
 | 
			
		|||
                input = <span>{ this.props.value }</span>
 | 
			
		||||
            }
 | 
			
		||||
            else {
 | 
			
		||||
                input = <input ref="custom" type="text" size="3" defaultValue={ this.props.value } onChange={ this.onCustomChange } />
 | 
			
		||||
                input = <input ref="custom" type="text" size="3" defaultValue={ this.props.value } onBlur={ this.onCustomBlur } onKeyDown={ this.onCustomKeyDown }/>
 | 
			
		||||
            }
 | 
			
		||||
            customPicker = <span> of { input }</span>;
 | 
			
		||||
        }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -154,6 +154,7 @@ module.exports = React.createClass({
 | 
			
		|||
        }
 | 
			
		||||
        var defaultLevel = powerLevelEvent.getContent().users_default;
 | 
			
		||||
        var modLevel = me.powerLevel - 1;
 | 
			
		||||
        if (modLevel > 50 && defaultLevel < 50) modLevel = 50; // try to stick with the vector level defaults
 | 
			
		||||
        // toggle the level
 | 
			
		||||
        var newLevel = this.state.isTargetMod ? defaultLevel : modLevel;
 | 
			
		||||
        MatrixClientPeg.get().setPowerLevel(roomId, target, newLevel, powerLevelEvent).done(
 | 
			
		||||
| 
						 | 
				
			
			@ -170,6 +171,36 @@ module.exports = React.createClass({
 | 
			
		|||
        this.props.onFinished();        
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
    onPowerChange: function(powerLevel) {
 | 
			
		||||
        var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
 | 
			
		||||
        var roomId = this.props.member.roomId;
 | 
			
		||||
        var target = this.props.member.userId;
 | 
			
		||||
        var room = MatrixClientPeg.get().getRoom(roomId);
 | 
			
		||||
        if (!room) {
 | 
			
		||||
            this.props.onFinished();
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        var powerLevelEvent = room.currentState.getStateEvents(
 | 
			
		||||
            "m.room.power_levels", ""
 | 
			
		||||
        );
 | 
			
		||||
        if (!powerLevelEvent) {
 | 
			
		||||
            this.props.onFinished();
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        MatrixClientPeg.get().setPowerLevel(roomId, target, powerLevel, powerLevelEvent).done(
 | 
			
		||||
        function() {
 | 
			
		||||
            // NO-OP; rely on the m.room.member event coming down else we could
 | 
			
		||||
            // get out of sync if we force setState here!
 | 
			
		||||
            console.log("Power change success");
 | 
			
		||||
        }, function(err) {
 | 
			
		||||
            Modal.createDialog(ErrorDialog, {
 | 
			
		||||
                title: "Failure to change power level",
 | 
			
		||||
                description: err.message
 | 
			
		||||
            });
 | 
			
		||||
        });
 | 
			
		||||
        this.props.onFinished();        
 | 
			
		||||
    },    
 | 
			
		||||
 | 
			
		||||
    onChatClick: function() {
 | 
			
		||||
        // check if there are any existing rooms with just us and them (1:1)
 | 
			
		||||
        // If so, just view that room. If not, create a private room with them.
 | 
			
		||||
| 
						 | 
				
			
			@ -317,12 +348,11 @@ module.exports = React.createClass({
 | 
			
		|||
    },
 | 
			
		||||
 | 
			
		||||
    render: function() {
 | 
			
		||||
        var interactButton, kickButton, banButton, muteButton, giveModButton, spinner;
 | 
			
		||||
        if (this.props.member.userId === MatrixClientPeg.get().credentials.userId) {
 | 
			
		||||
            interactButton = <div className="mx_MemberInfo_field" onClick={this.onLeaveClick}>Leave room</div>;
 | 
			
		||||
        }
 | 
			
		||||
        else {
 | 
			
		||||
            interactButton = <div className="mx_MemberInfo_field" onClick={this.onChatClick}>Start chat</div>;
 | 
			
		||||
        var startChat, kickButton, banButton, muteButton, giveModButton, spinner;
 | 
			
		||||
        if (this.props.member.userId !== MatrixClientPeg.get().credentials.userId) {
 | 
			
		||||
            // FIXME: we're referring to a vector component from react-sdk
 | 
			
		||||
            var BottomLeftMenuTile = sdk.getComponent('rooms.BottomLeftMenuTile');
 | 
			
		||||
            startChat = <BottomLeftMenuTile collapsed={ false } img="img/create-big.svg" label="Start chat" onClick={ this.onChatClick }/>
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (this.state.creatingRoom) {
 | 
			
		||||
| 
						 | 
				
			
			@ -347,34 +377,52 @@ module.exports = React.createClass({
 | 
			
		|||
            </div>;
 | 
			
		||||
        }
 | 
			
		||||
        if (this.state.can.modifyLevel) {
 | 
			
		||||
            var giveOpLabel = this.state.isTargetMod ? "Revoke Mod" : "Make Mod";
 | 
			
		||||
            var giveOpLabel = this.state.isTargetMod ? "Revoke Moderator" : "Make Moderator";
 | 
			
		||||
            giveModButton = <div className="mx_MemberInfo_field" onClick={this.onModToggle}>
 | 
			
		||||
                {giveOpLabel}
 | 
			
		||||
            </div>
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        var adminTools;
 | 
			
		||||
        if (kickButton || banButton || muteButton || giveModButton) {
 | 
			
		||||
            adminTools = 
 | 
			
		||||
                <div>
 | 
			
		||||
                    <h3>Admin tools</h3>
 | 
			
		||||
 | 
			
		||||
                    <div className="mx_MemberInfo_buttons">
 | 
			
		||||
                        {muteButton}
 | 
			
		||||
                        {kickButton}
 | 
			
		||||
                        {banButton}
 | 
			
		||||
                        {giveModButton}
 | 
			
		||||
                    </div>
 | 
			
		||||
                </div>
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        var MemberAvatar = sdk.getComponent('avatars.MemberAvatar');
 | 
			
		||||
        var PowerSelector = sdk.getComponent('elements.PowerSelector');
 | 
			
		||||
        return (
 | 
			
		||||
            <div className="mx_MemberInfo">
 | 
			
		||||
                <img className="mx_MemberInfo_cancel" src="img/cancel.svg" width="18" height="18" onClick={this.onCancel}/>
 | 
			
		||||
                <div className="mx_MemberInfo_avatar">
 | 
			
		||||
                    <MemberAvatar member={this.props.member} width={48} height={48} />
 | 
			
		||||
                </div>
 | 
			
		||||
 | 
			
		||||
                <h2>{ this.props.member.name }</h2>
 | 
			
		||||
                <div className="mx_MemberInfo_profileField">
 | 
			
		||||
                    { this.props.member.userId }
 | 
			
		||||
                </div>
 | 
			
		||||
                <div className="mx_MemberInfo_profileField">
 | 
			
		||||
                    power: { this.props.member.powerLevelNorm }%
 | 
			
		||||
                </div>
 | 
			
		||||
                <div className="mx_MemberInfo_buttons">
 | 
			
		||||
                    {interactButton}
 | 
			
		||||
                    {muteButton}
 | 
			
		||||
                    {kickButton}
 | 
			
		||||
                    {banButton}
 | 
			
		||||
                    {giveModButton}
 | 
			
		||||
                    {spinner}
 | 
			
		||||
 | 
			
		||||
                <div className="mx_MemberInfo_profile">
 | 
			
		||||
                    <div className="mx_MemberInfo_profileField">
 | 
			
		||||
                        { this.props.member.userId }
 | 
			
		||||
                    </div>
 | 
			
		||||
                    <div className="mx_MemberInfo_profileField">
 | 
			
		||||
                        Level: <b><PowerSelector value={ parseInt(this.props.member.powerLevel) } disabled={ !this.state.can.modifyLevel } onChange={ this.onPowerChange }/></b>
 | 
			
		||||
                    </div>
 | 
			
		||||
                </div>
 | 
			
		||||
 | 
			
		||||
                { startChat }
 | 
			
		||||
 | 
			
		||||
                { adminTools }
 | 
			
		||||
 | 
			
		||||
                { spinner }
 | 
			
		||||
            </div>
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -83,10 +83,7 @@ module.exports = React.createClass({
 | 
			
		|||
        if (!this.props.member) {
 | 
			
		||||
            return this._getDisplayName();
 | 
			
		||||
        }
 | 
			
		||||
        var label = this.props.member.userId;
 | 
			
		||||
        if (this.state.isTargetMod) {
 | 
			
		||||
            label += " - Mod (" + this.props.member.powerLevelNorm + "%)";
 | 
			
		||||
        }
 | 
			
		||||
        var label = this.props.member.userId + " (power " + this.props.member.powerLevel + ")";
 | 
			
		||||
        return label;
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue