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;
|
namespace App\Admin;
|
||||||
|
|
||||||
|
use App\Account\Action\ActiveAction;
|
||||||
use Framework\Module;
|
use Framework\Module;
|
||||||
use Framework\Renderer\RendererInterface;
|
use Framework\Renderer\RendererInterface;
|
||||||
use Framework\Renderer\TwigRenderer;
|
use Framework\Renderer\TwigRenderer;
|
||||||
|
@ -20,6 +21,8 @@ class AdminModule extends Module
|
||||||
{
|
{
|
||||||
$router->get('/dashboard', DashboardAction::class, 'dashboard');
|
$router->get('/dashboard', DashboardAction::class, 'dashboard');
|
||||||
$router->get('/dashboard/{user:[a-zA-Z\-0-9]+}', DashboardUserAction::class, 'dashboard.user');
|
$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) {
|
if ($renderer instanceof TwigRenderer) {
|
||||||
$renderer->getTwig()->addExtension($adminTwigExtension);
|
$renderer->getTwig()->addExtension($adminTwigExtension);
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,4 +30,6 @@ class User
|
||||||
public $avatar;
|
public $avatar;
|
||||||
|
|
||||||
public $suiviantenne;
|
public $suiviantenne;
|
||||||
|
|
||||||
|
public $actif;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,8 +9,10 @@
|
||||||
</div>
|
</div>
|
||||||
<ul class="list-group list-group-flush">
|
<ul class="list-group list-group-flush">
|
||||||
<div class="container" style="color:black;background-color: lightgray;opacity: 0.9;margin: 1rem;padding:1rem;">
|
<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>
|
<button class="btn btn-primary">Désactiver l'utilisateur</button>
|
||||||
|
{{ field('actif', false, "", {type: 'hidden'}) }}
|
||||||
|
{{ field('username', username, "", {type: 'hidden'}) }}
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
Loading…
Reference in New Issue