. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Contracts\UserInterface; 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 Symfony\Component\HttpFoundation\Response; use Illuminate\Database\Capsule\Manager as DB; /** * Class RepositoryListModule */ class RepositoryListModule extends AbstractModule implements ModuleListInterface { use ModuleListTrait; /** * How should this module be labelled on tabs, menus, 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 Tree $tree * @param UserInterface $user * * @return Response */ public function getListAction(Tree $tree, UserInterface $user): Response { Auth::checkComponentAccess($this, 'list', $tree, $user); $listController = new ListController(app(IndividualListService::class), app(LocalizationService::class)); return $listController->repositoryList($tree); } /** * @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(); } }