dev2 siliconpin 2024-08-05 14:35:05 +00:00
parent 990ec3b04e
commit 81c9d2a75c
15 changed files with 1683 additions and 3 deletions

195
app/components/Calendar.tsx Normal file
View File

@ -0,0 +1,195 @@
import React from "react";
import { SettingOutlined, QuestionCircleOutlined, LogoutOutlined, RightOutlined } from '@ant-design/icons';
import { Layout, Menu, theme, Button, Modal, MenuProps } from 'antd';
import { Dropdown, Space } from 'antd';
import dayjs from 'dayjs';
import 'dayjs/locale/zh-cn';
import { Calendar, Col, Row, Typography } from 'antd';
import type { CalendarProps } from 'antd';
import type { Dayjs } from 'dayjs';
import dayLocaleData from 'dayjs/plugin/localeData';
import { Content } from "antd/es/layout/layout";
import '../../public/assets/left_side_nav.css';
dayjs.extend(dayLocaleData);
const App: React.FC = () => {
const { token } = theme.useToken();
const onPanelChange = (value: Dayjs, mode: CalendarProps<Dayjs>['mode']) => {
console.log(value.format('YYYY-MM-DD'), mode);
};
const wrapperStyle: React.CSSProperties = {
width: 320,
border: `1px solid ${token.colorBorderSecondary}`,
borderRadius: token.borderRadiusLG,
padding: 16,
};
const headerStyle: React.CSSProperties = {
display: 'flex',
justifyContent: 'space-around',
alignItems: 'center',
// marginBottom: 16,
backgroundColor: '#0752bc',
height: 47,
borderTopLeftRadius: 10,
borderTopRightRadius: 10,
};
const titleStyle: React.CSSProperties = {
fontSize: 14,
fontWeight: 'bold',
color: '#fff',
};
const navButtonStyle: React.CSSProperties = {
cursor: 'pointer',
fontSize: 16,
};
return (
<>
<div className="grid gap-4 sm:grid-cols-1 md:grid-cols-[350px_1fr]">
<div className=" p-4">
<div className="grid grid-rows-2">
<div className="mb-4 bg-card bg-gray-200 rounded-lg shadow-md border border-zinc-300 dark:bg-card-foreground">
<Calendar
fullscreen={false}
headerRender={({ value, onChange }) => {
const monthFormat = 'MMMM';
const year = value.year();
const month = value.format(monthFormat);
const prevMonth = () => {
const newValue = value.clone().subtract(1, 'month');
onChange(newValue);
};
const nextMonth = () => {
const newValue = value.clone().add(1, 'month');
onChange(newValue);
};
return (
<div style={headerStyle}>
<div className="">
<div style={titleStyle}>{`${month} ${year}`}</div>
</div>
<div className="flex gap-8">
<div style={navButtonStyle} onClick={prevMonth}>{'<'}</div>
<div style={navButtonStyle} onClick={nextMonth}>{'>'}</div>
</div>
</div>
);
}}
onPanelChange={onPanelChange}
/>
</div>
<div className="">
<div className="bg-card h-80 bg-gray-200 rounded-lg shadow-md border border-zinc-300 dark:bg-card-foreground">
<div className="flex justify-around items-center h-12 border-b-2 border-zinc-300 bg-[#0752bc] rounded-t-lg">
{/* <h2 className="text-lg items-center font-semibold text-foreground dark:text-card-foreground">Upcoming Classes</h2> */}
<h2 style={titleStyle}>Upcoming Classes <span>&gt;</span></h2>
</div>
<div className=" ">
<div className="border-b-2 border-zinc-300 pb-12">
</div>
<div className="border-b-2 border-zinc-300 pb-12">
</div>
<div className="border-b-2 border-zinc-300 pb-12">
</div>
<div className="border-b-2 border-zinc-300 pb-12">
</div>
</div>
</div>
</div>
</div>
</div>
<div className=" p-4 border-l-[1px] py-2 border-[#CFCFCF]">
<div className='xl:col-span-4'>
<div className="p-4 bg-background">
<h2 className="text-lg font-semibold mb-4 border-b-[1px] py-2 border-[#CFCFCF]">Today's Schedule</h2>
<div className="space-y-2">
<div className="flex ">
<span className="w-16 text-zinc-700">9 AM</span>
<div className="flex-1 bg-blue-200 p-2 border-l-4 border-indigo-600 rounded-r-lg ">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">9 - 10 AM</span>
</div>
</div>
<div className="flex ">
<span className="w-16 text-zinc-700">10 AM</span>
<div className="flex-1 bg-blue-200 p-2 border-l-4 border-orange-600 rounded-r-lg">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">10 - 11 AM</span>
</div>
</div>
<div className="flex ">
<span className="w-16 text-zinc-700">11 AM</span>
<div className="flex-1"></div>
</div>
<div className="flex ">
<span className="w-16 text-zinc-700">12 PM</span>
<div className="flex-1 p-2 border-l-4 border-indigo-600 rounded-r-lg">
<span>Lorem Ipsum dolor sit</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex mb-8">
<span className="w-16 text-zinc-700">1 PM</span>
<div className="flex-1 p-2 border-l-4 border-green-600 rounded-r-lg">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex ">
<span className="w-16 text-zinc-700">2 PM</span>
<div className="flex-1 p-2 border-l-4 border-red-700 rounded-r-lg">
<span>Lorem Ipsum dolor sit</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex ">
<span className="w-16 text-zinc-700">3 PM</span>
<div className="flex-1 p-2 border-l-4 border-blue-700 rounded-r-lg">
<span>Lorem Ipsum dolor sit</span><br />
<span className="text-sm text-zinc-500">11 AM - 12:30 PM</span>
</div>
</div>
<div className="flex">
<span className="w-16 text-zinc-700">4 PM</span>
<div className="flex-1 bg-blue-200 p-2 border-l-4 border-sky-700 rounded-r-lg">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex ">
<span className="w-16 text-zinc-700">5 PM</span>
<div className="flex-1"></div>
</div>
</div>
</div>
</div>
</div>
</div>
</>
)
}
export default App;

View File

@ -0,0 +1,149 @@
import React from "react";
import { Layout, Menu, theme, Button, Modal, MenuProps } from 'antd';
const App: React.FC = () => {
return (
<>
<div className="grid grid-cols-1 md:grid-cols-3 gap-4 mb-6">
<div className="bg-card p-4 rounded-lg shadow">
<div className="h-48 bg-muted my-2 rounded relative bg-slate-300">
</div>
<h2 className="text-lg font-semibold">Life History of Dr. Maria Montessori</h2>
<p>Chapter 1 Graduate Program</p>
</div>
<div className="bg-card p-4 rounded-lg shadow">
<div className="h-48 bg-muted my-2 rounded relative bg-slate-300" >
</div>
<h2 className="text-lg font-semibold">Introduction to Montessori Methods</h2>
<p>Chapter 2 Graduate Program</p>
</div>
<div className="bg-card p-4 rounded-lg shadow">
<div className="h-48 bg-muted my-2 rounded relative bg-slate-300">
</div>
<h2 className="text-lg font-semibold">Exercises on Practical Life</h2>
<p>Chapter 3 Graduate Program</p>
</div>
</div>
{/* <div className="p-4 grid grid-cols-1 md:grid-cols-3 gap-4">
<div className="bg-card p-4 h-48 bg-gray-200 rounded-lg shadow-md border border-zinc-300 dark:bg-card-foreground">
<div className="flex justify-between items-center border-b-2 border-zinc-300 pb-3 mb-4">
<h2 className="text-lg font-semibold text-foreground dark:text-card-foreground">Attendance</h2>
<button className="text-primary dark:text-primary-foreground hover:text-primary/80">
<span>&gt;</span>
</button>
</div>
<div className="mt-4 text-center">
<p className="text-muted-foreground dark:text-muted-foreground">Graph</p>
</div>
</div> */}
{/* <div className="bg-card p-4 h-48 bg-gray-200 rounded-lg shadow-md border border-zinc-300 dark:bg-card-foreground">
<div className="flex justify-between items-center border-b-2 border-zinc-300 pb-3">
<h2 className="text-lg font-semibold text-foreground dark:text-card-foreground">Upcoming Classes</h2>
<button className="text-primary dark:text-primary-foreground hover:text-primary/80">
<span>&gt;</span>
</button>
</div>
<div className=" ">
<div className="border-b-2 border-zinc-300 pb-12">
</div>
<div className="border-b-2 border-zinc-300 pb-12">
</div>
</div>
</div>
<div className="bg-card p-4 rounded-lg shadow col-span-2">
<h2 className="text-lg font-semibold">Accomplishments/Qualifications</h2>
<div className="grid grid-cols-3 gap-4 mt-2">
<div className="h-24 w-24 bg-muted rounded-lg bg-slate-300"></div>
<div className="h-24 w-24 bg-muted rounded-lg bg-slate-300"></div>
<div className="h-24 w-24 bg-muted rounded-lg bg-slate-300"></div>
<div className="h-24 w-24 bg-muted rounded-lg bg-slate-300"></div>
<div className="h-24 w-24 bg-muted rounded-lg bg-slate-300"></div>
</div>
</div>
</div> */}
<div className="grid grid-cols-3 gap-4">
<div className="bg-card p-4 h-52 bg-gray-200 rounded-lg shadow-md border border-zinc-300 dark:bg-card-foreground">
<div className="flex justify-between items-center border-b-2 border-zinc-300 pb-3 mb-4">
<h2 className="text-lg font-semibold text-foreground dark:text-card-foreground">Attendance</h2>
<button className="text-primary dark:text-primary-foreground hover:text-primary/80">
<span>&gt;</span>
</button>
</div>
<div className="mt-4 text-center">
<p className="text-muted-foreground dark:text-muted-foreground">Graph</p>
</div>
</div>
<div className="bg-card p-4 h-52 bg-gray-200 rounded-lg shadow-md border border-zinc-300 dark:bg-card-foreground">
<div className="flex justify-between items-center border-b-2 border-zinc-300 pb-3">
<h2 className="text-lg font-semibold text-foreground dark:text-card-foreground">Upcoming Classes</h2>
<button className="text-primary dark:text-primary-foreground hover:text-primary/80">
<span>&gt;</span>
</button>
</div>
<div className=" ">
<div className="border-b-2 border-zinc-300 pb-12">
</div>
<div className="border-b-2 border-zinc-300 pb-12">
</div>
</div>
</div>
{/* <div className=" row-span-3 bg-card p-4 h-96 bg-gray-200 rounded-lg shadow-md border border-zinc-300 dark:bg-card-foreground">
<div className="flex justify-between items-center border-b-2 border-zinc-300 pb-3">
<h2 className="text-lg font-semibold text-foreground dark:text-card-foreground">Upcoming Classes</h2>
<button className="text-primary dark:text-primary-foreground hover:text-primary/80">
<span>&gt;</span>
</button>
</div>
<div className=" ">
<div className="border-b-2 border-zinc-300 pb-12">
</div>
<div className="border-b-2 border-zinc-300 pb-12">
</div>
</div>
</div> */}
<div className="max-w-md bg-card p-4 rounded-lg shadow-md row-span-3 bg-gray-200">
<h2 className="text-lg font-semibold text-foreground">Upcoming Tests</h2>
<div className="grid grid-rows-5 gap-4 mt-4">
<div className="bg-muted h-24 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-24 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-24 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-24 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-24 rounded-lg bg-slate-300"></div>
</div>
</div>
<div className="p-4 bg-card rounded-lg shadow-md col-span-2 border-b-2 border-zinc-300">
<h2 className="text-lg font-semibold text-foreground">Accomplishments/Qualifications</h2>
<div className="grid grid-cols-5 gap-4 mt-4">
<div className="bg-muted h-16 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-16 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-16 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-16 rounded-lg bg-slate-300"></div>
<div className="bg-muted h-16 rounded-lg bg-slate-300"></div>
</div>
</div>
</div>
</>
)
}
export default App;

View File

@ -435,7 +435,7 @@ const items2: MenuProps['items'] = [
children: [
{
key: '1sd',
label: (<a href='#'>Class Schedules</a>),
label: (<a href='#'>Class Schedule</a>),
},
{
key: '2sd',

88
app/components/NavBar.tsx Normal file
View File

@ -0,0 +1,88 @@
import React, { useState } from "react";
import { SettingOutlined, QuestionCircleOutlined, LogoutOutlined, RightOutlined } from '@ant-design/icons';
import { Layout, Menu, theme, Button, Modal, MenuProps } from 'antd';
import { Dropdown, Space } from 'antd';
import '../../public/assets/left_side_nav.css';
import '../../public/assets/knowledge-quest.css';
const { Content, Sider } = Layout;
const items: MenuProps['items'] = [
{
label: <a href="https://www.antgroup.com">1st menu item</a>,
key: '01sd',
},
{
type: 'divider',
},
{
label: <a href="https://www.aliyun.com">2nd menu item</a>,
key: '02sd',
},
{
type: 'divider',
},
{
label: '3rd menu item',
key: '03sd',
},
];
const App: React.FC = () => {
const [collapsed, setCollapsed] = useState(false);
const [open, setOpen] = React.useState<boolean>(false);
const [loading, setLoading] = React.useState<boolean>(true);
const showLoading = () => {
setOpen(true);
setLoading(true);
// Simple loading mock. You should add cleanup logic in real world.
setTimeout(() => {
setLoading(false);
}, 100);
};
const { token: { colorBgContainer }, } = theme.useToken();
return (
<div>
<Modal style={{ top: '20px', right: '0px' }} title={<p>Loading Modal</p>} footer={<Button type="primary" onClick={showLoading}> Reload </Button>} loading={loading} open={open} onCancel={() => setOpen(false)} >
<p>Some contents...</p>
<p>Some contents...</p>
<p>Some contents...</p>
</Modal>
<div className='border-b-[1px] py-2 border-[#CFCFCF]'>
<div className='container mx-auto flex flex-row justify-between'>
<div className='inline-flex justify-center place-items-center'>
<img src="../../assets/student-dash.svg" alt="" />
<p className='pl-1 text-[18px] font-[700] whitespace-nowrap'>Student Dashboard</p>
</div>
<div className="flex items-center">
<Button className='border-none shadow-none bg-transparent hover:bg-transparent' onClick={showLoading}>
<div className='border-[1px] border[#525252] rounded-full p-2 w-[47px] h-[47px]'>
<svg viewBox="0 0 26 26" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M5.06445 20.2658V18.2111H7.1191V11.0198C7.1191 9.59872 7.54715 8.33597 8.40325 7.2316C9.25935 6.12723 10.3723 5.40382 11.742 5.06138V4.34225C11.742 3.9142 11.8919 3.55036 12.1915 3.25072C12.4911 2.95109 12.855 2.80127 13.283 2.80127C13.7111 2.80127 14.0749 2.95109 14.3746 3.25072C14.6742 3.55036 14.824 3.9142 14.824 4.34225V5.06138C16.1938 5.40382 17.3067 6.12723 18.1628 7.2316C19.0189 8.33597 19.447 9.59872 19.447 11.0198V18.2111H21.5016V20.2658H5.06445ZM13.283 23.3477C12.718 23.3477 12.2343 23.1465 11.8319 22.7442C11.4296 22.3418 11.2284 21.8581 11.2284 21.2931H15.3377C15.3377 21.8581 15.1365 22.3418 14.7341 22.7442C14.3318 23.1465 13.8481 23.3477 13.283 23.3477ZM9.17374 18.2111H17.3923V11.0198C17.3923 9.88979 16.99 8.9224 16.1852 8.11766C15.3805 7.31293 14.4131 6.91056 13.283 6.91056C12.153 6.91056 11.1856 7.31293 10.3808 8.11766C9.57611 8.9224 9.17374 9.88979 9.17374 11.0198V18.2111Z" fill="black" />
<circle cx="19.4462" cy="19.2384" r="4.23771" fill="#FF0000" stroke="#fff" strokeWidth="2.31148" />
</svg>
</div>
</Button>
<Dropdown menu={{ items }} trigger={['click']}>
<a onClick={(e) => e.preventDefault()}>
<Space>
<div className='flex flex-row border-[1px] border-[#BBBBBB] rounded-full p-1 gap-x-6'>
<img src="/assets/man.png" alt="" />
<div>
<p className='text-[12px] text-[#EF7A0C] font-[500]'>My Profile</p>
<p className='text-[16px] text-[#27549F] font-[700]'>Rayan Holiday</p>
</div>
<RightOutlined style={{ fontSize: '12px', paddingRight: '10px' }} />
</div>
</Space>
</a>
</Dropdown>
</div>
</div>
</div>
</div>
)
}
export default App;

View File

@ -0,0 +1,82 @@
import React from "react";
import { Layout, Menu, theme, Button, Modal, MenuProps } from 'antd';
const App: React.FC = () => {
return (
<>
<div className='grid grid-cols-2 xl:grid-cols-7 gap-y-6 border-[1px] border-[#CFCFCF]'>
<div className='xl:col-span-4'>
<div className="p-4 bg-background">
<h2 className="text-lg font-semibold mb-4">Today's Schedule</h2>
<div className="space-y-2">
<div className="flex items-center">
<span className="w-16 text-zinc-700">9 AM</span>
<div className="flex-1 bg-blue-200 p-2 border-l-4 border-indigo-600 rounded-r-lg ">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">9 - 10 AM</span>
</div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">10 AM</span>
<div className="flex-1 bg-blue-200 p-2 border-l-4 border-orange-600 rounded-r-lg">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">10 - 11 AM</span>
</div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">11 AM</span>
<div className="flex-1"></div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">12 PM</span>
<div className="flex-1 p-2 border-l-4 border-indigo-600 rounded-r-lg">
<span>Lorem Ipsum dolor sit</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">1 PM</span>
<div className="flex-1 p-2 border-l-4 border-green-600 rounded-r-lg">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">2 PM</span>
<div className="flex-1 p-2 border-l-4 border-red-700 rounded-r-lg">
<span>Lorem Ipsum dolor sit</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">3 PM</span>
<div className="flex-1 p-2 border-l-4 border-blue-700 rounded-r-lg">
<span>Lorem Ipsum dolor sit</span><br />
<span className="text-sm text-zinc-500">11 AM - 12:30 PM</span>
</div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">4 PM</span>
<div className="flex-1 bg-blue-200 p-2 border-l-4 border-sky-700 rounded-r-lg">
<span>Lorem Ipsum</span><br />
<span className="text-sm text-zinc-500">11:30 AM - 12:30 PM</span>
</div>
</div>
<div className="flex items-center">
<span className="w-16 text-zinc-700">5 PM</span>
<div className="flex-1"></div>
</div>
</div>
</div>
</div>
</div>
</>
)
}
export default App;

213
app/components/Sidebar.tsx Normal file
View File

@ -0,0 +1,213 @@
import React,{useState} from "react";
import { SettingOutlined, QuestionCircleOutlined, LogoutOutlined, RightOutlined } from '@ant-design/icons';
import AdministrationIcon from '~/components/customIcon/AdministrationIcon';
import MyCoursesIcon from '~/components/customIcon/MyCoursesIcon';
import ExaminationIcon from '~/components/customIcon/ExaminationIcon';
import CommunityIcon from '~/components/customIcon/CommunityIcon';
import NotificationIcon from '~/components/customIcon/NotificationIcon';
import { Layout, Menu, theme, Button, Modal, MenuProps } from 'antd';
import { Dropdown, Space } from 'antd';
import '../../public/assets/left_side_nav.css';
const { Content, Sider } = Layout;
const items2: MenuProps['items'] = [
{
key: 'subsd1',
icon: <AdministrationIcon />,
label: (<p>&nbsp; Administration</p>),
children: [
{
key: '1sd',
label: (<a href='#'>Class Schedules</a>),
},
{
key: '2sd',
label: (<a href='#'>Classmate Directory</a>),
},
{
key: '3sd',
label: (<a href='#'>Qualifications</a>),
},
],
},
{
key: 'subsd2',
icon: <MyCoursesIcon />,
label: (<p>&nbsp; My Courses</p>),
children: [
{
key: '4sd',
label: (<a href='#'>Graduate Program</a>),
},
{
key: '5sd',
label: (<a href='#'>Post-Graduate Program</a>),
},
],
},
{
key: 'subsd3',
icon: <ExaminationIcon />,
label: (<p>&nbsp; Examinations</p>),
children: [
{
key: '6sd',
label: (<a href='#'>Exam Scheduled</a>),
},
{
key: '7sd',
label: (<a href='#'>Upcoming Exam</a>),
},
{
key: '8sd',
label: (<a href='#'>Passed Exam</a>),
},
],
},
{
key: 'subsd4',
icon: <CommunityIcon />,
label: (<p>&nbsp; Community</p>),
children: [
{
key: '9sd',
label: (<a href='#'>Exam Scheduled</a>),
},
{
key: '10sd',
label: (<a href='#'>Upcoming Exam</a>),
},
{
key: '11sd',
label: (<a href='#'>Passed Exam</a>),
},
],
},
{
key: 'subsd5',
icon: <NotificationIcon />,
label: (<p>&nbsp; Notifications</p>),
children: [
{
key: '12sd',
label: (<a href='#'>Exam Scheduled</a>),
},
{
key: '13sd',
label: (<a href='#'>Upcoming Exam</a>),
},
{
key: '14sd',
label: (<a href='#'>Passed Exam</a>),
},
],
},
// getItem('Files', '9', <FileOutlined />),
{
key: 'grp',
label: '',
type: 'group',
style: { marginTop: '100px' },
children: [
{
key: '15sd', style: { paddingTop: '10px', paddingBottom: '10px', border: 'none' },
icon: React.createElement(SettingOutlined, { style: { color: '#000' } }),
label: (<h2 className='text-[18px] font-[700] text-[#000]'>Settings</h2>)
},
{
key: '16sd', style: { paddingTop: '10px', paddingBottom: '10px', border: 'none' },
icon: React.createElement(QuestionCircleOutlined, { style: { color: '#000' } }),
label: (<h2 className='text-[18px] font-[700] text-[#000]'>Help & Support</h2>)
},
{
key: '17sd', style: { paddingTop: '10px', paddingBottom: '10px', border: 'none' },
icon: React.createElement(LogoutOutlined, { style: { color: '#000' } }),
label: (<h2 className='text-[18px] font-[700] text-[#000]'>Logout</h2>)
},
],
},
];
const items: MenuProps['items'] = [
{
label: <a href="https://www.antgroup.com">1st menu item</a>,
key: '01sd',
},
{
type: 'divider',
},
{
label: <a href="https://www.aliyun.com">2nd menu item</a>,
key: '02sd',
},
{
type: 'divider',
},
{
label: '3rd menu item',
key: '03sd',
},
];
///
interface SidebarProps {
isCollapsed: boolean;
toggleSidebar: () => void;
}
const App: React.FC <SidebarProps> = ({isCollapsed, toggleSidebar}) => {
const [collapsed, setCollapsed] = useState(false);
return(
<div >
{/* <Sider collapsible collapsed={collapsed} onCollapse={(value) => setCollapsed(value)} width={366} style={{ overflow: 'auto', height: '110vh', position: 'fixed', left: 0, top: 0, bottom: 0, background: '#FFF', borderRight: '1px solid #CFCFCF', borderBottom: '2px solid #000' }}> */}
<Sider
collapsible
collapsed={isCollapsed}
onCollapse={toggleSidebar}
width={366}
style={{
overflow: 'auto',
height: '100vh',
position: 'fixed',
left: 0,
top: 0,
bottom: 0,
background: '#FFF',
borderRight: '1px solid #CFCFCF',
borderBottom: '2px solid #000',
}}
>
<div className='flex flex-col justify-center demo-logo-vertical'>
<div className='px-4'>
<h1 className='text-[22px] font-[700] my-[37px] text-left text-[#000]'>IIMTT Logo</h1>
</div>
</div>
<Dropdown menu={{ items }} trigger={['click']}>
<a onClick={(e) => e.preventDefault()}>
<Space>
<div className='flex flex-row border-[1px] border-[#BBBBBB] rounded-full p-1 gap-x-6'>
<img src="/assets/man.png" alt="" />
<div>
<p className='text-[12px] text-[#EF7A0C] font-[500]'>My Profile</p>
<p className='text-[16px] text-[#27549F] font-[700]'>Rayan Holiday</p>
</div>
<RightOutlined style={{ fontSize: '12px', paddingRight: '10px' }} />
</div>
</Space>
</a>
</Dropdown>
<Menu className='custom-menu' defaultSelectedKeys={['1sd']} defaultOpenKeys={['subsd1']} mode="inline" style={{ height: '100%', borderRight: 0, paddingTop: 30, background: 'transparent' }} items={items2} />
</Sider>
</div>
)
}
export default App;

View File

@ -348,6 +348,7 @@ const App: React.FC = () => {
<img src="/assets/man.png" alt="" />
<div>
<p className='text-[12px] text-[#EF7A0C] font-[500]'>My Profile</p>
<p className='text-[16px] text-[#27549F] font-[700]'>Rayan Holiday</p>
</div>
<RightOutlined style={{ fontSize: '12px', paddingRight: '10px' }} />

View File

@ -53,7 +53,7 @@ const items2: MenuProps['items'] = [
children: [
{
key: '1',
label: (<a href='#'>Class Schedules</a>),
label: (<a href='#'>Class Schedule</a>),
},
{
key: '2',
@ -256,6 +256,7 @@ const App: React.FC = () => {
<img src="/assets/man.png" alt="" />
<div>
<p className='text-[12px] text-[#EF7A0C] font-[500]'>My Profile</p>
<p className='text-[16px] text-[#27549F] font-[700]'>Rayan Holiday</p>
</div>
<DownOutlined style={{ fontSize: '12px' }} />
@ -322,6 +323,8 @@ const App: React.FC = () => {
</div>
<div className='md:col-span-1 border-[1px] border-[#E9E9E9] w-full bg-[#FCFCFC] rounded-[10px]'>
<h2 className='text-[20px] font-[700] p-4 border-b-[1px] border-[#E9E9E9]'>Upcoming Tests</h2>
<div className='flex flex-col'>
<div className='p-4 border-b-[1px] border-[#CFCFCF]'>
<img className='h-[44px] w-[79px]' src="../../assets/rectangle.jpg" alt="" />

View File

@ -219,12 +219,13 @@ const App: React.FC = () => {
<Sider collapsible collapsed={collapsed} onCollapse={(value) => setCollapsed(value)} width={310} style={{overflow: 'auto', height: '110vh', position: 'fixed', left: 0, top: 0, bottom: 0, background: 'linear-gradient(180deg, #2F1B08D6 0%, #000000D6 83.93%)', borderRight: '1px solid #CFCFCF', borderBottom: '2px solid #000'}}>
<div className='flex flex-col justify-center demo-logo-vertical'>
<div className='px-4'>
<h1 className='text-[22px] font-[700] my-[37px] text-left text-[#FFF]'>IIMTT Logo</h1>
<h1 className='text-[22px] font-[700] my-[37px] text-left text-[#FFF]'>IIMTT Logo0</h1>
<a href="#" className='flex flex-row justify-between border-[1px] border-[#E9E9E9] rounded-[10px] p-2 place-items-center'>
<img className='w-[46px] h-[46px]' src="/assets/man.png" alt="" />
<div>
<p className='text-[16px] font-[500] text-[#D0D0D0]'>My Profile</p>
<p className='text-[22px] font-[700] text-[#FFF]'>Rayan Holiday</p>
</div>
<img className='' src="../../assets/right-arrow.svg" alt="" />
</a>
@ -323,6 +324,7 @@ const App: React.FC = () => {
</div>
<div className='md:col-span-1 border-[1px] border-[#E9E9E9] w-full bg-[#FCFCFC] rounded-[10px]'>
<h2 className='text-[20px] font-[700] p-4 border-b-[1px] border-[#E9E9E9]'>Upcoming Tests</h2>
<div className='flex flex-col'>
<div className='p-4 border-b-[1px] border-[#CFCFCF]'>
<img className='h-[44px] w-[79px]' src="../../assets/rectangle.jpg" alt="" />

40
app/routes/dashboard.tsx Normal file
View File

@ -0,0 +1,40 @@
import React, { useState } from 'react';
import Calendar from '../components/Calendar';
import Sidebar from '../components/Sidebar';
import NavBar from '../components/NavBar';
import { Layout, Menu, theme, Button, Modal, MenuProps } from 'antd';
import { Dropdown, Space } from 'antd';
import '../../public/assets/left_side_nav.css';
const { Content, Sider } = Layout;
const App: React.FC = () => {
const [isCollapsed, setIsCollapsed] = useState(false);
const toggleSidebar = () => {
setIsCollapsed(!isCollapsed);
};
return (
<Layout>
<Layout>
{/* <Sidebar />
<Layout style={{ marginLeft: 366, background: '#FFF' }}> */}
<Sidebar isCollapsed={isCollapsed} toggleSidebar={toggleSidebar} />
<Layout style={{ marginLeft: isCollapsed ? 80 : 366, transition: 'margin-left 0.2s ease' }}>
<Content style={{ overflow: 'initial', }}>
<NavBar />
<section className='grid grid-cols-1 xl:grid-cols-1 gap-y-6 border-[2px] border-[#CFCFCF]'>
<Calendar />
</section>
</Content>
</Layout>
</Layout>
</Layout>
);
};
export default App;

40
app/routes/directory.tsx Normal file
View File

@ -0,0 +1,40 @@
import React, { useState } from 'react';
import { Layout, Menu, theme, Button, Modal, MenuProps } from 'antd';
import { Dropdown, Space } from 'antd';
import DirectoryDashboard from '../components/DirectoryDashboard';
import '../../public/assets/left_side_nav.css';
const { Content, Sider } = Layout;
import Sidebar from '../components/Sidebar';
import NavBar from '../components/NavBar';
const App: React.FC = () => {
const [isCollapsed, setIsCollapsed] = useState(false);
const toggleSidebar = () => {
setIsCollapsed(!isCollapsed);
};
return (
<Layout>
<Layout>
<Sidebar isCollapsed={isCollapsed} toggleSidebar={toggleSidebar} />
<Layout style={{ marginLeft: isCollapsed ? 80 : 366, transition: 'margin-left 0.2s ease' }}>
<Content style={{ overflow: 'initial', }}>
<NavBar />
<div className='grid grid-cols-1 gap-y-6 border-[1px] border-[#CFCFCF]'>
<DirectoryDashboard />
</div>
</Content>
</Layout>
</Layout>
</Layout>
);
};
export default App;

View File

@ -0,0 +1,759 @@
import React, {useState} from 'react';
import { SettingOutlined, QuestionCircleOutlined, LogoutOutlined, DownOutlined} from '@ant-design/icons';
import Icon from '@ant-design/icons';
import AdministrationIcon from '~/components/customIcon/AdministrationIcon';
import MyCoursesIcon from '~/components/customIcon/MyCoursesIcon';
import ExaminationIcon from '~/components/customIcon/ExaminationIcon';
import CommunityIcon from '~/components/customIcon/CommunityIcon';
import NotificationIcon from '~/components/customIcon/NotificationIcon';
import {Layout, Menu, theme, Button, Modal, MenuProps, Tabs} from 'antd';
const { TabPane } = Tabs;
import { Dropdown, Space } from 'antd';
import '../../public/assets/knowledge-quest.css';
import { BrowserRouter as Router, Route, Routes, Link } from 'react-router-dom';
import dashboard from './dashboard';
import directory from './directory';
let courseData = [
{
id : "1",
title : "Life History of Dr. Maria Montessori",
chapter : "1",
Program : "Graduate Program",
img : "/assets/course1.jpg"
},
{
id : "2",
title : "Introduction to Montessori Methods",
chapter : "2",
Program : "Graduate Program",
img : "/assets/course2.jpg"
},
{
id : "3",
title : "Exercises on Practical Life",
chapter : "3",
Program : "Graduate Program",
img : "/assets/course3.jpg"
}
];
let knowledgeData = [
{
id: "1",
status: "1",
title: "Assessment on Special Education",
challenge: "Challenge yourself & climb the leaderboard.",
question: "Subjective Question",
img: "/assets/knowledge1.jpg"
},
{
id: "2",
status: "1",
title: "Quiz on Children Psychology",
challenge: "Challenge yourself & climb the leaderboard.",
question: "MCQ",
img: "/assets/knowledge2.jpg"
},
{
id: "3",
status: "1",
title: "Quiz on Montessori Methods",
challenge: "Challenge yourself & climb the leaderboard.",
question: "MCQ",
img: "/assets/knowledge3.jpg"
},
{
id: "4",
status: "1",
title: "Assessment on Special Education",
challenge: "Challenge yourself & climb the leaderboard.",
question: "Subjective Question",
img: "/assets/knowledge1.jpg"
},
{
id: "5",
status: "1",
title: "Quiz on Children Psychology",
challenge: "Challenge yourself & climb the leaderboard.",
question: "MCQ",
img: "/assets/knowledge2.jpg"
},
{
id: "6",
status: "1",
title: "Quiz on Montessori Methods",
challenge: "Challenge yourself & climb the leaderboard.",
question: "MCQ",
img: "/assets/knowledge3.jpg"
},
{
id: "7",
status: "1",
title: "Workshop on Child Development",
challenge: "Expand your knowledge & earn badges.",
question: "Interactive Session",
img: "/assets/knowledge1.jpg"
},
{
id: "8",
status: "1",
title: "Webinar on Educational Psychology",
challenge: "Join & enhance your skills.",
question: "Discussion",
img: "/assets/knowledge2.jpg"
},
{
id: "9",
status: "1",
title: "Seminar on Inclusive Education",
challenge: "Participate & gain insights.",
question: "Lecture",
img: "/assets/knowledge3.jpg"
},
{
id: "10",
status: "1",
title: "Course on Early Childhood Education",
challenge: "Complete the course & get certified.",
question: "Multiple Modules",
img: "/assets/knowledge1.jpg"
},
{
id: "11",
status: "1",
title: "Training on Classroom Management",
challenge: "Improve your teaching strategies.",
question: "Practical Tasks",
img: "/assets/knowledge2.jpg"
},
{
id: "12",
status: "1",
title: "Lecture on Cognitive Development",
challenge: "Expand your understanding & get certified.",
question: "Q&A Session",
img: "/assets/knowledge3.jpg"
},
{
id: "13",
status: "1",
title: "Workshop on Behavioral Issues",
challenge: "Join & learn from experts.",
question: "Interactive Session",
img: "/assets/knowledge1.jpg"
},
{
id: "14",
status: "1",
title: "Seminar on Learning Disabilities",
challenge: "Participate & enhance your knowledge.",
question: "Lecture",
img: "/assets/knowledge2.jpg"
},
{
id: "15",
status: "1",
title: "Webinar on Child Psychology",
challenge: "Join & expand your skills.",
question: "Discussion",
img: "/assets/knowledge3.jpg"
},
{
id: "16",
status: "1",
title: "Course on Special Education Needs",
challenge: "Complete the course & get certified.",
question: "Multiple Modules",
img: "/assets/knowledge1.jpg"
},
{
id: "17",
status: "1",
title: "Training on Autism Spectrum Disorder",
challenge: "Improve your teaching strategies.",
question: "Practical Tasks",
img: "/assets/knowledge2.jpg"
},
{
id: "18",
status: "1",
title: "Lecture on Emotional Development",
challenge: "Expand your understanding & get certified.",
question: "Q&A Session",
img: "/assets/knowledge3.jpg"
},
{
id: "19",
status: "1",
title: "Workshop on ADHD",
challenge: "Join & learn from experts.",
question: "Interactive Session",
img: "/assets/knowledge1.jpg"
},
{
id: "20",
status: "1",
title: "Seminar on Speech and Language Disorders",
challenge: "Participate & enhance your knowledge.",
question: "Lecture",
img: "/assets/knowledge2.jpg"
},
{
id: "21",
status: "1",
title: "Webinar on Child Nutrition",
challenge: "Join & expand your skills.",
question: "Discussion",
img: "/assets/knowledge3.jpg"
}
];
let performersData = [
{
id: "1",
name: "Eiden",
score: "48/50",
points: "999",
rank: "1",
program: "Graduate Program",
avatar: "/assets/avatar1.png"
},
{
id: "2",
name: "Jackson",
score: "45/50",
points: "997",
rank: "2",
program: "Graduate Program",
avatar: "/assets/avatar2.png"
},
{
id: "3",
name: "Emma Aria",
score: "43/50",
points: "994",
rank: "3",
program: "Graduate Program",
avatar: "/assets/avatar3.png"
},
{
id: "4",
name: "John Doe",
score: "40/50",
points: "990",
rank: "4",
program: "Graduate Program",
avatar: "/assets/avatar4.png"
},
{
id: "5",
name: "Jane Cooper",
score: "37/50",
points: "987",
rank: "5",
program: "Graduate Program",
avatar: "/assets/avatar5.png"
},
{
id: "6",
name: "John Doe",
score: "35/50",
points: "982",
rank: "6",
program: "Graduate Program",
avatar: "/assets/avatar6.png"
},
{
id: "7",
name: "Alice",
score: "33/50",
points: "980",
rank: "7",
program: "Graduate Program",
avatar: "/assets/avatar1.png"
},
{
id: "8",
name: "Bob",
score: "32/50",
points: "978",
rank: "8",
program: "Graduate Program",
avatar: "/assets/avatar2.png"
},
{
id: "9",
name: "Charlie",
score: "30/50",
points: "975",
rank: "9",
program: "Graduate Program",
avatar: "/assets/avatar3.png"
},
{
id: "10",
name: "Diana",
score: "28/50",
points: "972",
rank: "10",
program: "Graduate Program",
avatar: "/assets/avatar4.png"
},
{
id: "11",
name: "Edward",
score: "27/50",
points: "970",
rank: "11",
program: "Graduate Program",
avatar: "/assets/avatar5.png"
},
{
id: "12",
name: "Fiona",
score: "26/50",
points: "968",
rank: "12",
program: "Graduate Program",
avatar: "/assets/avatar6.png"
},
{
id: "13",
name: "George",
score: "25/50",
points: "965",
rank: "13",
program: "Graduate Program",
avatar: "/assets/avatar1.png"
},
{
id: "14",
name: "Hannah",
score: "23/50",
points: "962",
rank: "14",
program: "Graduate Program",
avatar: "/assets/avatar2.png"
},
{
id: "15",
name: "Ian",
score: "22/50",
points: "960",
rank: "15",
program: "Graduate Program",
avatar: "/assets/avatar3.png"
},
{
id: "16",
name: "Julia",
score: "20/50",
points: "957",
rank: "16",
program: "Graduate Program",
avatar: "/assets/avatar4.png"
},
{
id: "17",
name: "Kyle",
score: "19/50",
points: "955",
rank: "17",
program: "Graduate Program",
avatar: "/assets/avatar5.png"
},
{
id: "18",
name: "Laura",
score: "18/50",
points: "953",
rank: "18",
program: "Graduate Program",
avatar: "/assets/avatar6.png"
},
{
id: "19",
name: "Michael",
score: "17/50",
points: "950",
rank: "19",
program: "Graduate Program",
avatar: "/assets/avatar1.png"
},
{
id: "20",
name: "Nancy",
score: "16/50",
points: "947",
rank: "20",
program: "Graduate Program",
avatar: "/assets/avatar2.png"
},
{
id: "21",
name: "Oliver",
score: "15/50",
points: "945",
rank: "21",
program: "Graduate Program",
avatar: "/assets/avatar3.png"
}
];
const sortedData = performersData.sort((a, b) => parseInt(a.rank) - parseInt(b.rank));
const highestRank = sortedData[0];
const secondHighestRank = sortedData[1];
const thirdHighestRank = sortedData[2];
console.log('The highest rank is:', highestRank);
console.log('The second highest rank is:', secondHighestRank);
console.log('The Third highest rank is:', thirdHighestRank);
// const highestRank = performersData.reduce((prev, current) => (prev.rank < current.rank) ? prev : current);
// console.log('The highest rank is:', highestRank);
const { Header, Content, Sider } = Layout;
const items1: MenuProps['items'] = ['1', '2', '3'].map((key) => ({
key,
label: `navkq ${key}`,
}));
type MenuItem = Required<MenuProps>['items'][number];
const items2: MenuProps['items'] = [
{
key: 'subkq1',
icon: <AdministrationIcon />,
label: 'Administration',
children: [
{
key: '1kq',
// label: (<a href='#'>Class Schedules</a>),
label: (<Link to="/dashboard">Class Schedules</Link>),
},
{
key: '2kq',
// label: (<a href='#'>Classmate Directory</a>),
label: (<Link to="/directory">Classmate Directory</Link>),
},
{
key: '3kq',
label: (<a href='#'>Qualifications</a>),
},
],
},
{
key: 'subkq2',
icon: <MyCoursesIcon />,
label: 'My Courses',
children: [
{
key: '4kq',
label: (<a href='#'>Graduate Program</a>),
},
{
key: '5kq',
label: (<a href='#'>Post-Graduate Program</a>),
},
],
},
{
key: 'subkq3',
icon: <ExaminationIcon />,
label: 'Examinations',
children: [
{
key: '6kq',
label: (<a href='#'>Exam Schedules</a>),
},
{
key: '7kq',
label: (<a href='#'>Upcoming Exam</a>),
},
{
key: '8kq',
label: (<a href='#'>Passed Exam</a>),
},
],
},
{
key: 'subkq4',
icon: <CommunityIcon />,
label: 'Community',
children: [
{
key: '9kq',
label: (<a href='#'>Exam Scheduled</a>),
},
{
key: '10kq',
label: (<a href='#'>Upcoming Exam</a>),
},
{
key: '11kq',
label: (<a href='#'>Passed Exam</a>),
},
],
},
{
key: 'subkq5',
icon: <NotificationIcon />,
label: 'Notifications',
children: [
{
key: '12kq',
label: (<a href='#'>Exam Scheduled</a>),
},
{
key: '13kq',
label: (<a href='#'>Upcoming Exam</a>),
},
{
key: '14kq',
label: (<a href='#'>Passed Exam</a>),
},
],
},
// getItem('Files', '9', <FileOutlined />),
{
key: 'grp',
label: '',
type: 'group',
style: { marginTop: '100px' },
children: [
{
key: '15kq', style: {paddingTop: '10px', paddingBottom: '10px', border: 'none'},
icon: React.createElement(SettingOutlined, { style: { color: '#000' } }),
label: (<h2 className='text-[18px] font-[700] text-[#000]'>Settings</h2>)
},
{
key: '16kq', style: {paddingTop: '10px', paddingBottom: '10px', border: 'none'},
icon: React.createElement(QuestionCircleOutlined, { style: { color: '#000' } }),
label: (<h2 className='text-[18px] font-[700] text-[#000]'>Help & Support</h2>)
},
{
key: '17kq', style: {paddingTop: '10px', paddingBottom: '10px', border: 'none'},
icon: React.createElement(LogoutOutlined, { style: { color: '#000' } }),
label: (<h2 className='text-[18px] font-[700] text-[#000]'>Logout</h2>)
},
],
},
];
const items: MenuProps['items'] = [
{
label: <a href="https://www.antgroup.com">1st menu item</a>,
key: '01kq',
},
{
type: 'divider',
},
{
label: <a href="https://www.aliyun.com">2nd menu item</a>,
key: '02kq',
},
{
type: 'divider',
},
{
label: '3rd menu item',
key: '03kq',
},
];
const App: React.FC = () => {
const [collapsed, setCollapsed] = useState(false);
const [open, setOpen] = React.useState<boolean>(false);
const [loading, setLoading] = React.useState<boolean>(true);
const showLoading = () => {
setOpen(true);
setLoading(true);
// Simple loading mock. You should add cleanup logic in real world.
setTimeout(() => {
setLoading(false);
}, 100);
};
const { token: { colorBgContainer}, } = theme.useToken();
return (
<Layout>
<>
{/* <Button type="primary" onClick={showLoading}>Open Modal</Button> */}
<Modal style={{top: '20px', right: '0px'}} title={<p>Loading Modal</p>} footer={ <Button type="primary" onClick={showLoading}> Reload </Button>} loading={loading} open={open} onCancel={() => setOpen(false)} >
<p>Some contents...</p>
<p>Some contents...</p>
<p>Some contents...</p>
</Modal>
</>
{/* <Header style={{ display: 'flex', alignItems: 'center' }}>
<div className="demo-logo" />
<Menu theme="dark" mode="horizontal" defaultSelectedKeys={['2']} items={items1} style={{ flex: 1, minWidth: 0 }} />
</Header> */}
<Layout>
<div >
<Sider collapsible collapsed={collapsed} onCollapse={(value) => setCollapsed(value)} width={366} style={{overflow: 'auto', height: '110vh', position: 'fixed', left: 0, top: 0, bottom: 0, background: '#FFF', borderRight: '1px solid #CFCFCF', borderBottom: '2px solid #000'}}>
<div className='flex flex-col justify-center demo-logo-vertical'>
<div className='px-4'>
<h1 className='text-[22px] font-[700] my-[37px] text-left text-[#000]'>IIMTT Logo</h1>
</div>
</div>
<Menu className='custom-menu' mode="inline" style={{ height: '100%', borderRight: 0, paddingTop: 30, background: 'transparent'}} items={items2} />
</Sider>
</div>
{/* defaultSelectedKeys={['1']} defaultOpenKeys={['sub1']} */}
<Layout style={{marginLeft: 366, background: '#FFF'}}>
<Content style={{ overflow: 'initial',}}>
<div className='border-b-[1px] py-2 border-[#CFCFCF]'>
<div className='container mx-auto flex flex-row justify-between'>
<div className='inline-flex justify-center place-items-center'>
{/* <img src="/assets/student-dash.svg" alt=""/> */}
<p className='pl-1 text-[18px] font-[700] whitespace-nowrap'>Knowledge Quests</p>
</div>
<div className='flex justify-center place-items-center'>
<button className='bg-[#000] py-2.5 rounded-[8px] text-[#FFF] tetx-[16px] font-[600] inline-flex justify-center place-items-center'>
<img src="/assets/ai-button-icon.svg" alt="" /> AI Generative Quiz
</button>
<Button className='border-none shadow-none bg-transparent hover:bg-transparent' onClick={showLoading}>
<div className='border-[1px] border[#525252] rounded-full p-2 w-[47px] h-[47px]'>
<svg viewBox="0 0 26 26" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M5.06445 20.2658V18.2111H7.1191V11.0198C7.1191 9.59872 7.54715 8.33597 8.40325 7.2316C9.25935 6.12723 10.3723 5.40382 11.742 5.06138V4.34225C11.742 3.9142 11.8919 3.55036 12.1915 3.25072C12.4911 2.95109 12.855 2.80127 13.283 2.80127C13.7111 2.80127 14.0749 2.95109 14.3746 3.25072C14.6742 3.55036 14.824 3.9142 14.824 4.34225V5.06138C16.1938 5.40382 17.3067 6.12723 18.1628 7.2316C19.0189 8.33597 19.447 9.59872 19.447 11.0198V18.2111H21.5016V20.2658H5.06445ZM13.283 23.3477C12.718 23.3477 12.2343 23.1465 11.8319 22.7442C11.4296 22.3418 11.2284 21.8581 11.2284 21.2931H15.3377C15.3377 21.8581 15.1365 22.3418 14.7341 22.7442C14.3318 23.1465 13.8481 23.3477 13.283 23.3477ZM9.17374 18.2111H17.3923V11.0198C17.3923 9.88979 16.99 8.9224 16.1852 8.11766C15.3805 7.31293 14.4131 6.91056 13.283 6.91056C12.153 6.91056 11.1856 7.31293 10.3808 8.11766C9.57611 8.9224 9.17374 9.88979 9.17374 11.0198V18.2111Z" fill="black"/>
<circle cx="19.4462" cy="19.2384" r="4.23771" fill="#FF0000" stroke="#fff" strokeWidth="2.31148"/>
</svg>
</div>
</Button>
<Dropdown menu={{ items }} trigger={['click']}>
<a onClick={(e) => e.preventDefault()}>
<Space>
<div className='flex flex-row border-[1px] border-[#BBBBBB] rounded-full p-1 gap-x-6'>
<img src="/assets/man.png" alt="" />
<div>
<p className='text-[12px] text-[#EF7A0C] font-[500]'>My Profile</p>
<p className='text-[16px] text-[#27549F] font-[700]'>Rayan Holiday</p>
</div>
<DownOutlined style={{ fontSize: '12px' }} />
</div>
</Space>
</a>
</Dropdown>
</div>
</div>
</div>
<section className='container mx-auto my-16'>
<div className='grid grid-cols-1 xl:grid-cols-7 gap-y-6 border-[1px] border-[#CFCFCF]'>
<div className='xl:col-span-5 border-r-[1px] border-[#CFCFCF]'>
<div className=''>
<Tabs className='' defaultActiveKey="1" >
<TabPane className='' tab="All" key="1">
<div className='flex flex-col gap-6'>
{knowledgeData.map(data => (
<div key={data.id} className='flex flex-row justify-between px-6 place-items-center'>
<div className='flex flex-row justify-between gap-6'>
<img src={data.img} alt="" />
<div className='flex flex-col space-y-3'>
<h2 className='text-[16px] font-[700] text-[#000]'>{data.title}</h2>
<p className='text-[14px] font-[600] text-[#525252]'>{data.challenge}</p>
<p className='text-[14px] font-[600] text-[#9D9D9D]'>{data.question}</p>
</div>
</div>
<button className='bg-[#000] text-[#FFF] rounded-[8px] px-16 py-3 h-fit text-[18px] font-[600]'>Start</button>
</div>
))}
</div>
</TabPane>
<TabPane tab="Completed" key="2">
<div className='flex flex-col gap-6'>
{knowledgeData.map(data => (
<div key={data.id} className='flex flex-row justify-between px-6 place-items-center'>
<div className='flex flex-row justify-between gap-6'>
<img src={data.img} alt="" />
<div className='flex flex-col space-y-3'>
<h2 className='text-[16px] font-[700] text-[#000]'>{data.title}</h2>
<p className='text-[14px] font-[600] text-[#525252]'>{data.challenge}</p>
<p className='text-[14px] font-[600] text-[#9D9D9D]'>{data.question}</p>
</div>
</div>
<p className='bg-[#000] text-[#FFF] rounded-[8px] px-16 py-3 h-fit text-[18px] font-[600]'>Review</p>
</div>
))}
</div>
</TabPane>
</Tabs>
</div>
{/* <h2 className='text-[20px] font-[700] inline-flex p-6'>Knowledge Quests <img src="/assets/right-arrow.svg" alt="" /></h2> */}
</div>
<div className='xl:col-span-2'>
<h2 className='text-[20px] font-[700] inline-flex px-4 pt-4'>Top Performers <img src="/assets/right-arrow.svg" alt="" /></h2>
<p className='text-[16px] font-[700] text-[#6E6E6E] px-4 pb-4 mb-28'>Knowledge Quest</p>
<div className='flex flex-row justify-between place-items-center space-x-2 border-b-[1px] border-[#CFCFCF]'>
<div className='w-full mx-auto h-[88px] border-x-[1px] border-t-[1px] border-[#CFCFCF] rounded-t-[10px] justify-center place-items-center mx-auto py-4'>
<div className='-mt-10 relative flex flex-col justify-center place-items-center'>
<img className='mx-auto h-[52px] w-[60px] ' src={secondHighestRank.avatar} alt="" />
<img className='absolute mt-12' src="/assets/bacth2.svg" alt="" />
</div>
<p className='text-[12px] font-[700] text-center mt-4'>{secondHighestRank.name}</p>
<p className='text-[12px] font-[700] text-center'>{secondHighestRank.score}</p>
</div>
<div className='w-full mx-auto h-[130px] -mt-[42px] border-x-[1px] border-t-[1px] border-[#CFCFCF] rounded-t-[10px] justify-center place-items-center mx-auto py-4'>
<div className='-mt-10 relative flex flex-col justify-center place-items-center'>
<img className='-mt-10' src="/assets/crown.png" alt="" />
<img className='mx-auto h-[52px] w-[60px]' src={highestRank.avatar} alt="" />
<img className='absolute mt-12' src="/assets/bacth1.svg" alt="" />
</div>
<p className='text-[12px] font-[700] text-center mt-4'>{highestRank.name}</p>
<p className='text-[12px] font-[700] text-center'>{highestRank.score}</p>
</div>
<div className='w-full mx-auto h-[88px] border-x-[1px] border-t-[1px] border-[#CFCFCF] rounded-t-[10px] justify-center place-items-center mx-auto py-4'>
<div className='-mt-10 relative flex flex-col justify-center place-items-center'>
<img className='mx-auto h-[52px] w-[60px]' src={thirdHighestRank.avatar} alt="" />
<img className='absolute mt-12' src="/assets/bacth3.svg" alt="" />
</div>
<p className='text-[12px] font-[700] text-center mt-4'>{thirdHighestRank.name}</p>
<p className='text-[12px] font-[700] text-center'>{thirdHighestRank.score}</p>
</div>
</div>
<div className='flex flex-col'>
{sortedData.slice(3).map(data => (
<div key={data.id} className='flex flex-row justify-between place-items-center border-b-[1px] border-[#CFCFCF] p-2'>
<p className='text-[11px] font-[700]'># {data.rank}</p>
<img className='w-[35px] h-[35px]' src={data.avatar} alt="" />
<div>
<p className='text-[14px] font-[700]'>{data.name}</p>
<p className='text-[10px] font-[700] text-[#6E6E6E]'>{data.program}</p>
</div>
<div className='flex flex-col justify-center place-items-center'>
<img src="/assets/points-icon.svg" alt="" />
<p className='text-[10px] font-[700]'>{data.points} Points</p>
</div>
</div>
))}
</div>
</div>
</div>
</section>
</Content>
</Layout>
</Layout>
</Layout>
);
};
export default App;

View File

@ -0,0 +1 @@
<?xml version="1.0" encoding="utf-8"?><svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 110.01 122.88" style="enable-background:new 0 0 110.01 122.88" xml:space="preserve"><style type="text/css">.st0{fill-rule:evenodd;clip-rule:evenodd;}</style><g><path class="st0" d="M1.87,14.69h22.66L24.5,14.3V4.13C24.5,1.86,26.86,0,29.76,0c2.89,0,5.26,1.87,5.26,4.13V14.3l-0.03,0.39 h38.59l-0.03-0.39V4.13C73.55,1.86,75.91,0,78.8,0c2.89,0,5.26,1.87,5.26,4.13V14.3l-0.03,0.39h24.11c1.03,0,1.87,0.84,1.87,1.87 v19.46c0,1.03-0.84,1.87-1.87,1.87H1.87C0.84,37.88,0,37.04,0,36.01V16.55C0,15.52,0.84,14.69,1.87,14.69L1.87,14.69z M0.47,42.19 h109.08c0.26,0,0.46,0.21,0.46,0.46l0,0v79.76c0,0.25-0.21,0.46-0.46,0.46l-109.08,0c-0.25,0-0.47-0.21-0.47-0.46V42.66 C0,42.4,0.21,42.19,0.47,42.19L0.47,42.19L0.47,42.19z M97.27,52.76H83.57c-0.83,0-1.5,0.63-1.5,1.4V66.9c0,0.77,0.67,1.4,1.5,1.4 h13.71c0.83,0,1.51-0.63,1.51-1.4V54.16C98.78,53.39,98.1,52.76,97.27,52.76L97.27,52.76z M12.24,74.93h13.7 c0.83,0,1.51,0.63,1.51,1.4v12.74c0,0.77-0.68,1.4-1.51,1.4H12.71c-0.83,0-1.5-0.63-1.5-1.4V75.87c0-0.77,0.68-1.4,1.5-1.4 L12.24,74.93L12.24,74.93z M12.24,97.11h13.7c0.83,0,1.51,0.63,1.51,1.4v12.74c0,0.77-0.68,1.4-1.51,1.4l-13.24,0 c-0.83,0-1.5-0.63-1.5-1.4V98.51c0-0.77,0.68-1.4,1.5-1.4L12.24,97.11L12.24,97.11z M12.24,52.76h13.7c0.83,0,1.51,0.63,1.51,1.4 V66.9c0,0.77-0.68,1.4-1.51,1.4l-13.24,0c-0.83,0-1.5-0.63-1.5-1.4V54.16c0-0.77,0.68-1.4,1.5-1.4L12.24,52.76L12.24,52.76z M36.02,52.76h13.71c0.83,0,1.5,0.63,1.5,1.4V66.9c0,0.77-0.68,1.4-1.5,1.4l-13.71,0c-0.83,0-1.51-0.63-1.51-1.4V54.16 C34.51,53.39,35.19,52.76,36.02,52.76L36.02,52.76L36.02,52.76z M36.02,74.93h13.71c0.83,0,1.5,0.63,1.5,1.4v12.74 c0,0.77-0.68,1.4-1.5,1.4H36.02c-0.83,0-1.51-0.63-1.51-1.4V75.87c0-0.77,0.68-1.4,1.51-1.4V74.93L36.02,74.93z M36.02,97.11h13.71 c0.83,0,1.5,0.63,1.5,1.4v12.74c0,0.77-0.68,1.4-1.5,1.4l-13.71,0c-0.83,0-1.51-0.63-1.51-1.4V98.51 C34.51,97.74,35.19,97.11,36.02,97.11L36.02,97.11L36.02,97.11z M59.79,52.76H73.5c0.83,0,1.51,0.63,1.51,1.4V66.9 c0,0.77-0.68,1.4-1.51,1.4l-13.71,0c-0.83,0-1.51-0.63-1.51-1.4V54.16C58.29,53.39,58.96,52.76,59.79,52.76L59.79,52.76 L59.79,52.76z M59.79,74.93H73.5c0.83,0,1.51,0.63,1.51,1.4v12.74c0,0.77-0.68,1.4-1.51,1.4H59.79c-0.83,0-1.51-0.63-1.51-1.4 V75.87c0-0.77,0.68-1.4,1.51-1.4V74.93L59.79,74.93z M97.27,74.93H83.57c-0.83,0-1.5,0.63-1.5,1.4v12.74c0,0.77,0.67,1.4,1.5,1.4 h13.71c0.83,0,1.51-0.63,1.51-1.4l0-13.21c0-0.77-0.68-1.4-1.51-1.4L97.27,74.93L97.27,74.93z M97.27,97.11H83.57 c-0.83,0-1.5,0.63-1.5,1.4v12.74c0,0.77,0.67,1.4,1.5,1.4h13.71c0.83,0,1.51-0.63,1.51-1.4l0-13.21c0-0.77-0.68-1.4-1.51-1.4 L97.27,97.11L97.27,97.11z M59.79,97.11H73.5c0.83,0,1.51,0.63,1.51,1.4v12.74c0,0.77-0.68,1.4-1.51,1.4l-13.71,0 c-0.83,0-1.51-0.63-1.51-1.4V98.51C58.29,97.74,58.96,97.11,59.79,97.11L59.79,97.11L59.79,97.11z M7.01,47.71h96.92 c0.52,0,0.94,0.44,0.94,0.94v67.77c0,0.5-0.44,0.94-0.94,0.94H6.08c-0.5,0-0.94-0.42-0.94-0.94V49.58 C5.14,48.55,5.98,47.71,7.01,47.71L7.01,47.71L7.01,47.71z M78.8,29.4c2.89,0,5.26-1.87,5.26-4.13V15.11l-0.03-0.41H73.58 l-0.03,0.41v10.16C73.55,27.54,75.91,29.4,78.8,29.4L78.8,29.4L78.8,29.4z M29.76,29.4c2.89,0,5.26-1.87,5.26-4.13V15.11 l-0.03-0.41H24.53l-0.03,0.41v10.16C24.5,27.54,26.86,29.4,29.76,29.4L29.76,29.4z"/></g></svg>

After

Width:  |  Height:  |  Size: 3.3 KiB

View File

@ -0,0 +1,107 @@
.ant-menu-light .ant-menu-item-selected{
color: #ED9545;
border-left: 3px solid #ED9545 ;
background: transparent;
}
/* App.css */
.custom-menu .ant-menu-item{
border-radius: 0; /* Remove border-radius */
color: #6E6E6E;
}
:where(.css-dev-only-do-not-override-1uq9j6g).ant-menu-light .ant-menu-item a, :where(.css-dev-only-do-not-override-1uq9j6g).ant-menu-light>.ant-menu .ant-menu-item a, :where(.css-dev-only-do-not-override-1uq9j6g).ant-menu-light .ant-menu-item a:hover, :where(.css-dev-only-do-not-override-1uq9j6g).ant-menu-light>.ant-menu .ant-menu-item a:hover{
color: #6E6E6E;
}
/* Specific styling for parent menu items (non-selected) */
.custom-menu .ant-menu-submenu-title {
border-bottom: 1px solid #CFCFCF; /* Default border color for parent items */
border-radius: 0; /* Remove border-radius for parent items */
font-size: 18px;
color: #000;
font-weight: 700;
padding-top: 40px;
padding-bottom: 40px;
--icon-color: #000; /* Default icon color */
}
/* Specific styling for selected parent menu items */
.custom-menu .ant-menu-submenu-selected .ant-menu-submenu-title,
.custom-menu .ant-menu-submenu-title.ant-menu-submenu-title-selected,
.custom-menu .ant-menu-submenu-title .ant-menu-submenu-open {
color: #ED9545; /* Selected text color for parent items */
border-bottom: 1px solid #CFCFCF; /* Selected border color for parent items */
--icon-color: #ED9545; /* Selected icon color */
}
/* Ensure parent item remains #ED9545 when any child is selected */
.custom-menu .ant-menu-submenu-open > .ant-menu-submenu-title {
color: #ED9545; /* Ensure parent item text color */
border-bottom: 1px solid #CFCFCF; /* Ensure parent item border color */
--icon-color: #ED9545; /* Ensure parent item icon color */
}
/* Ensure parent item text color reverts to #000 when submenu is collapsed */
.custom-menu .ant-menu-submenu-closed > .ant-menu-submenu-title {
color: #000; /* Ensure parent item text color */
--icon-color: #000; /* Ensure parent item icon color */
}
/* For Custom Scrollbar */
/* Custom scrollbar for WebKit browsers */
::-webkit-scrollbar {
width: 3px; /* Width of the scrollbar */
}
::-webkit-scrollbar-track {
background: #fcfcfc; /* Track background */
}
::-webkit-scrollbar-thumb {
background: #CFCFCF; /* Scrollbar color */
border-radius: 10px; /* Rounded corners */
}
::-webkit-scrollbar-thumb:hover {
background: #555; /* Color when hovering */
}
/* Firefox scrollbar styling */
.custom-gradient-border {
border: 4.32px solid transparent;
border-image-source: linear-gradient(159.09deg, #FFFFFF 13.82%, rgba(0, 0, 0, 0) 97.01%);
border-image-slice: 1;
border-radius: 8px; /* Adjust as needed */
}
.ant-layout-sider-children .ant-dropdown-trigger{
display: none;
}
@media(max-width:1000px){
:where(.css-dev-only-do-not-override-1uq9j6g).ant-layout {
display: flex;
flex: auto;
min-height: 0;
background: #f5f5f5;
}
:where(.css-dev-only-do-not-override-1uq9j6g).ant-layout.ant-layout-has-sider >.ant-layout, :where(.css-dev-only-do-not-override-1uq9j6g).ant-layout.ant-layout-has-sider >.ant-layout-content {
width: auto;
}
.md\:grid-cols-\[350px_1fr\] {
grid-template-columns:1fr;
}
a.ant-dropdown-trigger{
display: none;
}
.ant-layout-sider-children .ant-dropdown-trigger{
display: block;
margin-left: 28px;
}
}