mirror of
https://github.com/philomena-dev/philomena.git
synced 2024-11-23 20:18:00 +01:00
admin badge user list
This commit is contained in:
parent
991cab61bf
commit
1435149d32
4 changed files with 62 additions and 1 deletions
31
lib/philomena_web/controllers/admin/badge/user_controller.ex
Normal file
31
lib/philomena_web/controllers/admin/badge/user_controller.ex
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
defmodule PhilomenaWeb.Admin.Badge.UserController do
|
||||||
|
use PhilomenaWeb, :controller
|
||||||
|
|
||||||
|
alias Philomena.Users.User
|
||||||
|
alias Philomena.Badges.Badge
|
||||||
|
alias Philomena.Repo
|
||||||
|
import Ecto.Query
|
||||||
|
|
||||||
|
plug :verify_authorized
|
||||||
|
plug :load_resource, model: Badge, id_name: "badge_id", persisted: true
|
||||||
|
|
||||||
|
def index(conn, _params) do
|
||||||
|
badge = conn.assigns.badge
|
||||||
|
|
||||||
|
users =
|
||||||
|
User
|
||||||
|
|> join(:inner, [u], _ in assoc(u, :awards))
|
||||||
|
|> where([_u, a], a.badge_id == ^badge.id)
|
||||||
|
|> order_by([u, _a], asc: u.name)
|
||||||
|
|> Repo.paginate(conn.assigns.pagination)
|
||||||
|
|
||||||
|
render(conn, "index.html", title: "Users with badge #{badge.title}", users: users)
|
||||||
|
end
|
||||||
|
|
||||||
|
defp verify_authorized(conn, _opts) do
|
||||||
|
case Canada.Can.can?(conn.assigns.current_user, :index, Badge) do
|
||||||
|
true -> conn
|
||||||
|
_false -> PhilomenaWeb.NotAuthorizedPlug.call(conn)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -230,7 +230,9 @@ defmodule PhilomenaWeb.Router do
|
||||||
resources "/adverts", AdvertController, except: [:show]
|
resources "/adverts", AdvertController, except: [:show]
|
||||||
|
|
||||||
resources "/forums", ForumController, except: [:show, :delete]
|
resources "/forums", ForumController, except: [:show, :delete]
|
||||||
resources "/badges", BadgeController, except: [:show, :delete]
|
resources "/badges", BadgeController, except: [:show, :delete] do
|
||||||
|
resources "/users", Badge.UserController, only: [:index]
|
||||||
|
end
|
||||||
resources "/mod_notes", ModNoteController, except: [:show]
|
resources "/mod_notes", ModNoteController, except: [:show]
|
||||||
resources "/users", UserController, only: [:index, :edit, :update] do
|
resources "/users", UserController, only: [:index, :edit, :update] do
|
||||||
resources "/avatar", User.AvatarController, only: [:delete], singleton: true
|
resources "/avatar", User.AvatarController, only: [:delete], singleton: true
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
h1
|
||||||
|
' Users with
|
||||||
|
=> @badge.title
|
||||||
|
' badge
|
||||||
|
|
||||||
|
- route = fn p -> Routes.admin_badge_user_path(@conn, :index, p) end
|
||||||
|
- pagination = render PhilomenaWeb.PaginationView, "_pagination.html", page: @users, route: route, conn: @conn
|
||||||
|
|
||||||
|
.block
|
||||||
|
.block__header
|
||||||
|
= pagination
|
||||||
|
|
||||||
|
.block__content
|
||||||
|
table.table
|
||||||
|
thead
|
||||||
|
tr
|
||||||
|
th User
|
||||||
|
tbody
|
||||||
|
= for user <- @users do
|
||||||
|
tr
|
||||||
|
td
|
||||||
|
= link user.name, to: Routes.profile_path(@conn, :show, user)
|
||||||
|
|
||||||
|
.block__header.block__header--light
|
||||||
|
= pagination
|
3
lib/philomena_web/views/admin/badge/user_view.ex
Normal file
3
lib/philomena_web/views/admin/badge/user_view.ex
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
defmodule PhilomenaWeb.Admin.Badge.UserView do
|
||||||
|
use PhilomenaWeb, :view
|
||||||
|
end
|
Loading…
Reference in a new issue