tududi/frontend/components/Task/TaskStatusBadge.tsx
Chris 4d2ea4212c
Cleanup statuses (#724)
* Cleanup statuses

* Add more statuses

* Hide buttons

* fixup! Hide buttons

* Show subtasks on click

* Fix status button in taskdetails page

* fixup! Fix status button in taskdetails page

* fixup! fixup! Fix status button in taskdetails page

* Fix today planned query
2025-12-19 11:13:27 +02:00

60 lines
1.8 KiB
TypeScript

import React from 'react';
import {
MinusIcon,
CheckCircleIcon,
ArchiveBoxIcon,
ArrowPathIcon,
ClockIcon,
XCircleIcon,
CalendarIcon,
} from '@heroicons/react/24/solid';
import { StatusType } from '../../entities/Task';
import { getStatusString } from '../../constants/taskStatus';
interface TaskStatusBadgeProps {
status: StatusType | number;
className?: string;
}
const TaskStatusBadge: React.FC<TaskStatusBadgeProps> = ({
status,
className,
}) => {
const statusString = getStatusString(status);
let statusIcon;
switch (statusString) {
case 'not_started':
statusIcon = <MinusIcon className="h-4 w-4 text-gray-400" />;
break;
case 'planned':
statusIcon = <CalendarIcon className="h-4 w-4 text-purple-400" />;
break;
case 'in_progress':
statusIcon = <ArrowPathIcon className="h-4 w-4 text-blue-400" />;
break;
case 'waiting':
statusIcon = <ClockIcon className="h-4 w-4 text-yellow-400" />;
break;
case 'done':
statusIcon = <CheckCircleIcon className="h-4 w-4 text-green-400" />;
break;
case 'cancelled':
statusIcon = <XCircleIcon className="h-4 w-4 text-red-400" />;
break;
case 'archived':
statusIcon = <ArchiveBoxIcon className="h-4 w-4 text-gray-400" />;
break;
default:
statusIcon = <MinusIcon className="h-4 w-4 text-gray-400" />;
}
return (
<div className={`flex items-center md:px-2 ${className}`}>
{statusIcon}
{/* <span className="ml-2 text-xs font-medium inline md:hidden">{statusLabel}</span> */}
</div>
);
};
export default TaskStatusBadge;