exmr/lib/exmr_web/live/exam_live/index.html.heex

61 lines
1.7 KiB
Text
Raw Normal View History

2024-11-14 23:33:29 +02:00
<.header>
Listing Exams
<div>
<button phx-click="sort" phx-value-by="subject" class="font-light"><%= gettext("Sort by Subject") %></button>
<a>|</a>
<button phx-click="sort" phx-value-by="date" class="font-light"><%= gettext("Sort by Date") %></button>
</div>
2024-11-14 23:33:29 +02:00
<:actions>
<.link patch={~p"/exams/new"}>
2024-12-01 18:31:23 +02:00
<.button class="dark:bg-sky-300 text-white dark:text-black/80 dark:hover:bg-sky-400">
<%= gettext("New Exam") %>
2024-12-01 18:31:23 +02:00
</.button>
2024-11-14 23:33:29 +02:00
</.link>
</:actions>
</.header>
<div class="divide-y">
<div :for={exam <- @exams} class="py-2 flex gap-2">
<div class="grow">
<div class="font-bold"><%= exam.subject %></div>
2024-12-09 21:05:13 +02:00
<div class="font-sm">
<%= exam.date %> |
<b>
<%= case Date.diff(exam.date, Date.utc_today()) do
0 -> gettext("Today")
1 -> gettext("Tomorrow")
x when x > 1 -> "#{x} #{gettext("days left")}"
x when x < 0 -> "#{x*-1} #{gettext("days passed")}"
end %>
</b>
2024-12-09 21:05:13 +02:00
</div>
2024-11-14 23:33:29 +02:00
</div>
2024-11-27 18:02:28 +02:00
<button
phx-click="edit"
phx-value-id={exam.id}
class="bg-blue-500 hover:bg-blue-700 text-white font-bold py-2 px-3 rounded-md"
>
<%= gettext("Edit") %>
2024-11-27 18:02:28 +02:00
</button>
<button
phx-click="remove"
phx-value-id={exam.id}
class="bg-red-500 hover:bg-red-700 text-white font-bold py-2 px-3 rounded-md"
2024-11-14 23:33:29 +02:00
>
<%= gettext("Remove") %>
</button>
</div>
</div>
2024-11-14 23:33:29 +02:00
<.modal :if={@live_action in [:new, :edit]} id="exam-modal" show on_cancel={JS.patch(~p"/exams")}>
<.live_component
module={ExmrWeb.ExamLive.FormComponent}
id={@exam.id || :new}
title={@page_title}
action={@live_action}
exam={@exam}
patch={~p"/exams"}
/>
</.modal>