Skip to content

Commit

Permalink
fix(chat ui):fixed ui for the chat
Browse files Browse the repository at this point in the history
  • Loading branch information
k3lly003 committed Jul 11, 2024
1 parent 6f44a43 commit 3385687
Show file tree
Hide file tree
Showing 12 changed files with 90 additions and 184 deletions.
39 changes: 0 additions & 39 deletions src/__tests__/formatTime.test.tsx

This file was deleted.

6 changes: 3 additions & 3 deletions src/app/globals.css
Original file line number Diff line number Diff line change
Expand Up @@ -241,9 +241,9 @@ body {}
}

/* Scroll */
.o-hidden{overflow: hidden !important;}
/* .o-hidden{overflow: hidden !important;}
.o-x-scroll{overflow-y: scroll !important;}
.opacity-0{opacity: 0 !important;}
.opacity-0{opacity: 0 !important;} */
/* doubleshricked*/
/* width */
.scroll-double-shrinked::-webkit-scrollbar {
Expand All @@ -264,4 +264,4 @@ body {}
margin-top: 4px !important ;
margin-bottom: 4px !important ;
height: 90% !important;
}
}
68 changes: 29 additions & 39 deletions src/app/page.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
'use client';

import React, { useState, useEffect, useRef } from 'react';
import { useForm } from 'react-hook-form';
import { zodResolver } from '@hookform/resolvers/zod';
Expand All @@ -7,15 +8,15 @@ import Header from '@/components/Header';
import HeroSection from '@/components/HeroSection';
import { LatestSection } from '@/components/LatestSection';
import Footer from '@/components/Footer';
import { MdOutlineChat } from 'react-icons/md';
import { IoMdClose } from 'react-icons/io';

import { HomeAds } from '@/components/HomeAds';

import { ProductWithFilter } from '@/components/allProducts';
import Link from 'next/link';
import ChatRoomsList from '@/components/ChatRoomsList';
import ChatPopUp from '@/hooks/ChatPopUp';
import ChatWrapper from '@/components/chatWrapper';

import Link from 'next/link';
import { MdOutlineChat } from 'react-icons/md';
import { checkUserLoggedIn } from '@/components/isLogged';

export interface FormDataType {
confirmPassword: string;
Expand All @@ -24,9 +25,8 @@ export interface FormDataType {
}

export default function Home() {
// const [isOpen, setIsOpen] = useState(false);
const [showlModal, setShowmodal] = useState(false);
const { isChatPopUpOpen, setIsChatPopUpOpen, toggleChatPopUp } = ChatPopUp();
const [showlModal, setShowmodal] = useState(false);
const {
register,
handleSubmit,
Expand All @@ -43,42 +43,12 @@ export default function Home() {
reset();
};

// function handlePopUp(): void {
// setIsOpen(!isOpen);
// }

return (
<div className="sm:flex sm:justify-center sm:items-center sm:flex-col">
<Header />
<HeroSection />
<main className="flex flex-col items-center justify-between ">
{/* <div className="sm:flex h-[20px] gap-10">
<div>
<button
className=" w-auto"
onClick={() => setShowmodal(!showlModal)}
>
change password
</button>
</div>
</div> */}
</main>
{/* Startttttttt */}
<div className='absolute right-5 w-full flex justify-end items-end'>
<div className="fixed bottom-20 z-50 h-[30rem] w-full max-w-[20%] ">
<div className="fixed bottom-5 right-0 z-10 p-4 bg-green-300 rounded-full">
<MdOutlineChat
className="text-4xl cursor-pointer z-20"
onClick={toggleChatPopUp}
/>
</div>
{isChatPopUpOpen && (
// <ChatRoomsList chatrooms= {chatrooms} currentUser = {currentUser as string}/>
<ChatWrapper />
)}
</div>
</div>
{/* Enddddddddd */}
<main className="flex flex-col items-center justify-between "></main>

{/* The Image adds */}
<HomeAds />
{/* LAtest Product */}
Expand All @@ -98,6 +68,26 @@ export default function Home() {
</Link>
</div>
</div>
{/* Startttttttt */}
<div className="absolute right-5 w-full flex justify-end items-end">
{checkUserLoggedIn() && (
<div className="fixed bottom-5 right-0 z-10 p-4 bg-green-300 rounded-full">
<MdOutlineChat
className="text-4xl cursor-pointer z-20"
onClick={toggleChatPopUp}
/>
</div>
)}
<div
className={`${isChatPopUpOpen ? 'block fixed bottom-24' : 'hidden'} h-[30rem] w-full max-w-[20%]`}
>
{isChatPopUpOpen && (
// <ChatRoomsList chatrooms= {chatrooms} currentUser = {currentUser as string}/>
<ChatWrapper />
)}
</div>
</div>
{/* Enddddddddd */}
{/* Footer Sections */}
<Footer />
</div>
Expand Down
2 changes: 1 addition & 1 deletion src/components/ChatConversation.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ const allMessagesList = messages.map((message:Message)=>{
toogleDislay={toogleDislay}
/>
</div>
<div className="h-[78%] w-full p-2 o-x-hidden o-x-scroll scroll-double-shrinked">
<div className="h-[78%] w-full p-2 overflow-hidden overflow-y-auto scroll-double-shrinked">
{allMessagesList}
</div>
<div className="h-[10%] w-full border">
Expand Down
10 changes: 2 additions & 8 deletions src/components/ChatRoomsList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,16 +23,10 @@ const ChatRoomsList:React.FC<chatroomsLists>=({chatrooms, currentUser, toogleDis
))
return (
<>
<h2 className="flex justify-center self-center text-bold text-2xl py-3">
<h2 className="flex justify-center self-center text-bold text-2xl py-5 bg-gray-100">
Messages
</h2>
<div className="w-full flex justify-center items-center">
<input
type="text"
className="rounded-full border bg-gray-200 h-10 w-full max-w-[70%]"
/>
</div>
<hr className="my-3" />
<hr />
<div>
{ListOfChatRooms}
</div>
Expand Down
37 changes: 1 addition & 36 deletions src/components/DashboardHeader.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
'use client';
import React, { useEffect, useState } from 'react';
import React, { useState } from 'react';
import { CiBellOn } from 'react-icons/ci';
import { GiHamburgerMenu } from 'react-icons/gi';
import { useQuery } from '@tanstack/react-query';
Expand Down Expand Up @@ -32,41 +32,6 @@ const DashboardHeader: React.FC<HeaderInterface> = ({ pageName }) => {
setOverlayComponent('notification');
};
const user = data?.User as userData;
// const { isChatPopUpOpen, setIsChatPopUpOpen, toggleChatPopUp } = ChatPopUp();
// const [currentUser, setCurrentUser] = useState(getCurrentUser());
// const [currentUserToken, setCurrentUserToken] = useState('');
// const [chatrooms, setChatrooms] = useState([]);


// useEffect(() => {
// const token = localStorage.getItem('token');
// if (token) {
// const trimmedToken = token.split(' ')[1];
// setCurrentUserToken(trimmedToken);

// socket = io(`${process.env.URL__CHAT}`, {
// auth: { token: trimmedToken },
// });

// socket.on('connect', () => {
// socket.emit('fetch all chatrooms');
// });

// socket.on('connect_error', (err) => {
// console.error('Socket connection error:', err);

// });

// socket.on('all chatrooms', (receivedChatrooms) => {
// setChatrooms(receivedChatrooms);
// });

// return () => {
// socket.off('all chatrooms');
// socket.disconnect();
// };
// }
// }, [currentUserToken]);

const handleCloseOverlay = () => {
setOverlayComponent(null);
Expand Down
47 changes: 25 additions & 22 deletions src/components/LayoutDashboard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ import React, { FC, useEffect, useState } from 'react';
import DashNavbar from '@/components/DashNavbar';
import HeaderDash from '@/components/headerDash';
import { useRouter } from 'next/navigation';
import ChatWrapper from './chatWrapper';
import { MdOutlineChat } from 'react-icons/md';
import ChatPopUp from '@/hooks/ChatPopUp';
import ChatWrapper from './chatWrapper';
interface Properties {
children: React.ReactNode;
pageName: string;
Expand All @@ -16,6 +16,7 @@ const LayoutDashboard: React.FC<Properties> = ({
pageName,
isLoading,
}) => {
const { isChatPopUpOpen, setIsChatPopUpOpen, toggleChatPopUp } = ChatPopUp();
const [user, setUser] = useState<any>();
const router = useRouter();
useEffect(() => {
Expand All @@ -33,46 +34,48 @@ const LayoutDashboard: React.FC<Properties> = ({
};
categ();
}, []);
const { isChatPopUpOpen, setIsChatPopUpOpen, toggleChatPopUp } = ChatPopUp();

return (
<div className="w-full flex sm:flex-row flex-col fixed ">
<div className="z-50">
<DashNavbar role={user?.Role?.name} />
</div>
<div className="flex-1 sm:pt-5 h-screen sm:relative w-full z-10 ">
<div className="mb-1 ">
<HeaderDash pageName={pageName} />
<>
<div className="w-full flex sm:flex-row flex-col fixed ">
<div className="z-50">
<DashNavbar role={user?.Role?.name} />
</div>
<div className="flex justify-center sm:justify-start sm:items-start overflow-auto h-[90vh] fixed sm:relative w-full sm:pb-10 pb-20 z-0">
{/* Statistic section */}
<div className="w-full relative flex flex-col gap-5 items-center sm:px-7 sm:justify-start sm:items-start z-10">
{!isLoading ? (
children
) : (
<div className="min-h-screen w-full justify-center items-center flex">
<div className="border-t-4 border-b-4 border-blue-600 rounded-full w-20 h-20 animate-spin m-auto"></div>
</div>
)}
<div className="flex-1 sm:pt-5 h-screen sm:relative w-full z-10 ">
<div className="mb-1 ">
<HeaderDash pageName={pageName} />
</div>
<div className="flex justify-center sm:justify-start sm:items-start overflow-auto h-[90vh] fixed sm:relative w-full sm:pb-10 pb-20 z-0">
{/* Statistic section */}
<div className="w-full relative flex flex-col gap-5 items-center sm:px-7 sm:justify-start sm:items-start z-10">
{!isLoading ? (
children
) : (
<div className="min-h-screen w-full justify-center items-center flex">
<div className="border-t-4 border-b-4 border-blue-600 rounded-full w-20 h-20 animate-spin m-auto"></div>
</div>
)}
</div>
</div>
</div>
</div>
{/* Startttttttt */}
<div className='absolute right-5 w-full flex justify-end items-end'>
<div className="fixed bottom-20 z-50 h-[30rem] w-full max-w-[20%] ">
<div className="fixed bottom-5 right-0 z-10 p-4 bg-green-300 rounded-full">
<div className="fixed bottom-5 right-0 z-10 p-4 bg-green-300 rounded-full">
<MdOutlineChat
className="text-4xl cursor-pointer z-20"
onClick={toggleChatPopUp}
/>
</div>
<div className={`${isChatPopUpOpen?"block fixed bottom-24" : "hidden"} h-[30rem] w-full max-w-[20%]`}>
{isChatPopUpOpen && (
// <ChatRoomsList chatrooms= {chatrooms} currentUser = {currentUser as string}/>
<ChatWrapper />
)}
</div>
</div>
{/* Enddddddddd */}
</div>
</>
);
};

Expand Down
1 change: 1 addition & 0 deletions src/components/Product/AddProducts.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,7 @@ const ProductPopup: React.FC<ProductPopupProps> = ({
console.log(result.message);
onClose();
} catch (error: any) {
console.error('Failed to create product:', error);
let errorMessage = 'An unknown error occurred';
if (error.response) {
if (error.response.data && error.response.data.error) {
Expand Down
11 changes: 6 additions & 5 deletions src/components/chatWrapper.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
'use client'

import React,{useState, useEffect} from 'react'
import ChatConversation from './ChatConversation'
import ChatRoomsList from './ChatRoomsList'
Expand All @@ -16,9 +18,8 @@ export interface msgObject {
}

let socket: Socket;

const ChatWrapper= () => {

const chatUrl = process.env.NEXT_PUBLIC_URL_CHAT as string;
//socket connect

const [chatrooms, setChatrooms] = useState([]);
Expand All @@ -43,14 +44,14 @@ const ChatWrapper= () => {
}
},[]);


useEffect(() => {
const token = localStorage.getItem('token');
if (token) {
const trimmedToken = token.split(' ')[1];
setCurrentUserToken(trimmedToken);

socket = io('http://localhost:9090/chats', {
// const chatUrl = process.env.URL_CHAT as string
console.log("Chatttttt urllllllll",chatUrl);
socket = io(chatUrl, {
auth: { token: trimmedToken },
});

Expand Down
12 changes: 12 additions & 0 deletions src/components/isLogged.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
'use client';

export const checkUserLoggedIn = (): boolean => {
if (typeof window !== 'undefined') {
const userLocalStorage = localStorage.getItem("profile");
if (userLocalStorage) {
const userParse = JSON.parse(userLocalStorage);
return !!userParse?.User;
}
}
return false;
};
Loading

0 comments on commit 3385687

Please sign in to comment.