. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Http\Controllers\BranchesController; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Services\ModuleService; use Fisharebest\Webtrees\Tree; use InvalidArgumentException; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use function assert; use function redirect; use function route; /** * Class BranchesListModule */ class BranchesListModule extends AbstractModule implements ModuleListInterface { use ModuleListTrait; /** * How should this module be identified in the control panel, etc.? * * @return string */ public function title(): string { /* I18N: Name of a module/list */ return I18N::translate('Branches'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “BranchesListModule” module */ return I18N::translate('A list of branches of a family.'); } /** * CSS class for the URL. * * @return string */ public function listMenuClass(): string { return 'menu-branches'; } /** * @param Tree $tree * @param mixed[] $parameters * * @return string */ public function listUrl(Tree $tree, array $parameters = []): string { return route('module', [ 'module' => $this->name(), 'action' => 'Page', 'tree' => $tree->name(), ] + $parameters); } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function getPageAction(ServerRequestInterface $request): ResponseInterface { $tree = $request->getAttribute('tree'); assert($tree instanceof Tree, new InvalidArgumentException()); $user = $request->getAttribute('user'); Auth::checkComponentAccess($this, ModuleListInterface::class, $tree, $user); $listController = new BranchesController(app(ModuleService::class)); return $listController->page($request); } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function postPageAction(ServerRequestInterface $request): ResponseInterface { $tree = $request->getAttribute('tree'); assert($tree instanceof Tree, new InvalidArgumentException()); return redirect(route('module', [ 'module' => $this->name(), 'action' => 'Page', 'surname' => $request->getParsedBody()['surname'] ?? '', 'soundex_dm' => $request->getParsedBody()['soundex_dm'] ?? '', 'soundex_std' => $request->getParsedBody()['soundex_std'] ?? '', 'tree' => $tree->name(), ])); } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function getListAction(ServerRequestInterface $request): ResponseInterface { $tree = $request->getAttribute('tree'); assert($tree instanceof Tree, new InvalidArgumentException()); $user = $request->getAttribute('user'); Auth::checkComponentAccess($this, ModuleListInterface::class, $tree, $user); return app(BranchesController::class)->list($request); } /** * @return string[] */ public function listUrlAttributes(): array { return []; } }