aboutsummaryrefslogtreecommitdiff
path: root/src/Enmarcha.Backend/Views/Alerts/Index.cshtml
blob: 114f3a577bce2efaae9e5014a73a05412de35918 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
@model List<Enmarcha.Backend.Data.Models.ServiceAlert>
@using Enmarcha.Backend.Data.Models
@using Enmarcha.Backend.Helpers
@{
    ViewData["Title"] = "Alertas de servicio";
}

@if (TempData["SuccessMessage"] is string successMsg)
{
    <div class="alert alert-success alert-dismissible fade show d-flex align-items-center gap-2 mb-4" role="alert">
        <i class="bi bi-check-circle-fill"></i> @successMsg
        <button type="button" class="btn-close ms-auto" data-bs-dismiss="alert"></button>
    </div>
}

<div class="d-flex justify-content-between align-items-center mb-4">
    <h1 class="h3 mb-0">
        <i class="bi bi-exclamation-triangle me-2 text-warning"></i>Alertas de servicio
    </h1>
    <a href="/backoffice/alerts/create" class="btn btn-primary">
        <i class="bi bi-plus-lg me-1"></i> Nueva alerta
    </a>
</div>

@if (!Model.Any())
{
    <div class="alert alert-secondary d-flex align-items-center gap-2">
        <i class="bi bi-info-circle"></i>
        No hay alertas registradas.
    </div>
}
else
{
    <div class="card shadow-sm">
        <div class="table-responsive">
            <table class="table table-hover align-middle mb-0">
                <thead class="table-dark">
                    <tr>
                        <th>Título</th>
                        <th>Fase</th>
                        <th>Causa</th>
                        <th>Efecto</th>
                        <th>Evento</th>
                        <th style="width:1%"></th>
                    </tr>
                </thead>
                <tbody>
                    @foreach (var alert in Model)
                    {
                        var phase = alert.GetPhase();
                        var (badgeClass, phaseLabel) = phase switch
                        {
                            AlertPhase.Draft      => ("bg-secondary", "Borrador"),
                            AlertPhase.PreNotice  => ("bg-info text-dark", "Pre-aviso"),
                            AlertPhase.Active     => ("bg-success", "Activa"),
                            AlertPhase.Finished   => ("bg-warning text-dark", "Finalizada"),
                            _                     => ("bg-dark", "Archivada")
                        };
                        <tr>
                            <td>
                                <div class="fw-semibold">@alert.Header.Get("es")</div>
                                <div class="text-muted small font-monospace">@alert.Id[..Math.Min(8, alert.Id.Length)]…</div>
                            </td>
                            <td><span class="badge @badgeClass">@phaseLabel</span></td>
                            <td class="small">@alert.Cause.GetDescription()</td>
                            <td class="small">@alert.Effect.GetDescription()</td>
                            <td class="small text-nowrap">
                                @alert.EventStartDate.ToString("dd/MM/yy HH:mm")<br />
                                <span class="text-muted">→ @alert.EventEndDate.ToString("dd/MM/yy HH:mm")</span>
                            </td>
                            <td class="text-end text-nowrap">
                                <a href="/backoffice/alerts/@alert.Id/edit"
                                   class="btn btn-sm btn-outline-secondary"
                                   title="Editar">
                                    <i class="bi bi-pencil"></i>
                                </a>
                                <form action="/backoffice/alerts/@alert.Id/push" method="post" class="d-inline ms-1">
                                    @Html.AntiForgeryToken()
                                    <button type="submit" class="btn btn-sm btn-outline-primary" title="Enviar notificación push">
                                        <i class="bi bi-bell"></i>
                                    </button>
                                </form>
                                <a href="/backoffice/alerts/@alert.Id/delete"
                                   class="btn btn-sm btn-outline-danger ms-1"
                                   title="Eliminar">
                                    <i class="bi bi-trash"></i>
                                </a>
                            </td>
                        </tr>
                    }
                </tbody>
            </table>
        </div>
    </div>
}