aboutsummaryrefslogtreecommitdiff
path: root/lib/waev_web
diff options
context:
space:
mode:
Diffstat (limited to 'lib/waev_web')
-rw-r--r--lib/waev_web/controllers/exports_controller.ex2
-rw-r--r--lib/waev_web/templates/exports/show.html.eex4
-rw-r--r--lib/waev_web/views/exports_view.ex49
3 files changed, 45 insertions, 10 deletions
diff --git a/lib/waev_web/controllers/exports_controller.ex b/lib/waev_web/controllers/exports_controller.ex
index 8d16cb5..a5a1f51 100644
--- a/lib/waev_web/controllers/exports_controller.ex
+++ b/lib/waev_web/controllers/exports_controller.ex
@@ -7,7 +7,7 @@ defmodule WaevWeb.ExportsController do
case Waev.Export.get(id, page, size) do
{:ok, export} ->
- render(conn, "show.html", id: id, export: export, page: page, size: size)
+ render(conn, "show.html", id: id, export: export)
:error ->
conn
diff --git a/lib/waev_web/templates/exports/show.html.eex b/lib/waev_web/templates/exports/show.html.eex
index 948c125..ef35265 100644
--- a/lib/waev_web/templates/exports/show.html.eex
+++ b/lib/waev_web/templates/exports/show.html.eex
@@ -11,7 +11,7 @@
</div>
<% else %>
<%= for {date, blocks} <- process_messages(@export.messages) do %>
- <div class="row row--padded">
+ <div class="row row-center row--padded">
<div class="middle-box">
<%= date %>
</div>
@@ -53,4 +53,4 @@
<% end %>
<% end %>
<% end %>
-<%= pagination_bar(assigns, @page, @size) %>
+<%= pagination_bar(assigns, @export.pagination) %>
diff --git a/lib/waev_web/views/exports_view.ex b/lib/waev_web/views/exports_view.ex
index 62eefc1..9175122 100644
--- a/lib/waev_web/views/exports_view.ex
+++ b/lib/waev_web/views/exports_view.ex
@@ -114,15 +114,50 @@ defmodule WaevWeb.ExportsView do
String.replace(text, "\n", "<br />")
end
- def pagination_bar(assigns, page, size) do
- prev = if page == 0, do: 0, else: page - 1
- # TODO max
- next = page + 1
+ def pagination_bar(assigns, %{page: page, size: size, pages: pages}) do
+ offset = 1 # How many buttons to see in each side
+ path = fn page ->
+ ~E"""
+ <%= Routes.exports_path(@conn, :show, @id, page: page, size: size) %>
+ """
+ end
+
+ btn = fn enabled, page, text ->
+ ~E"""
+ <a class="button button-clear"
+ <%= if enabled do %>
+ href="<%= path.(page) %>"
+ <% else %>
+ disabled
+ <% end %>>
+ <%= text %>
+ </a>
+ """
+ end
~E"""
- <div>
- <a href="<%= Routes.exports_path(@conn, :show, @id, page: prev, size: size) %>">Left</a>
- <a href="<%= Routes.exports_path(@conn, :show, @id, page: next, size: size) %>">Right</a>
+ <div class="row row-center row--padded">
+ <%= btn.(page != 1, page-1, "<") %>
+ <%= if (page > 1 + offset) do %>
+ <%= btn.(true, 1, "1") %>
+ <% end %>
+ <%= if (page > 1 + offset + 1) do %>
+ ...
+ <% end %>
+ <%= for p <- max(1, page-offset) .. min(pages, page+offset) do %>
+ <%= if (p == page) do %>
+ <a disabled class="button"><%= page %></a>
+ <% else %>
+ <%= btn.(p != page, p, p) %>
+ <% end %>
+ <% end %>
+ <%= if (page < pages - offset - 1) do %>
+ ...
+ <% end %>
+ <%= if (page < pages - offset) do %>
+ <%= btn.(true, pages, pages) %>
+ <% end %>
+ <%= btn.(page != pages, page+1, ">") %>
</div>
"""
end