chore: prettier everywhere

This commit is contained in:
Julien Froidefond
2025-10-09 13:40:03 +02:00
parent f8100ae3e9
commit d9cf9a2655
303 changed files with 15420 additions and 9391 deletions

View File

@@ -12,52 +12,70 @@ interface CriticalDeadlinesCardProps {
disableHover?: boolean;
}
export function CriticalDeadlinesCard({ overdue, critical, warning, disableHover = false }: CriticalDeadlinesCardProps) {
export function CriticalDeadlinesCard({
overdue,
critical,
warning,
disableHover = false,
}: CriticalDeadlinesCardProps) {
const { tags: availableTags } = useTasksContext();
// Combiner toutes les tâches urgentes et trier par urgence
const urgentTasks = [...overdue, ...critical, ...warning]
.sort((a, b) => {
// En retard d'abord, puis critique, puis attention
const urgencyOrder: Record<string, number> = { 'overdue': 0, 'critical': 1, 'warning': 2 };
if (urgencyOrder[a.urgencyLevel] !== urgencyOrder[b.urgencyLevel]) {
return urgencyOrder[a.urgencyLevel] - urgencyOrder[b.urgencyLevel];
}
// Si même urgence, trier par jours restants
return a.daysRemaining - b.daysRemaining;
});
const urgentTasks = [...overdue, ...critical, ...warning].sort((a, b) => {
// En retard d'abord, puis critique, puis attention
const urgencyOrder: Record<string, number> = {
overdue: 0,
critical: 1,
warning: 2,
};
if (urgencyOrder[a.urgencyLevel] !== urgencyOrder[b.urgencyLevel]) {
return urgencyOrder[a.urgencyLevel] - urgencyOrder[b.urgencyLevel];
}
// Si même urgence, trier par jours restants
return a.daysRemaining - b.daysRemaining;
});
const getUrgencyStyle = (task: DeadlineTask) => {
if (task.urgencyLevel === 'overdue') {
return {
icon: '🔴',
text: task.daysRemaining === -1 ? 'En retard de 1 jour' : `En retard de ${Math.abs(task.daysRemaining)} jours`,
style: 'border-[var(--destructive)]/60'
text:
task.daysRemaining === -1
? 'En retard de 1 jour'
: `En retard de ${Math.abs(task.daysRemaining)} jours`,
style: 'border-[var(--destructive)]/60',
};
} else if (task.urgencyLevel === 'critical') {
return {
icon: '🟠',
text: task.daysRemaining === 0 ? 'Échéance aujourd\'hui' :
task.daysRemaining === 1 ? 'Échéance demain' :
`Dans ${task.daysRemaining} jours`,
style: 'border-[var(--accent)]/60'
text:
task.daysRemaining === 0
? "Échéance aujourd'hui"
: task.daysRemaining === 1
? 'Échéance demain'
: `Dans ${task.daysRemaining} jours`,
style: 'border-[var(--accent)]/60',
};
} else {
return {
icon: '🟡',
text: `Dans ${task.daysRemaining} jours`,
style: 'border-[var(--yellow)]/60'
style: 'border-[var(--yellow)]/60',
};
}
};
if (urgentTasks.length === 0) {
return (
<Card variant="glass" className="p-6 hover:shadow-lg transition-shadow">
<h3 className="text-lg font-semibold mb-4">Tâches Urgentes</h3>
<div className="text-center py-8">
<div className="text-4xl mb-2">🎉</div>
<h4 className="text-lg font-medium mb-2" style={{ color: 'var(--green)' }}>Excellent !</h4>
<h4
className="text-lg font-medium mb-2"
style={{ color: 'var(--green)' }}
>
Excellent !
</h4>
<p className="text-sm text-[var(--muted-foreground)]">
Aucune tâche urgente ou critique
</p>
@@ -75,24 +93,29 @@ export function CriticalDeadlinesCard({ overdue, critical, warning, disableHover
</div>
</div>
<div className="space-y-2 max-h-40 overflow-y-auto scrollbar-thin scrollbar-track-transparent pr-2" style={{ scrollbarColor: 'var(--muted) transparent' }}>
<div
className="space-y-2 max-h-40 overflow-y-auto scrollbar-thin scrollbar-track-transparent pr-2"
style={{ scrollbarColor: 'var(--muted) transparent' }}
>
{urgentTasks.map((task) => {
const urgencyStyle = getUrgencyStyle(task);
const getCardClassName = (urgencyLevel: string) => {
let baseClass = '';
if (urgencyLevel === 'overdue') {
baseClass = 'border-[var(--destructive)]/60 shadow-[var(--destructive)]/20';
baseClass =
'border-[var(--destructive)]/60 shadow-[var(--destructive)]/20';
} else if (urgencyLevel === 'critical') {
baseClass = 'border-[var(--accent)]/60 shadow-[var(--accent)]/20';
} else {
baseClass = 'border-[var(--yellow)]/60 shadow-[var(--yellow)]/20';
}
if (disableHover) {
baseClass += ' hover:scale-100 hover:shadow-none hover:border-current hover:-translate-y-0';
baseClass +=
' hover:scale-100 hover:shadow-none hover:border-current hover:-translate-y-0';
}
return baseClass;
};
@@ -118,7 +141,10 @@ export function CriticalDeadlinesCard({ overdue, critical, warning, disableHover
<div className="pt-3 border-t border-[var(--border)] mt-4">
<div className="flex flex-wrap gap-3 text-xs text-[var(--muted-foreground)] justify-center">
{overdue.length > 0 && (
<span className="font-medium" style={{ color: 'var(--destructive)' }}>
<span
className="font-medium"
style={{ color: 'var(--destructive)' }}
>
{overdue.length} en retard
</span>
)}