tududi/frontend/components/Task/TaskDetails/TaskPriorityCard.tsx
2025-12-07 14:12:38 +02:00

91 lines
4.1 KiB
TypeScript

import React from 'react';
import { useTranslation } from 'react-i18next';
import { Task, PriorityType } from '../../../entities/Task';
interface TaskPriorityCardProps {
task: Task;
onUpdate: (priority: PriorityType) => Promise<void>;
}
const TaskPriorityCard: React.FC<TaskPriorityCardProps> = ({
task,
onUpdate,
}) => {
const { t } = useTranslation();
const handlePriorityClick = async (priority: PriorityType) => {
await onUpdate(priority);
};
return (
<div className="min-w-0">
<h4 className="text-sm font-semibold text-gray-700 dark:text-gray-300 mb-2">
{t('task.priority', 'Priority')}
</h4>
<div className="grid grid-cols-4 gap-2">
<button
type="button"
onClick={() => handlePriorityClick(null)}
className={`w-full min-w-0 px-2 sm:px-3 py-2 text-sm font-medium rounded transition-colors ${
task.priority === null || task.priority === undefined
? 'bg-gray-300 dark:bg-gray-600 text-gray-900 dark:text-gray-100'
: 'bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 hover:bg-gray-300 dark:hover:bg-gray-600'
}`}
title={t('priority.none', 'None')}
>
<span className="sm:hidden">-</span>
<span className="hidden sm:inline">
{t('priority.none', 'None')}
</span>
</button>
<button
type="button"
onClick={() => handlePriorityClick('low')}
className={`w-full min-w-0 px-2 sm:px-3 py-2 text-sm font-medium rounded transition-colors ${
task.priority === 'low' || task.priority === 0
? 'bg-blue-500 dark:bg-blue-600 text-white'
: 'bg-blue-100 dark:bg-blue-900/30 text-blue-700 dark:text-blue-300 hover:bg-blue-200 dark:hover:bg-blue-900/50'
}`}
title={t('priority.low', 'Low')}
>
<span className="sm:hidden">L</span>
<span className="hidden sm:inline">
{t('priority.low', 'Low')}
</span>
</button>
<button
type="button"
onClick={() => handlePriorityClick('medium')}
className={`w-full min-w-0 px-2 sm:px-3 py-2 text-sm font-medium rounded transition-colors ${
task.priority === 'medium' || task.priority === 1
? 'bg-yellow-500 dark:bg-yellow-600 text-white'
: 'bg-yellow-100 dark:bg-yellow-900/30 text-yellow-700 dark:text-yellow-300 hover:bg-yellow-200 dark:hover:bg-yellow-900/50'
}`}
title={t('priority.medium', 'Medium')}
>
<span className="sm:hidden">M</span>
<span className="hidden sm:inline">
{t('priority.medium', 'Med')}
</span>
</button>
<button
type="button"
onClick={() => handlePriorityClick('high')}
className={`w-full min-w-0 px-2 sm:px-3 py-2 text-sm font-medium rounded transition-colors ${
task.priority === 'high' || task.priority === 2
? 'bg-red-500 dark:bg-red-600 text-white'
: 'bg-red-100 dark:bg-red-900/30 text-red-700 dark:text-red-300 hover:bg-red-200 dark:hover:bg-red-900/50'
}`}
title={t('priority.high', 'High')}
>
<span className="sm:hidden">H</span>
<span className="hidden sm:inline">
{t('priority.high', 'High')}
</span>
</button>
</div>
</div>
);
};
export default TaskPriorityCard;