Mobile-first UI for my schedule
This commit is contained in:
@ -13,36 +13,50 @@ export default function MySchedulePage({ assignments }) {
|
|||||||
|
|
||||||
const { data: session, status } = useSession();
|
const { data: session, status } = useSession();
|
||||||
if (status === "loading") {
|
if (status === "loading") {
|
||||||
return <div>Loading...</div>;
|
return <div className="flex justify-center items-center h-screen">Loading...</div>;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Layout>
|
<Layout>
|
||||||
<ProtectedRoute allowedRoles={[UserRole.ADMIN, UserRole.POWERUSER, UserRole.USER]}>
|
<ProtectedRoute allowedRoles={[UserRole.ADMIN, UserRole.POWERUSER, UserRole.USER]}>
|
||||||
<h1 className="text-3xl font-bold">Моите смени</h1>
|
|
||||||
<div className="container mx-auto p-4">
|
<div className="container mx-auto p-4">
|
||||||
{assignments && assignments.map((assignment) => (
|
<h1 className="text-2xl md:text-3xl font-bold text-center my-4">Моите смени</h1>
|
||||||
<div className="flex items-center space-x-2 py-1" key={assignment.dateStr}>
|
<div className="space-y-4">
|
||||||
<div className="font-bold flex-shrink-0 w-6 text-right">{assignment.dateStr + ":"}</div> {/*This is the column for the date. I've given it a fixed width (w-8) which you can adjust*/}
|
{assignments && assignments.map((assignment) => (
|
||||||
<div className="flex-grow flex">
|
<div key={assignment.dateStr} className="bg-white shadow overflow-hidden rounded-lg">
|
||||||
<div className="flow space-x-2 bg-gray-200 rounded-lg shadow-md py-2 px-3" key={assignment.id}>
|
<div className="px-4 py-5 sm:px-6">
|
||||||
<span>{GetTimeFormat(assignment.shift.startTime)} - {GetTimeFormat(assignment.shift.endTime)}</span>
|
<h3 className="text-lg leading-6 font-medium text-gray-900">{assignment.dateStr}</h3>
|
||||||
<button
|
</div>
|
||||||
className={`text-sm text-white font-semibold px-2 rounded-lg shadow ${assignment.isConfirmed ? "bg-yellow-400 hover:bg-yellow-500" : "bg-red-400 hover:bg-red-500"}`}
|
<div className="border-t border-gray-200">
|
||||||
onClick={() => searchReplacement(assignment.id)}
|
<dl>
|
||||||
>
|
<div className="bg-gray-50 px-4 py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
|
||||||
Търси заместник
|
<dt className="text-sm font-medium text-gray-500">Час</dt>
|
||||||
</button>
|
<dd className="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2">
|
||||||
<button
|
{GetTimeFormat(assignment.shift.startTime)} - {GetTimeFormat(assignment.shift.endTime)}
|
||||||
className="text-sm bg-green-400 hover:bg-green-500 text-white font-semibold px-2 rounded-lg shadow"
|
</dd>
|
||||||
onClick={() => AddToGoogleCalendar(assignment.id)}
|
</div>
|
||||||
>
|
<div className="bg-white px-4 py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
|
||||||
Добави в календар
|
<dt className="text-sm font-medium text-gray-500">Действия</dt>
|
||||||
</button>
|
<dd className="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2">
|
||||||
|
<button
|
||||||
|
className="mr-2 mb-2 inline-flex items-center px-3 py-2 border border-transparent text-sm leading-4 font-medium rounded-md shadow-sm text-white bg-green-600 hover:bg-green-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-green-500"
|
||||||
|
onClick={() => AddToGoogleCalendar(assignment.id)}
|
||||||
|
>
|
||||||
|
Добави в календар
|
||||||
|
</button>
|
||||||
|
<button
|
||||||
|
className="inline-flex items-center px-3 py-2 border border-transparent text-sm leading-4 font-medium rounded-md shadow-sm text-white bg-blue-600 hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500"
|
||||||
|
onClick={() => searchReplacement(assignment.id)}
|
||||||
|
>
|
||||||
|
Търси заместник
|
||||||
|
</button>
|
||||||
|
</dd>
|
||||||
|
</div>
|
||||||
|
</dl>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
))}
|
||||||
))}
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</ProtectedRoute>
|
</ProtectedRoute>
|
||||||
</Layout>
|
</Layout>
|
||||||
|
Reference in New Issue
Block a user