TRF Certest first commit

This commit is contained in:
2025-02-26 08:57:46 +01:00
commit 3ce064a108
2524 changed files with 475404 additions and 0 deletions
@@ -0,0 +1,17 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard;
use Vanguard\Plugins\Plugin;
use Vanguard\Support\Sidebar\Item;
class Dashboard extends Plugin
{
public function sidebar(): Item
{
return Item::create(__('Dashboard'))
->route('dashboard')
->icon('fas fa-home')
->active('/');
}
}
@@ -0,0 +1,35 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard\Widgets;
use Illuminate\Contracts\View\View;
use Vanguard\Plugins\Widget;
use Vanguard\Repositories\User\UserRepository;
use Vanguard\Support\Enum\UserStatus;
class BannedUsers extends Widget
{
/**
* {@inheritdoc}
*/
public ?string $width = '3';
/**
* {@inheritdoc}
*/
protected string|\Closure|array $permissions = 'users.manage';
public function __construct(protected readonly UserRepository $users)
{
}
/**
* {@inheritDoc}
*/
public function render(): View
{
return view('plugins.dashboard.widgets.banned-users', [
'count' => $this->users->countByStatus(UserStatus::BANNED),
]);
}
}
@@ -0,0 +1,34 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard\Widgets;
use Illuminate\Contracts\View\View;
use Vanguard\Plugins\Widget;
use Vanguard\Repositories\User\UserRepository;
class LatestRegistrations extends Widget
{
/**
* {@inheritdoc}
*/
public ?string $width = '4';
/**
* {@inheritdoc}
*/
protected string|\Closure|array $permissions = 'users.manage';
public function __construct(protected readonly UserRepository $users)
{
}
/**
* {@inheritdoc}
*/
public function render(): View
{
return view('plugins.dashboard.widgets.latest-registrations', [
'latestRegistrations' => $this->users->latest(6),
]);
}
}
@@ -0,0 +1,34 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard\Widgets;
use Illuminate\Contracts\View\View;
use Vanguard\Plugins\Widget;
use Vanguard\Repositories\User\UserRepository;
class NewUsers extends Widget
{
/**
* {@inheritdoc}
*/
public ?string $width = '3';
/**
* {@inheritdoc}
*/
protected string|\Closure|array $permissions = 'users.manage';
public function __construct(protected readonly UserRepository $users)
{
}
/**
* {@inheritdoc}
*/
public function render(): View
{
return view('plugins.dashboard.widgets.new-users', [
'count' => $this->users->newUsersCount(),
]);
}
}
@@ -0,0 +1,59 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard\Widgets;
use Carbon\Carbon;
use Illuminate\Contracts\View\View;
use Vanguard\Plugins\Widget;
use Vanguard\Repositories\User\UserRepository;
class RegistrationHistory extends Widget
{
/**
* {@inheritdoc}
*/
public ?string $width = '8';
protected string|\Closure|array $permissions = 'users.manage';
/**
* @var array Count of new users per month.
*/
protected array $usersPerMonth;
public function __construct(protected UserRepository $users)
{
}
/**
* {@inheritdoc}
*/
public function render(): View
{
return view('plugins.dashboard.widgets.registration-history', [
'usersPerMonth' => $this->getUsersPerMonth(),
]);
}
/**
* {@inheritDoc}
*/
public function scripts(): View
{
return view('plugins.dashboard.widgets.registration-history-scripts', [
'usersPerMonth' => $this->getUsersPerMonth(),
]);
}
private function getUsersPerMonth(): array
{
if (isset($this->usersPerMonth)) {
return $this->usersPerMonth;
}
return $this->usersPerMonth = $this->users->countOfNewUsersPerMonthPerRole(
Carbon::now()->subYear()->startOfMonth(),
Carbon::now()->endOfMonth()
);
}
}
@@ -0,0 +1,34 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard\Widgets;
use Illuminate\Contracts\View\View;
use Vanguard\Plugins\Widget;
use Vanguard\Repositories\User\UserRepository;
class TotalUsers extends Widget
{
/**
* {@inheritdoc}
*/
public ?string $width = '3';
/**
* {@inheritdoc}
*/
protected string|\Closure|array $permissions = 'users.manage';
public function __construct(protected readonly UserRepository $users)
{
}
/**
* {@inheritdoc}
*/
public function render(): View
{
return view('plugins.dashboard.widgets.total-users', [
'count' => $this->users->count(),
]);
}
}
@@ -0,0 +1,35 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard\Widgets;
use Illuminate\Contracts\View\View;
use Vanguard\Plugins\Widget;
use Vanguard\Repositories\User\UserRepository;
use Vanguard\Support\Enum\UserStatus;
class UnconfirmedUsers extends Widget
{
/**
* {@inheritdoc}
*/
public ?string $width = '3';
/**
* {@inheritdoc}
*/
protected string|\Closure|array $permissions = 'users.manage';
public function __construct(protected readonly UserRepository $users)
{
}
/**
* {@inheritdoc}
*/
public function render(): View
{
return view('plugins.dashboard.widgets.unconfirmed-users', [
'count' => $this->users->countByStatus(UserStatus::UNCONFIRMED),
]);
}
}
@@ -0,0 +1,25 @@
<?php
namespace Vanguard\Support\Plugins\Dashboard\Widgets;
use Illuminate\Contracts\View\View;
use Vanguard\Plugins\Widget;
use Vanguard\User;
class UserActions extends Widget
{
public function __construct()
{
$this->permissions(function (User $user) {
return $user->hasRole('User');
});
}
/**
* {@inheritdoc}
*/
public function render(): View
{
return view('plugins.dashboard.widgets.user-actions');
}
}
@@ -0,0 +1,31 @@
<?php
namespace Vanguard\Support\Plugins;
use Vanguard\Plugins\Plugin;
use Vanguard\Support\Sidebar\Item;
class RolesAndPermissions extends Plugin
{
public function sidebar(): Item
{
$roles = Item::create(__('Roles'))
->route('roles.index')
->active('roles*')
->permissions('roles.manage');
$permissions = Item::create(__('Permissions'))
->route('permissions.index')
->active('permissions*')
->permissions('permissions.manage');
return Item::create(__('Roles & Permissions'))
->href('#roles-dropdown')
->icon('fas fa-users-cog')
->permissions(['roles.manage', 'permissions.manage'])
->addChildren([
$roles,
$permissions,
]);
}
}
+45
View File
@@ -0,0 +1,45 @@
<?php
namespace Vanguard\Support\Plugins;
use Vanguard\Plugins\Plugin;
use Vanguard\Support\Sidebar\Item;
use Vanguard\User;
class Settings extends Plugin
{
public function sidebar(): Item
{
$general = Item::create(__('General'))
->route('settings.general')
->active('settings')
->permissions('settings.general');
$authAndRegistration = Item::create(__('Auth & Registration'))
->route('settings.auth')
->active('settings/auth')
->permissions('settings.auth');
$notifications = Item::create(__('Notifications'))
->route('settings.notifications')
->active('settings/notifications')
->permissions(function (User $user) {
return $user->hasPermission('settings.notifications');
});
return Item::create(__('Settings'))
->href('#settings-dropdown')
->icon('fas fa-cogs')
->permissions(function (User $user) {
return $user->hasPermission(
['settings.general', 'settings.auth', 'settings.notifications'],
allRequired: false
);
})
->addChildren([
$general,
$authAndRegistration,
$notifications,
]);
}
}
+18
View File
@@ -0,0 +1,18 @@
<?php
namespace Vanguard\Support\Plugins;
use Vanguard\Plugins\Plugin;
use Vanguard\Support\Sidebar\Item;
class Users extends Plugin
{
public function sidebar(): Item
{
return Item::create(__('Users'))
->route('users.index')
->icon('fas fa-users')
->active('users*')
->permissions('users.manage');
}
}