статусы на русском языке
All checks were successful
Auto Deploy / deploy (push) Successful in 22s

This commit is contained in:
deonisii
2026-04-17 23:49:12 +03:00
parent 4f67bca4be
commit 9b86175929
3 changed files with 103 additions and 51 deletions

View File

@@ -3,13 +3,30 @@
import { useState } from "react";
const statuses = [
{ value: "NEW", label: "NEW" },
{ value: "IN_PROGRESS", label: "IN_PROGRESS" },
{ value: "CALL_SCHEDULED", label: "CALL_SCHEDULED" },
{ value: "WON", label: "WON" },
{ value: "LOST", label: "LOST" },
{ value: "NEW", label: "Новая" },
{ value: "IN_PROGRESS", label: "В работе" },
{ value: "CALL_SCHEDULED", label: "Назначен звонок" },
{ value: "WON", label: "Успешно" },
{ value: "LOST", label: "Закрыта" },
] as const;
function getStatusDot(value: string) {
switch (value) {
case "NEW":
return "bg-sky-400";
case "IN_PROGRESS":
return "bg-amber-400";
case "CALL_SCHEDULED":
return "bg-violet-400";
case "WON":
return "bg-emerald-400";
case "LOST":
return "bg-rose-400";
default:
return "bg-neutral-400";
}
}
export default function LeadStatusSelect({
leadId,
value,
@@ -21,6 +38,7 @@ export default function LeadStatusSelect({
const [isSaving, setIsSaving] = useState(false);
async function updateStatus(nextStatus: string) {
const prev = status;
setStatus(nextStatus);
setIsSaving(true);
@@ -34,11 +52,11 @@ export default function LeadStatusSelect({
});
if (!response.ok) {
setStatus(value);
setStatus(prev);
alert("Не удалось обновить статус");
}
} catch {
setStatus(value);
setStatus(prev);
alert("Ошибка сети");
} finally {
setIsSaving(false);
@@ -46,17 +64,20 @@ export default function LeadStatusSelect({
}
return (
<select
value={status}
disabled={isSaving}
onChange={(e) => updateStatus(e.target.value)}
className="rounded-xl border border-white/10 bg-black/30 px-3 py-2 text-sm outline-none"
>
{statuses.map((item) => (
<option key={item.value} value={item.value}>
{item.label}
</option>
))}
</select>
<div className="flex items-center gap-2">
<span className={`inline-block h-2.5 w-2.5 rounded-full ${getStatusDot(status)}`} />
<select
value={status}
disabled={isSaving}
onChange={(e) => updateStatus(e.target.value)}
className="rounded-xl border border-white/10 bg-black/30 px-3 py-2 text-sm outline-none"
>
{statuses.map((item) => (
<option key={item.value} value={item.value}>
{item.label}
</option>
))}
</select>
</div>
);
}