mirror of
https://github.com/vector-im/hydrogen-web.git
synced 2025-01-17 07:47:00 +01:00
45 lines
1.7 KiB
JavaScript
45 lines
1.7 KiB
JavaScript
import GapTile from "./tiles/GapTile.js";
|
|
import TextTile from "./tiles/TextTile.js";
|
|
import ImageTile from "./tiles/ImageTile.js";
|
|
import LocationTile from "./tiles/LocationTile.js";
|
|
import RoomNameTile from "./tiles/RoomNameTile.js";
|
|
import RoomMemberTile from "./tiles/RoomMemberTile.js";
|
|
|
|
export default function ({timeline, ownUserId}) {
|
|
return function tilesCreator(entry, emitUpdate) {
|
|
const options = {entry, emitUpdate, ownUserId};
|
|
if (entry.isGap) {
|
|
return new GapTile(options, timeline);
|
|
} else if (entry.event) {
|
|
const event = entry.event;
|
|
switch (event.type) {
|
|
case "m.room.message": {
|
|
const content = event.content;
|
|
const msgtype = content && content.msgtype;
|
|
switch (msgtype) {
|
|
case "m.text":
|
|
case "m.notice":
|
|
case "m.emote":
|
|
return new TextTile(options);
|
|
case "m.image":
|
|
return null; // not supported yet
|
|
// return new ImageTile(options);
|
|
case "m.location":
|
|
return new LocationTile(options);
|
|
default:
|
|
// unknown msgtype not rendered
|
|
return null;
|
|
}
|
|
}
|
|
case "m.room.name":
|
|
return new RoomNameTile(options);
|
|
case "m.room.member":
|
|
return new RoomMemberTile(options);
|
|
default:
|
|
// unknown type not rendered
|
|
return null;
|
|
}
|
|
}
|
|
}
|
|
}
|