. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Http\Controllers\ListController; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Services\IndividualListService; use Fisharebest\Webtrees\Services\LocalizationService; use Fisharebest\Webtrees\Tree; use Fisharebest\Webtrees\Auth; use Illuminate\Database\Capsule\Manager as DB; use InvalidArgumentException; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use function assert; /** * Class RepositoryListModule */ class RepositoryListModule 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('Repositories'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “RepositoryListModule” module */ return I18N::translate('A list of repositories.'); } /** * CSS class for the URL. * * @return string */ public function listMenuClass(): string { return 'menu-list-repo'; } /** * @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); $listController = new ListController(app(IndividualListService::class), app(LocalizationService::class)); return $listController->repositoryList($request); } /** * @return string[] */ public function listUrlAttributes(): array { return []; } /** * @param Tree $tree * * @return bool */ public function listIsEmpty(Tree $tree): bool { return !DB::table('other') ->where('o_file', '=', $tree->id()) ->where('o_type', '=', 'REPO') ->exists(); } }