Merge remote-tracking branch 'origin/develop' into dbkr/dont_crash_if_room_tag_value_null
commit
cc08179b5d
|
@ -71,6 +71,23 @@ export default class MessageComposer extends React.Component {
|
||||||
// XXX: fragile as all hell - fixme somehow, perhaps with a dedicated Room.encryption event or something.
|
// XXX: fragile as all hell - fixme somehow, perhaps with a dedicated Room.encryption event or something.
|
||||||
MatrixClientPeg.get().on("event", this.onEvent);
|
MatrixClientPeg.get().on("event", this.onEvent);
|
||||||
this._roomStoreToken = RoomViewStore.addListener(this._onRoomViewStoreUpdate);
|
this._roomStoreToken = RoomViewStore.addListener(this._onRoomViewStoreUpdate);
|
||||||
|
this._waitForOwnMember();
|
||||||
|
}
|
||||||
|
|
||||||
|
_waitForOwnMember() {
|
||||||
|
// if we have the member already, do that
|
||||||
|
const me = this.props.room.getMember(MatrixClientPeg.get().getUserId());
|
||||||
|
if (me) {
|
||||||
|
this.setState({me});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Otherwise, wait for member loading to finish and then update the member for the avatar.
|
||||||
|
// The members should already be loading, and loadMembersIfNeeded
|
||||||
|
// will return the promise for the existing operation
|
||||||
|
this.props.room.loadMembersIfNeeded().then(() => {
|
||||||
|
const me = this.props.room.getMember(MatrixClientPeg.get().getUserId());
|
||||||
|
this.setState({me});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
componentWillUnmount() {
|
componentWillUnmount() {
|
||||||
|
@ -208,7 +225,6 @@ export default class MessageComposer extends React.Component {
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const me = this.props.room.getMember(MatrixClientPeg.get().credentials.userId);
|
|
||||||
const uploadInputStyle = {display: 'none'};
|
const uploadInputStyle = {display: 'none'};
|
||||||
const MemberAvatar = sdk.getComponent('avatars.MemberAvatar');
|
const MemberAvatar = sdk.getComponent('avatars.MemberAvatar');
|
||||||
const TintableSvg = sdk.getComponent("elements.TintableSvg");
|
const TintableSvg = sdk.getComponent("elements.TintableSvg");
|
||||||
|
@ -216,11 +232,13 @@ export default class MessageComposer extends React.Component {
|
||||||
|
|
||||||
const controls = [];
|
const controls = [];
|
||||||
|
|
||||||
controls.push(
|
if (this.state.me) {
|
||||||
<div key="controls_avatar" className="mx_MessageComposer_avatar">
|
controls.push(
|
||||||
<MemberAvatar member={me} width={24} height={24} />
|
<div key="controls_avatar" className="mx_MessageComposer_avatar">
|
||||||
</div>,
|
<MemberAvatar member={this.state.me} width={24} height={24} />
|
||||||
);
|
</div>,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
let e2eImg, e2eTitle, e2eClass;
|
let e2eImg, e2eTitle, e2eClass;
|
||||||
const roomIsEncrypted = MatrixClientPeg.get().isRoomEncrypted(this.props.room.roomId);
|
const roomIsEncrypted = MatrixClientPeg.get().isRoomEncrypted(this.props.room.roomId);
|
||||||
|
|
|
@ -94,6 +94,7 @@ describe('RoomList', () => {
|
||||||
createRoom({tags: {'m.lowpriority': {}}, name: 'Some unimportant room'}),
|
createRoom({tags: {'m.lowpriority': {}}, name: 'Some unimportant room'}),
|
||||||
createRoom({tags: {'custom.tag': {}}, name: 'Some room customly tagged'}),
|
createRoom({tags: {'custom.tag': {}}, name: 'Some room customly tagged'}),
|
||||||
];
|
];
|
||||||
|
client.getVisibleRooms = client.getRooms;
|
||||||
|
|
||||||
const roomMap = {};
|
const roomMap = {};
|
||||||
client.getRooms().forEach((r) => {
|
client.getRooms().forEach((r) => {
|
||||||
|
|
|
@ -74,6 +74,7 @@ export function createTestClient() {
|
||||||
getPushActionsForEvent: sinon.stub(),
|
getPushActionsForEvent: sinon.stub(),
|
||||||
getRoom: sinon.stub().returns(mkStubRoom()),
|
getRoom: sinon.stub().returns(mkStubRoom()),
|
||||||
getRooms: sinon.stub().returns([]),
|
getRooms: sinon.stub().returns([]),
|
||||||
|
getVisibleRooms: sinon.stub().returns([]),
|
||||||
getGroups: sinon.stub().returns([]),
|
getGroups: sinon.stub().returns([]),
|
||||||
loginFlows: sinon.stub(),
|
loginFlows: sinon.stub(),
|
||||||
on: sinon.stub(),
|
on: sinon.stub(),
|
||||||
|
|
Loading…
Reference in New Issue