feat: improve chat room UI and scrolling behavior
- Added automatic scrolling to bottom of messages in chat room - Updated CSS to handle app and chat container height more precisely - Implemented scrollToBottom function for messages container - Ensured messages scroll automatically on new message or send - Removed unnecessary port mapping in docker-compose.yml
This commit is contained in:
		
							parent
							
								
									1e5a035d33
								
							
						
					
					
						commit
						1e3b188d90
					
				
					 3 changed files with 22 additions and 5 deletions
				
			
		|  | @ -65,7 +65,8 @@ body { | |||
| .app { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   min-height: 100vh; | ||||
|   height: calc(100vh - 4rem); | ||||
|   overflow: hidden; | ||||
| } | ||||
| 
 | ||||
| .app-header { | ||||
|  | @ -81,6 +82,8 @@ body { | |||
| .app-main { | ||||
|   flex: 1; | ||||
|   padding: 1rem; | ||||
|   height: 100%; | ||||
|   overflow: hidden; | ||||
| } | ||||
| 
 | ||||
| /* Auth styles */ | ||||
|  | @ -185,7 +188,8 @@ button:disabled { | |||
| /* Chat styles */ | ||||
| .chat-container { | ||||
|   display: flex; | ||||
|   height: calc(100vh - 120px); | ||||
|   height: 100%; | ||||
|   max-height: calc(100vh - 120px); | ||||
|   background-color: var(--card-background); | ||||
|   border-radius: 0.5rem; | ||||
|   overflow: hidden; | ||||
|  |  | |||
|  | @ -80,6 +80,13 @@ export function ChatRoom(props: ChatRoomProps) { | |||
|   const [messages, setMessages] = createSignal<Message[]>([]); | ||||
|   const [confirmLeave, setConfirmLeave] = createSignal(false); | ||||
|   const [leaveError, setLeaveError] = createSignal<string | null>(null); | ||||
|   let messagesContainer: HTMLDivElement | undefined; | ||||
| 
 | ||||
|   const scrollToBottom = () => { | ||||
|     if (messagesContainer) { | ||||
|       messagesContainer.scrollTop = messagesContainer.scrollHeight; | ||||
|     } | ||||
|   }; | ||||
| 
 | ||||
|   // Query room details
 | ||||
|   const [roomQuery] = createQuery({ | ||||
|  | @ -121,12 +128,19 @@ export function ChatRoom(props: ChatRoomProps) { | |||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   createEffect(() => { | ||||
|     if (messages().length > 0) { | ||||
|       scrollToBottom(); | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   // Handle new messages from subscription
 | ||||
|   createEffect(() => { | ||||
|     const result = messageSubscription; | ||||
|     if (result.data?.messageAdded) { | ||||
|       const newMessage = result.data.messageAdded; | ||||
|       setMessages((prev) => [...prev, newMessage]); | ||||
|       scrollToBottom(); | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|  | @ -149,6 +163,7 @@ export function ChatRoom(props: ChatRoomProps) { | |||
|         roomId: props.roomId, | ||||
|       }); | ||||
|       setMessage(''); | ||||
|       scrollToBottom(); | ||||
|     } catch (error) { | ||||
|       console.error('Failed to send message:', error); | ||||
|     } | ||||
|  | @ -209,7 +224,7 @@ export function ChatRoom(props: ChatRoomProps) { | |||
|         </div> | ||||
|       </Show> | ||||
| 
 | ||||
|       <div class='chat-messages'> | ||||
|       <div class='chat-messages' ref={messagesContainer}> | ||||
|         <Show | ||||
|           when={!roomQuery.fetching} | ||||
|           fallback={<div>Loading messages...</div>} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue