mirror of
https://github.com/vector-im/hydrogen-web.git
synced 2025-01-18 08:11:41 +01:00
Roll back to using heroes for computing DM color
This commit is contained in:
parent
d0f70cbdf9
commit
ee1f1500e9
@ -69,7 +69,7 @@ export class BaseTileViewModel extends ViewModel {
|
|||||||
}
|
}
|
||||||
|
|
||||||
get avatarColorNumber() {
|
get avatarColorNumber() {
|
||||||
return getIdentifierColorNumber(this._avatarSource.id);
|
return getIdentifierColorNumber(this._avatarSource.avatarColorId);
|
||||||
}
|
}
|
||||||
|
|
||||||
avatarUrl(size) {
|
avatarUrl(size) {
|
||||||
|
@ -15,7 +15,6 @@ See the License for the specific language governing permissions and
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {getIdentifierColorNumber} from "../../avatar.js";
|
|
||||||
import {BaseTileViewModel} from "./BaseTileViewModel.js";
|
import {BaseTileViewModel} from "./BaseTileViewModel.js";
|
||||||
|
|
||||||
export class RoomTileViewModel extends BaseTileViewModel {
|
export class RoomTileViewModel extends BaseTileViewModel {
|
||||||
@ -76,10 +75,6 @@ export class RoomTileViewModel extends BaseTileViewModel {
|
|||||||
return timeDiff;
|
return timeDiff;
|
||||||
}
|
}
|
||||||
|
|
||||||
get avatarColorNumber() {
|
|
||||||
return getIdentifierColorNumber(this._room.avatarColorId);
|
|
||||||
}
|
|
||||||
|
|
||||||
get isUnread() {
|
get isUnread() {
|
||||||
return this._room.isUnread;
|
return this._room.isUnread;
|
||||||
}
|
}
|
||||||
|
@ -341,8 +341,14 @@ export class BaseRoom extends EventEmitter {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the identifier that should be used to color
|
||||||
|
* this room's avatar. By default this is the room's
|
||||||
|
* ID, but DM rooms should be the same color as their
|
||||||
|
* user's avatar.
|
||||||
|
*/
|
||||||
get avatarColorId() {
|
get avatarColorId() {
|
||||||
return this._summary.data.avatarColorId;
|
return this._roomId;
|
||||||
}
|
}
|
||||||
|
|
||||||
get lastMessageTimestamp() {
|
get lastMessageTimestamp() {
|
||||||
|
@ -179,6 +179,7 @@ export class Invite extends EventEmitter {
|
|||||||
_createData(inviteState, myInvite, inviter, summaryData, heroes) {
|
_createData(inviteState, myInvite, inviter, summaryData, heroes) {
|
||||||
const name = heroes ? heroes.roomName : summaryData.name;
|
const name = heroes ? heroes.roomName : summaryData.name;
|
||||||
const avatarUrl = heroes ? heroes.roomAvatarUrl : summaryData.avatarUrl;
|
const avatarUrl = heroes ? heroes.roomAvatarUrl : summaryData.avatarUrl;
|
||||||
|
const avatarColorId = heroes ? heroes.roomAvatarColorId : this.id;
|
||||||
return {
|
return {
|
||||||
roomId: this.id,
|
roomId: this.id,
|
||||||
isEncrypted: !!summaryData.encryption,
|
isEncrypted: !!summaryData.encryption,
|
||||||
@ -186,7 +187,7 @@ export class Invite extends EventEmitter {
|
|||||||
// type:
|
// type:
|
||||||
name,
|
name,
|
||||||
avatarUrl,
|
avatarUrl,
|
||||||
avatarColorId: summaryData.avatarColorId,
|
avatarColorId,
|
||||||
canonicalAlias: summaryData.canonicalAlias,
|
canonicalAlias: summaryData.canonicalAlias,
|
||||||
timestamp: this._platform.clock.now(),
|
timestamp: this._platform.clock.now(),
|
||||||
joinRule: this._getJoinRule(inviteState),
|
joinRule: this._getJoinRule(inviteState),
|
||||||
|
@ -328,6 +328,10 @@ export class Room extends BaseRoom {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get avatarColorId() {
|
||||||
|
return this._heroes?.roomAvatarColorId || this._roomId;
|
||||||
|
}
|
||||||
|
|
||||||
get isUnread() {
|
get isUnread() {
|
||||||
return this._summary.data.isUnread;
|
return this._summary.data.isUnread;
|
||||||
}
|
}
|
||||||
|
@ -239,15 +239,6 @@ export class SummaryData {
|
|||||||
return !this.name && !this.canonicalAlias && this.heroes && this.heroes.length > 0;
|
return !this.name && !this.canonicalAlias && this.heroes && this.heroes.length > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
get avatarColorId() {
|
|
||||||
if (this.heroes && this.heroes.length === 1) {
|
|
||||||
for (const hero of this.heroes) {
|
|
||||||
return hero;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return this.roomId;
|
|
||||||
}
|
|
||||||
|
|
||||||
isNewJoin(oldData) {
|
isNewJoin(oldData) {
|
||||||
return this.membership === "join" && oldData.membership !== "join";
|
return this.membership === "join" && oldData.membership !== "join";
|
||||||
}
|
}
|
||||||
|
@ -97,4 +97,13 @@ export class Heroes {
|
|||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get roomAvatarColorId() {
|
||||||
|
if (this._members.size === 1) {
|
||||||
|
for (const member of this._members.keys()) {
|
||||||
|
return member
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user