Tailwind css not holding the full screen

i was working a react project with tailwind css and i want the sidebar holding the full height below the logo and the links to the left with specified width but it is not holding? i have tried asking chatgpt,but it seems it did not find out why it is not occupying the full height.finally chatgpt is a creation of human at all. front end look profile.jsx

import { useContext, useState } from "react";
import { useLocation } from "react-router-dom";
import { UserContext } from "../App";
import ProfileView from "./profileView"

function Profile() {
  const location = useLocation();
  const msg = location.state?.mes;
  const [success, setSuccess] = useState(msg === undefined ? "" : msg);
  const [cancel, setCancel] = useState(msg === undefined ? "" : "X");
  const [name, setName] = useState(
    msg === undefined
      ? "h-0"
      : "h-10 flex justify-around items-center bg-green-200 text-black"
  );
  const { state, dispatch } = useContext(UserContext);

  function handleClick() {
    setSuccess("");
    setCancel("");
    setName("h-0");
  }
  return (
    <>
      <div className={name}>
        {success}
        <button onClick={handleClick}>{cancel}</button>
      </div>
      {state.logStatus ? (
        <div className="h-full">
        <ProfileView />
        </div>
      ) : (
        <div className="h-96 bg-red-200 flex justify-center items-center text-3xl font-bold">
          <div>You need to login in order to view your profile!</div>
        </div>
      )}
    </>
  );
}

export default Profile;

profileView.jsx

import { Component, useContext, useEffect, useState } from "react";
import { UserContext } from "../App";
import AdminProfile from "./adminProfile";
import StudentProfile from "./studentProfile";
import TeacherProfile from "./teacherProfile";

function ProfileView() {
  const { state, dispatch } = useContext(UserContext);

  return (
  <div className="h-full">
  {state.identity.id === "admin" ? (
        <AdminProfile />
      ) : state.identity.id === "teacher" ? (
        <TeacherProfile />
      ) : (
        <StudentProfile />
      )}
  </div>
  );
}

export default ProfileView;

studentProfile.jsx

import { SiGoogleclassroom } from "react-icons/si";
import { FaHouseUser } from "react-icons/fa";
import { MdGrade } from "react-icons/md";
import { MdManageAccounts } from "react-icons/md";
import { Link } from "react-router-dom";

const side = [
  { title: "Class", icon: <SiGoogleclassroom />, link: "/class" },
  { title: "Dormitory", icon: <FaHouseUser />, link: "/dormitory" },
  { title: "Grade", icon: <MdGrade />, link: "/grade" },
  { title: "Account", icon: <MdManageAccounts />, link: "/account" },
];

function StudentProfile() {
  return (
    <div className="bg-[#2f4050] text-white box-border w-1/4 h-full">
      {side.map((val, index) => {
        return (
         
            <Link to={val.link} key={index}>
              <div>{val.icon}</div>
              <div>{val.title}</div>
            </Link>
         
        );
      })}
    </div>
  );
}

export default StudentProfile;

Pretty hard to debug without a live example but h-full is height: 100% so it depends on the parent height. You have to set a viewport-related height on the parent (or a fixed height) for 100% to actually calculate to a height.

This topic was automatically closed 182 days after the last reply. New replies are no longer allowed.