Ajout fonction actif/inactif dans tableau de bord User
This commit is contained in:
parent
ef9e63d898
commit
2f0b22e26e
|
@ -0,0 +1,70 @@
|
|||
<?php
|
||||
namespace App\Account\Action;
|
||||
|
||||
use App\Auth\UserTable;
|
||||
use Framework\Auth;
|
||||
use Framework\Renderer\RendererInterface;
|
||||
use Framework\Response\RedirectResponse;
|
||||
use Framework\Session\FlashService;
|
||||
use Framework\Validator;
|
||||
use Psr\Http\Message\ServerRequestInterface;
|
||||
|
||||
class ActiveAction
|
||||
{
|
||||
|
||||
/**
|
||||
* @var RendererInterface
|
||||
*/
|
||||
private $renderer;
|
||||
/**
|
||||
* @var Auth
|
||||
*/
|
||||
private $auth;
|
||||
/**
|
||||
* @var FlashService
|
||||
*/
|
||||
private $flashService;
|
||||
/**
|
||||
* @var UserTable
|
||||
*/
|
||||
private $userTable;
|
||||
|
||||
public function __construct(
|
||||
RendererInterface $renderer,
|
||||
Auth $auth,
|
||||
FlashService $flashService,
|
||||
UserTable $userTable
|
||||
) {
|
||||
|
||||
$this->renderer = $renderer;
|
||||
$this->auth = $auth;
|
||||
$this->flashService = $flashService;
|
||||
$this->userTable = $userTable;
|
||||
}
|
||||
|
||||
public function __invoke(ServerRequestInterface $request)
|
||||
{
|
||||
$user = $this->auth->getUser();
|
||||
var_dump($user);
|
||||
die();
|
||||
$params = $request->getParsedBody();
|
||||
$validator = (new Validator($params))
|
||||
->required('username', 'actif');
|
||||
if ($validator->isValid()) {
|
||||
$userParams = [
|
||||
'username' => $params['username'],
|
||||
'actif' => $params['actif']
|
||||
];
|
||||
|
||||
$this->userTable->update($user->id, $userParams);
|
||||
if (!$params['actif']) {
|
||||
$this->flashService->success("L'utilisateur ".$params['username']." a bien été désactivé");
|
||||
} else {
|
||||
$this->flashService->success("L'utilisateur ".$params['username']." a bien été réactivé");
|
||||
}
|
||||
return new RedirectResponse($request->getUri()->getPath());
|
||||
}
|
||||
$errors = $validator->getErrors();
|
||||
return $this->renderer->render('@account/account', compact('user', 'errors'));
|
||||
}
|
||||
}
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
namespace App\Admin;
|
||||
|
||||
use App\Account\Action\ActiveAction;
|
||||
use Framework\Module;
|
||||
use Framework\Renderer\RendererInterface;
|
||||
use Framework\Renderer\TwigRenderer;
|
||||
|
@ -20,6 +21,8 @@ class AdminModule extends Module
|
|||
{
|
||||
$router->get('/dashboard', DashboardAction::class, 'dashboard');
|
||||
$router->get('/dashboard/{user:[a-zA-Z\-0-9]+}', DashboardUserAction::class, 'dashboard.user');
|
||||
$router->get('/activation', ActiveAction::class, 'account.active');
|
||||
$router->post('/activation', ActiveAction::class);
|
||||
if ($renderer instanceof TwigRenderer) {
|
||||
$renderer->getTwig()->addExtension($adminTwigExtension);
|
||||
}
|
||||
|
|
|
@ -30,4 +30,6 @@ class User
|
|||
public $avatar;
|
||||
|
||||
public $suiviantenne;
|
||||
|
||||
public $actif;
|
||||
}
|
||||
|
|
|
@ -9,8 +9,10 @@
|
|||
</div>
|
||||
<ul class="list-group list-group-flush">
|
||||
<div class="container" style="color:black;background-color: lightgray;opacity: 0.9;margin: 1rem;padding:1rem;">
|
||||
<form action="" method="post">
|
||||
<form action="{{ path('account.active') }}" method="post">
|
||||
<button class="btn btn-primary">Désactiver l'utilisateur</button>
|
||||
{{ field('actif', false, "", {type: 'hidden'}) }}
|
||||
{{ field('username', username, "", {type: 'hidden'}) }}
|
||||
</form>
|
||||
</div>
|
||||
</ul>
|
||||
|
|
Loading…
Reference in New Issue