|  |  |  | @ -1,9 +1,25 @@ | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | const chat_ws_scheme = window.location.protocol === "https:" ? "wss" : "ws"; | 
		
	
		
			
				|  |  |  |  | const domain = "192.168.1.106:8000"; | 
		
	
		
			
				|  |  |  |  | const osichatSocketUrl = `${chat_ws_scheme}://${domain}/ws/osichat/`; | 
		
	
		
			
				|  |  |  |  | const osichatSocket = new WebSocket(osichatSocketUrl); | 
		
	
		
			
				|  |  |  |  | console.log('hi') | 
		
	
		
			
				|  |  |  |  | // Function to fetch session ID
 | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | async function fetchSessionID() { | 
		
	
		
			
				|  |  |  |  |     try { | 
		
	
		
			
				|  |  |  |  |         const response = await fetch('http://192.168.1.106:3000/get-client-session/');  | 
		
	
		
			
				|  |  |  |  |         const data = await response.json(); | 
		
	
		
			
				|  |  |  |  |         return data.session_id; | 
		
	
		
			
				|  |  |  |  |     } catch (error) { | 
		
	
		
			
				|  |  |  |  |         console.error('Error fetching session ID:', error); | 
		
	
		
			
				|  |  |  |  |         return 'Unknown'; | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | // Function to initialize WebSocket connection
 | 
		
	
		
			
				|  |  |  |  | async function initializeChatWebSocket() { | 
		
	
		
			
				|  |  |  |  |     const session_id = await fetchSessionID(); | 
		
	
		
			
				|  |  |  |  |     const osichatSocketUrl = `${chat_ws_scheme}://${domain}/ws/osichat/${session_id}/`; | 
		
	
		
			
				|  |  |  |  |     const osichatSocket = new WebSocket(osichatSocketUrl); | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     osichatSocket.onopen = () => { | 
		
	
		
			
				|  |  |  |  |         console.log('WebSocket connection to osichat established'); | 
		
	
	
		
			
				
					|  |  |  | @ -22,7 +38,6 @@ osichatSocket.onmessage = function (e) { | 
		
	
		
			
				|  |  |  |  |             script.src = `http://${domain}/static/js/osichat/chat-toggle.js`; | 
		
	
		
			
				|  |  |  |  |             chatDiv.appendChild(script); | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |             const startChatContainer = document.getElementById('startChat'); | 
		
	
		
			
				|  |  |  |  |             // If this container exists then the template returned was start-conversation.html, no conversation yet.
 | 
		
	
		
			
				|  |  |  |  |             if (startChatContainer) { | 
		
	
	
		
			
				
					|  |  |  | @ -48,14 +63,12 @@ osichatSocket.onmessage = function (e) { | 
		
	
		
			
				|  |  |  |  |             if (sendMessageContainer) { | 
		
	
		
			
				|  |  |  |  |                 sendMessageContainer.addEventListener('submit', function (event) { | 
		
	
		
			
				|  |  |  |  |                     event.preventDefault(); | 
		
	
		
			
				|  |  |  |  |                 console.log('i am here') | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |                     const message = event.target.elements.message.value; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |                     const eventMessage = { | 
		
	
		
			
				|  |  |  |  |                         'event_type': 'send_message', | 
		
	
		
			
				|  |  |  |  |                         'message': message, | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |                     }; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |                     osichatSocket.send(JSON.stringify(eventMessage)); | 
		
	
	
		
			
				
					|  |  |  | @ -73,7 +86,6 @@ osichatSocket.onmessage = function (e) { | 
		
	
		
			
				|  |  |  |  |             const messagesDiv = document.getElementById('messages'); | 
		
	
		
			
				|  |  |  |  |             const html = data.html; | 
		
	
		
			
				|  |  |  |  |             messagesDiv.insertAdjacentHTML('beforeend', html); | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |     }; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
	
		
			
				
					|  |  |  | @ -84,5 +96,9 @@ osichatSocket.onclose = () => { | 
		
	
		
			
				|  |  |  |  |     osichatSocket.onerror = (error) => { | 
		
	
		
			
				|  |  |  |  |         console.log('WebSocket error:', error); | 
		
	
		
			
				|  |  |  |  |     }; | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | document.addEventListener('DOMContentLoaded', () => { | 
		
	
		
			
				|  |  |  |  |     initializeChatWebSocket(); | 
		
	
		
			
				|  |  |  |  | }); | 
		
	
	
		
			
				
					|  |  |  | 
 |