mirror of https://github.com/vector-im/riot-web
API Change: better fallback for room avatars
parent
549d992293
commit
7e93b75aa0
|
@ -18,6 +18,12 @@ limitations under the License.
|
||||||
|
|
||||||
var MatrixClientPeg = require('../../MatrixClientPeg');
|
var MatrixClientPeg = require('../../MatrixClientPeg');
|
||||||
|
|
||||||
|
/*
|
||||||
|
* View class should provide:
|
||||||
|
* - getUrlList() returning an array of URLs to try for the room avatar
|
||||||
|
in order of preference from the most preferred at index 0. null entries
|
||||||
|
in the array will be skipped over.
|
||||||
|
*/
|
||||||
module.exports = {
|
module.exports = {
|
||||||
getDefaultProps: function() {
|
getDefaultProps: function() {
|
||||||
return {
|
return {
|
||||||
|
@ -27,35 +33,69 @@ module.exports = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
avatarUrlForRoom: function(room) {
|
getInitialState: function() {
|
||||||
var url = room.getAvatarUrl(
|
this.urlList = this.getUrlList();
|
||||||
|
this.urlListIndex = -1;
|
||||||
|
return {
|
||||||
|
imageUrl: this._nextUrl()
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
_nextUrl: function() {
|
||||||
|
do {
|
||||||
|
++this.urlListIndex;
|
||||||
|
} while (
|
||||||
|
this.urlList[this.urlListIndex] === null &&
|
||||||
|
this.urlListIndex < this.urlList.length
|
||||||
|
);
|
||||||
|
if (this.urlListIndex < this.urlList.length) {
|
||||||
|
return this.urlList[this.urlListIndex];
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
// provided to the view class for convenience
|
||||||
|
roomAvatarUrl: function() {
|
||||||
|
var url = this.props.room.getAvatarUrl(
|
||||||
MatrixClientPeg.get().getHomeserverUrl(),
|
MatrixClientPeg.get().getHomeserverUrl(),
|
||||||
this.props.width, this.props.height, this.props.resizeMethod,
|
this.props.width, this.props.height, this.props.resizeMethod,
|
||||||
false
|
false
|
||||||
);
|
);
|
||||||
if (url === null) {
|
|
||||||
url = this.defaultAvatarUrl(room);
|
|
||||||
}
|
|
||||||
return url;
|
return url;
|
||||||
},
|
},
|
||||||
|
|
||||||
defaultAvatarUrl: function(member) {
|
// provided to the view class for convenience
|
||||||
return "";
|
getOneToOneAvatar: function() {
|
||||||
|
var userIds = Object.keys(this.props.room.currentState.members);
|
||||||
|
|
||||||
|
if (userIds.length == 2) {
|
||||||
|
var theOtherGuy = null;
|
||||||
|
if (this.props.room.currentState.members[userIds[0]].userId == MatrixClientPeg.get().credentials.userId) {
|
||||||
|
theOtherGuy = this.props.room.currentState.members[userIds[1]];
|
||||||
|
} else {
|
||||||
|
theOtherGuy = this.props.room.currentState.members[userIds[0]];
|
||||||
|
}
|
||||||
|
return theOtherGuy.getAvatarUrl(
|
||||||
|
MatrixClientPeg.get().getHomeserverUrl(),
|
||||||
|
this.props.width, this.props.height, this.props.resizeMethod,
|
||||||
|
false
|
||||||
|
);
|
||||||
|
} else if (userIds.length == 1) {
|
||||||
|
return this.props.room.currentState.members[userIds[0]].getAvatarUrl(
|
||||||
|
MatrixClientPeg.get().getHomeserverUrl(),
|
||||||
|
this.props.width, this.props.height, this.props.resizeMethod,
|
||||||
|
false
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
onError: function(ev) {
|
onError: function(ev) {
|
||||||
// don't tightloop if the browser can't load a data url
|
|
||||||
if (ev.target.src == this.defaultAvatarUrl(this.props.room)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
this.setState({
|
this.setState({
|
||||||
imageUrl: this.defaultAvatarUrl(this.props.room)
|
imageUrl: this._nextUrl()
|
||||||
});
|
});
|
||||||
},
|
|
||||||
|
|
||||||
getInitialState: function() {
|
|
||||||
return {
|
|
||||||
imageUrl: this.avatarUrlForRoom(this.props.room)
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue