mirror of
https://github.com/tdurieux/anonymous_github.git
synced 2026-05-15 14:38:03 +02:00
120 lines
5.7 KiB
HTML
120 lines
5.7 KiB
HTML
<div class="container paper-page">
|
|
<div class="paper-crumbs">Admin / <span class="here">Users</span></div>
|
|
<h1 class="paper-page-title">Registered <em>users</em></h1>
|
|
<p class="paper-page-lede">Browse, search, and manage every account.</p>
|
|
|
|
<nav class="admin-nav">
|
|
<a href="/admin/"><i class="fas fa-code-branch"></i> Repositories</a>
|
|
<a href="/admin/users" class="active"><i class="fas fa-users"></i> Users</a>
|
|
<a href="/admin/conferences"><i class="fas fa-chalkboard-teacher"></i> Conferences</a>
|
|
<a href="/admin/queues"><i class="fas fa-tasks"></i> Queues</a>
|
|
</nav>
|
|
|
|
<div class="admin-stats">
|
|
<div class="admin-stat-card">
|
|
<div class="stat-value" ng-bind="total >= 0 ? (total | number) : '...'"></div>
|
|
<div class="stat-label">Total users</div>
|
|
</div>
|
|
<div class="admin-stat-card">
|
|
<div class="stat-value">{{query.page}}/{{totalPage || '...'}}</div>
|
|
<div class="stat-label">Current page</div>
|
|
</div>
|
|
</div>
|
|
|
|
<form class="w-100 dashboard-filter-row" aria-label="Users" accept-charset="UTF-8">
|
|
<div class="search-wrap">
|
|
<input
|
|
type="search"
|
|
class="form-control"
|
|
aria-label="Search users"
|
|
placeholder="Search users…"
|
|
autocomplete="off"
|
|
ng-model="query.search"
|
|
/>
|
|
</div>
|
|
<div class="d-flex flex-wrap" style="gap: 8px; align-items: center;">
|
|
<div class="pagination-compact">
|
|
<button class="btn btn-sm" type="button" ng-click="query.page = Math.max(1, query.page - 1)" ng-disabled="query.page <= 1">
|
|
<i class="fas fa-chevron-left"></i>
|
|
</button>
|
|
<input type="number" class="form-control form-control-sm" ng-model="query.page" min="1" max="{{totalPage}}" />
|
|
<span>/{{totalPage}}</span>
|
|
<button class="btn btn-sm" type="button" ng-click="query.page = Math.min(totalPage, query.page + 1)" ng-disabled="query.page >= totalPage">
|
|
<i class="fas fa-chevron-right"></i>
|
|
</button>
|
|
</div>
|
|
|
|
<div class="dropdown">
|
|
<button class="btn dropdown-toggle" type="button" id="dropdownSort" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Sort</button>
|
|
<div class="dropdown-menu" aria-labelledby="dropdownSort">
|
|
<h6 class="dropdown-header">Sort by</h6>
|
|
<a class="dropdown-item" href="#" ng-click="query.sort = 'username'">
|
|
<i class="fas fa-check" ng-show="query.sort == 'username'"></i> Username
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
|
|
<div class="paper-table w-100" role="table" aria-label="Users" style="--cols: minmax(280px, 2.4fr) 140px 140px 52px;">
|
|
<div class="paper-table-head admin-users-row" role="row">
|
|
<div role="columnheader">User</div>
|
|
<div role="columnheader">Status</div>
|
|
<div role="columnheader">Role</div>
|
|
<div role="columnheader" aria-label="Actions"></div>
|
|
</div>
|
|
<div
|
|
class="paper-table-row admin-users-row"
|
|
role="row"
|
|
ng-repeat="u in users | filter:userFiler | orderBy:orderBy as filteredUsers"
|
|
>
|
|
<div class="cell-anon" role="cell">
|
|
<img ng-src="{{u.photo}}" ng-if="u.photo" width="28" height="28" class="rounded-circle" style="flex-shrink:0;" />
|
|
<div class="anon-text">
|
|
<a class="repo-name" ng-href="/admin/users/{{u.username}}" ng-bind="u.username"></a>
|
|
<div class="anon-sub">
|
|
<span ng-if="u.emails[0].email">{{u.emails[0].email}}</span><span ng-if="u.emails[0].email"> · </span><a href="https://github.com/{{u.username}}" target="_blank"><i class="fab fa-github"></i> {{u.username}}</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="cell-status" role="cell">
|
|
<span class="status-dot" ng-class="{'status-ready': u.status == 'active', 'status-removed': u.status == 'removed' || u.status == 'banned'}"></span>
|
|
<span ng-bind="u.status | title"></span>
|
|
</div>
|
|
<div class="cell-status" role="cell">
|
|
<span ng-if="u.isAdmin" class="type-badge type-repo">Admin</span>
|
|
<span ng-if="!u.isAdmin" class="empty-dash">—</span>
|
|
</div>
|
|
<div class="cell-actions" role="cell">
|
|
<div class="dropdown">
|
|
<button class="btn btn-icon-dots" type="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" aria-label="Actions">
|
|
<i class="fas fa-ellipsis-h" aria-hidden="true"></i>
|
|
</button>
|
|
<div class="dropdown-menu dropdown-menu-right">
|
|
<a class="dropdown-item" href="/admin/users/{{u.username}}"><i class="far fa-eye"></i> View details</a>
|
|
<div class="dropdown-divider"></div>
|
|
<a class="dropdown-item text-danger" href="#" ng-show="u.status == 'active'" ng-click="banUser(u)"><i class="fas fa-ban"></i> Ban</a>
|
|
<a class="dropdown-item" href="#" ng-show="u.status == 'removed' || u.status == 'banned'" ng-click="activateUser(u)"><i class="fas fa-check-circle"></i> Activate</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="paper-table-empty" ng-if="filteredUsers.length == 0">
|
|
<i class="fas fa-inbox"></i>
|
|
<span>No users match the current filters.</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="admin-toolbar" ng-if="totalPage > 1" style="justify-content: center; border-bottom: none;">
|
|
<div class="pagination-compact">
|
|
<button class="btn btn-sm" ng-click="query.page = Math.max(1, query.page - 1)" ng-disabled="query.page <= 1">
|
|
<i class="fas fa-chevron-left"></i> Previous
|
|
</button>
|
|
<span>Page {{query.page}} of {{totalPage}}</span>
|
|
<button class="btn btn-sm" ng-click="query.page = Math.min(totalPage, query.page + 1)" ng-disabled="query.page >= totalPage">
|
|
Next <i class="fas fa-chevron-right"></i>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|