diff options
Diffstat (limited to 'lib/waev_web')
-rw-r--r-- | lib/waev_web/controllers/exports_controller.ex | 2 | ||||
-rw-r--r-- | lib/waev_web/templates/exports/show.html.eex | 4 | ||||
-rw-r--r-- | lib/waev_web/views/exports_view.ex | 49 |
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 |