thirdroom
thirdroom copied to clipboard
Third Room UI
Third Room is a custom Matrix client built around 3D worlds. The UI is built with React and it uses the Hydrogen Matrix SDK for interacting with Matrix and rendering the chat timelines efficiently.
Here are the high level client UI features and todo items:
- [ ] Landing Page
- [x] Login Page
- [x] Temporary username/password implementation
- [x] Final implementation blocked on OpenID Connect implementation
- [x] Status Bar
- [x] Overlay open / close tip
- [x] Active world name
- [x] Notifications indicator
- [ ] Sidebar
- [x] Fix showing avatars by adding proper COEP header
- [x] Show unread indicator
- [x] Differentiate between world, room, DM, and group message icons?
- [x] Context Menu
- [x] World
- [x] Room
- [x] User (DM)
- [x] World participant list (see who is in a world currently)
- [ ] User presence (see if they are online or not)
- [x] Send room / world / DM invite
- [x] Home Tab
- [x] Basic implementation showing all rooms
- [x] Finalize design with details on which worlds / rooms / dms to show
- [x] Worlds Tab
- [x] Filter worlds only
- [x] Rooms Tab
- [x] Filter rooms only
- [x] Chat Tab
- [x] Filter dms only
- [ ] Settings Tab
- [ ] Figure out if this is the best place for this menu item or if it should be swapped with something else
- [ ] VoIP controls
- [x] Mute mic
- [ ] Mute incoming audio
- [x] Leave world
- [ ] Settings
- [ ] Pick microphone
- [ ] Pick output
- [ ] Active world info
- [x] World avatar
- [x] World name
- [ ] World info (needs design)
- [x] Members list
- [ ] Participants list (who is online)
- [x] Topic
- [ ] Scene info
- [x] Spaces bar
- [x] Disable for now
- [x] In Room Controls
- [x] Mute microphone
- [x] Mute incoming audio
- [x] Leave room
- [ ] In World Chat
- [x] Fade out messages when not open
- [x] Fix loading message on scroll
- [ ] Match designs for open / closed state
- [x] Finalize message bubble design
- [ ] Overlay Chat
- [x] Fix loading message on scroll
- [x] Invite to room
- [ ] Room info
- [ ] Create world screen
- [x] Allow for picking scene file
- [ ] Generate thumbnails for scene
- [ ] Create room screen
- [ ] Standard UI for creating a Matrix room
- [x] User profile screen
- [x] Set display name
- [x] Set avatar
- [x] Set 3D avatar