Merge remote-tracking branch 'origin/develop' into dbkr/missed_accessiblebuttons

pull/21833/head
David Baker 2017-02-14 17:45:30 +00:00
commit e1cb34e255
6 changed files with 156 additions and 74 deletions

View File

@ -149,6 +149,7 @@ class EmailIdentityStage extends Stage {
nextLink nextLink
).then(function(response) { ).then(function(response) {
self.sid = response.sid; self.sid = response.sid;
self.signupInstance.setIdSid(self.sid);
return self._completeVerify(); return self._completeVerify();
}).then(function(request) { }).then(function(request) {
request.poll_for_success = true; request.poll_for_success = true;

View File

@ -77,6 +77,8 @@ import views$dialogs$BaseDialog from './components/views/dialogs/BaseDialog';
views$dialogs$BaseDialog && (module.exports.components['views.dialogs.BaseDialog'] = views$dialogs$BaseDialog); views$dialogs$BaseDialog && (module.exports.components['views.dialogs.BaseDialog'] = views$dialogs$BaseDialog);
import views$dialogs$ChatInviteDialog from './components/views/dialogs/ChatInviteDialog'; import views$dialogs$ChatInviteDialog from './components/views/dialogs/ChatInviteDialog';
views$dialogs$ChatInviteDialog && (module.exports.components['views.dialogs.ChatInviteDialog'] = views$dialogs$ChatInviteDialog); views$dialogs$ChatInviteDialog && (module.exports.components['views.dialogs.ChatInviteDialog'] = views$dialogs$ChatInviteDialog);
import views$dialogs$ConfirmUserActionDialog from './components/views/dialogs/ConfirmUserActionDialog';
views$dialogs$ConfirmUserActionDialog && (module.exports.components['views.dialogs.ConfirmUserActionDialog'] = views$dialogs$ConfirmUserActionDialog);
import views$dialogs$DeactivateAccountDialog from './components/views/dialogs/DeactivateAccountDialog'; import views$dialogs$DeactivateAccountDialog from './components/views/dialogs/DeactivateAccountDialog';
views$dialogs$DeactivateAccountDialog && (module.exports.components['views.dialogs.DeactivateAccountDialog'] = views$dialogs$DeactivateAccountDialog); views$dialogs$DeactivateAccountDialog && (module.exports.components['views.dialogs.DeactivateAccountDialog'] = views$dialogs$DeactivateAccountDialog);
import views$dialogs$ErrorDialog from './components/views/dialogs/ErrorDialog'; import views$dialogs$ErrorDialog from './components/views/dialogs/ErrorDialog';

View File

@ -217,6 +217,12 @@ module.exports = React.createClass({
window.localStorage.getItem('mx_team_token') || window.localStorage.getItem('mx_team_token') ||
window.sessionStorage.getItem('mx_team_token'); window.sessionStorage.getItem('mx_team_token');
// Some users have ended up with "undefined" as their local storage team token,
// treat that as undefined.
if (this._teamToken === "undefined") {
this._teamToken = undefined;
}
if (this._teamToken) { if (this._teamToken) {
console.info(`Team token set to ${this._teamToken}`); console.info(`Team token set to ${this._teamToken}`);
} }
@ -904,14 +910,6 @@ module.exports = React.createClass({
onUserClick: function(event, userId) { onUserClick: function(event, userId) {
event.preventDefault(); event.preventDefault();
// var MemberInfo = sdk.getComponent('rooms.MemberInfo');
// var member = new Matrix.RoomMember(null, userId);
// ContextualMenu.createMenu(MemberInfo, {
// member: member,
// right: window.innerWidth - event.pageX,
// top: event.pageY
// });
var member = new Matrix.RoomMember(null, userId); var member = new Matrix.RoomMember(null, userId);
if (!member) { return; } if (!member) { return; }
dis.dispatch({ dis.dispatch({

View File

@ -0,0 +1,83 @@
/*
Copyright 2017 Vector Creations 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.
*/
import React from 'react';
import sdk from '../../../index';
import classnames from 'classnames';
/*
* A dialog for confirming an operation on another user.
* Takes a user ID and a verb, displays the target user prominently
* such that it should be easy to confirm that the operation is being
* performed on the right person, and displays the operation prominently
* to make it obvious what is going to happen.
* Also tweaks the style for 'dangerous' actions (albeit only with colour)
*/
export default React.createClass({
displayName: 'ConfirmUserActionDialog',
propTypes: {
member: React.PropTypes.object.isRequired, // matrix-js-sdk member object
action: React.PropTypes.string.isRequired, // eg. 'Ban'
danger: React.PropTypes.bool,
onFinished: React.PropTypes.func.isRequired,
},
defaultProps: {
danger: false,
},
onOk: function() {
this.props.onFinished(true);
},
onCancel: function() {
this.props.onFinished(false);
},
render: function() {
const BaseDialog = sdk.getComponent('views.dialogs.BaseDialog');
const MemberAvatar = sdk.getComponent("views.avatars.MemberAvatar");
const title = this.props.action + " this person?";
const confirmButtonClass = classnames({
'mx_Dialog_primary': true,
'danger': this.props.danger,
});
return (
<BaseDialog className="mx_UserActionConfirmDialog" onFinished={this.props.onFinished}
onEnterPressed={ this.onOk }
title={title}
>
<div className="mx_Dialog_content">
<div className="mx_ConfirmUserActionDialog_avatar">
<MemberAvatar member={this.props.member} width={72} height={72} />
</div>
<div className="mx_ConfirmUserActionDialog_name">{this.props.member.name}</div>
<div className="mx_ConfirmUserActionDialog_userId">{this.props.member.userId}</div>
</div>
<div className="mx_Dialog_buttons">
<button className={confirmButtonClass} onClick={this.onOk} autoFocus={true}>
{this.props.action}
</button>
<button onClick={this.onCancel}>
Cancel
</button>
</div>
</BaseDialog>
);
},
});

View File

@ -222,7 +222,8 @@ module.exports = React.createClass({
title: "Add an Integration", title: "Add an Integration",
description: description:
<div> <div>
You are about to taken to a third-party site so you can authenticate your account for use with {integrationsUrl}.<br/> You are about to be taken to a third-party site so you can
authenticate your account for use with {integrationsUrl}.<br/>
Do you wish to continue? Do you wish to continue?
</div>, </div>,
button: "Continue", button: "Continue",

View File

@ -1,5 +1,6 @@
/* /*
Copyright 2015, 2016 OpenMarket Ltd Copyright 2015, 2016 OpenMarket Ltd
Copyright 2017 Vector Creations Ltd
Licensed under the Apache License, Version 2.0 (the "License"); Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License. you may not use this file except in compliance with the License.
@ -25,16 +26,16 @@ limitations under the License.
* 'muted': boolean, * 'muted': boolean,
* 'isTargetMod': boolean * 'isTargetMod': boolean
*/ */
var React = require('react'); import React from 'react';
var classNames = require('classnames'); import classNames from 'classnames';
var dis = require("../../../dispatcher"); import dis from '../../../dispatcher';
var Modal = require("../../../Modal"); import Modal from '../../../Modal';
var sdk = require('../../../index'); import sdk from '../../../index';
var createRoom = require('../../../createRoom'); import createRoom from '../../../createRoom';
var DMRoomMap = require('../../../utils/DMRoomMap'); import DMRoomMap from '../../../utils/DMRoomMap';
var Unread = require('../../../Unread'); import Unread from '../../../Unread';
var Receipt = require('../../../utils/Receipt'); import { findReadReceiptFromUserId } from '../../../utils/Receipt';
var WithMatrixClient = require('../../../wrappers/WithMatrixClient'); import WithMatrixClient from '../../../wrappers/WithMatrixClient';
import AccessibleButton from '../elements/AccessibleButton'; import AccessibleButton from '../elements/AccessibleButton';
module.exports = WithMatrixClient(React.createClass({ module.exports = WithMatrixClient(React.createClass({
@ -43,13 +44,6 @@ module.exports = WithMatrixClient(React.createClass({
propTypes: { propTypes: {
matrixClient: React.PropTypes.object.isRequired, matrixClient: React.PropTypes.object.isRequired,
member: React.PropTypes.object.isRequired, member: React.PropTypes.object.isRequired,
onFinished: React.PropTypes.func,
},
getDefaultProps: function() {
return {
onFinished: function() {}
};
}, },
getInitialState: function() { getInitialState: function() {
@ -164,7 +158,7 @@ module.exports = WithMatrixClient(React.createClass({
onRoomReceipt: function(receiptEvent, room) { onRoomReceipt: function(receiptEvent, room) {
// because if we read a notification, it will affect notification count // because if we read a notification, it will affect notification count
// only bother updating if there's a receipt from us // only bother updating if there's a receipt from us
if (Receipt.findReadReceiptFromUserId(receiptEvent, this.props.matrixClient.credentials.userId)) { if (findReadReceiptFromUserId(receiptEvent, this.props.matrixClient.credentials.userId)) {
this.forceUpdate(); this.forceUpdate();
} }
}, },
@ -224,15 +218,23 @@ module.exports = WithMatrixClient(React.createClass({
}, },
onKick: function() { onKick: function() {
var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); const ConfirmUserActionDialog = sdk.getComponent("dialogs.ConfirmUserActionDialog");
var roomId = this.props.member.roomId; Modal.createDialog(ConfirmUserActionDialog, {
var target = this.props.member.userId; member: this.props.member,
action: 'Kick',
danger: true,
onFinished: (proceed) => {
if (!proceed) return;
this.setState({ updating: this.state.updating + 1 }); this.setState({ updating: this.state.updating + 1 });
this.props.matrixClient.kick(roomId, target).then(function() { this.props.matrixClient.kick(
this.props.member.roomId, this.props.member.userId,
).then(function() {
// NO-OP; rely on the m.room.member event coming down else we could // NO-OP; rely on the m.room.member event coming down else we could
// get out of sync if we force setState here! // get out of sync if we force setState here!
console.log("Kick success"); console.log("Kick success");
}, function(err) { }, function(err) {
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
Modal.createDialog(ErrorDialog, { Modal.createDialog(ErrorDialog, {
title: "Kick error", title: "Kick error",
description: err.message description: err.message
@ -241,29 +243,39 @@ module.exports = WithMatrixClient(React.createClass({
).finally(()=>{ ).finally(()=>{
this.setState({ updating: this.state.updating - 1 }); this.setState({ updating: this.state.updating - 1 });
}); });
this.props.onFinished(); }
});
}, },
onBan: function() { onBan: function() {
var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); const ConfirmUserActionDialog = sdk.getComponent("dialogs.ConfirmUserActionDialog");
var roomId = this.props.member.roomId; Modal.createDialog(ConfirmUserActionDialog, {
var target = this.props.member.userId; member: this.props.member,
action: 'Ban',
danger: true,
onFinished: (proceed) => {
if (!proceed) return;
this.setState({ updating: this.state.updating + 1 }); this.setState({ updating: this.state.updating + 1 });
this.props.matrixClient.ban(roomId, target).then( this.props.matrixClient.ban(
this.props.member.roomId, this.props.member.userId,
).then(
function() { function() {
// NO-OP; rely on the m.room.member event coming down else we could // NO-OP; rely on the m.room.member event coming down else we could
// get out of sync if we force setState here! // get out of sync if we force setState here!
console.log("Ban success"); console.log("Ban success");
}, function(err) { }, function(err) {
const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog");
Modal.createDialog(ErrorDialog, { Modal.createDialog(ErrorDialog, {
title: "Ban error", title: "Ban error",
description: err.message description: err.message,
}); });
} }
).finally(()=>{ ).finally(()=>{
this.setState({ updating: this.state.updating - 1 }); this.setState({ updating: this.state.updating - 1 });
}); });
this.props.onFinished(); },
});
}, },
onMuteToggle: function() { onMuteToggle: function() {
@ -272,14 +284,12 @@ module.exports = WithMatrixClient(React.createClass({
var target = this.props.member.userId; var target = this.props.member.userId;
var room = this.props.matrixClient.getRoom(roomId); var room = this.props.matrixClient.getRoom(roomId);
if (!room) { if (!room) {
this.props.onFinished();
return; return;
} }
var powerLevelEvent = room.currentState.getStateEvents( var powerLevelEvent = room.currentState.getStateEvents(
"m.room.power_levels", "" "m.room.power_levels", ""
); );
if (!powerLevelEvent) { if (!powerLevelEvent) {
this.props.onFinished();
return; return;
} }
var isMuted = this.state.muted; var isMuted = this.state.muted;
@ -314,7 +324,6 @@ module.exports = WithMatrixClient(React.createClass({
this.setState({ updating: this.state.updating - 1 }); this.setState({ updating: this.state.updating - 1 });
}); });
} }
this.props.onFinished();
}, },
onModToggle: function() { onModToggle: function() {
@ -323,19 +332,16 @@ module.exports = WithMatrixClient(React.createClass({
var target = this.props.member.userId; var target = this.props.member.userId;
var room = this.props.matrixClient.getRoom(roomId); var room = this.props.matrixClient.getRoom(roomId);
if (!room) { if (!room) {
this.props.onFinished();
return; return;
} }
var powerLevelEvent = room.currentState.getStateEvents( var powerLevelEvent = room.currentState.getStateEvents(
"m.room.power_levels", "" "m.room.power_levels", ""
); );
if (!powerLevelEvent) { if (!powerLevelEvent) {
this.props.onFinished();
return; return;
} }
var me = room.getMember(this.props.matrixClient.credentials.userId); var me = room.getMember(this.props.matrixClient.credentials.userId);
if (!me) { if (!me) {
this.props.onFinished();
return; return;
} }
var defaultLevel = powerLevelEvent.getContent().users_default; var defaultLevel = powerLevelEvent.getContent().users_default;
@ -366,7 +372,6 @@ module.exports = WithMatrixClient(React.createClass({
).finally(()=>{ ).finally(()=>{
this.setState({ updating: this.state.updating - 1 }); this.setState({ updating: this.state.updating - 1 });
}); });
this.props.onFinished();
}, },
_applyPowerChange: function(roomId, target, powerLevel, powerLevelEvent) { _applyPowerChange: function(roomId, target, powerLevel, powerLevelEvent) {
@ -386,7 +391,6 @@ module.exports = WithMatrixClient(React.createClass({
).finally(()=>{ ).finally(()=>{
this.setState({ updating: this.state.updating - 1 }); this.setState({ updating: this.state.updating - 1 });
}).done(); }).done();
this.props.onFinished();
}, },
onPowerChange: function(powerLevel) { onPowerChange: function(powerLevel) {
@ -396,14 +400,12 @@ module.exports = WithMatrixClient(React.createClass({
var room = this.props.matrixClient.getRoom(roomId); var room = this.props.matrixClient.getRoom(roomId);
var self = this; var self = this;
if (!room) { if (!room) {
this.props.onFinished();
return; return;
} }
var powerLevelEvent = room.currentState.getStateEvents( var powerLevelEvent = room.currentState.getStateEvents(
"m.room.power_levels", "" "m.room.power_levels", ""
); );
if (!powerLevelEvent) { if (!powerLevelEvent) {
this.props.onFinished();
return; return;
} }
if (powerLevelEvent.getContent().users) { if (powerLevelEvent.getContent().users) {
@ -422,9 +424,6 @@ module.exports = WithMatrixClient(React.createClass({
if (confirmed) { if (confirmed) {
self._applyPowerChange(roomId, target, powerLevel, powerLevelEvent); self._applyPowerChange(roomId, target, powerLevel, powerLevelEvent);
} }
else {
self.props.onFinished();
}
}, },
}); });
} }
@ -440,7 +439,6 @@ module.exports = WithMatrixClient(React.createClass({
onNewDMClick: function() { onNewDMClick: function() {
this.setState({ updating: this.state.updating + 1 }); this.setState({ updating: this.state.updating + 1 });
createRoom({dmUserId: this.props.member.userId}).finally(() => { createRoom({dmUserId: this.props.member.userId}).finally(() => {
this.props.onFinished();
this.setState({ updating: this.state.updating - 1 }); this.setState({ updating: this.state.updating - 1 });
}).done(); }).done();
}, },
@ -450,7 +448,6 @@ module.exports = WithMatrixClient(React.createClass({
action: 'leave_room', action: 'leave_room',
room_id: this.props.member.roomId, room_id: this.props.member.roomId,
}); });
this.props.onFinished();
}, },
_calculateOpsPermissions: function(member) { _calculateOpsPermissions: function(member) {