. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Http\RequestHandlers\SearchAdvancedPage; use Fisharebest\Webtrees\Http\RequestHandlers\SearchGeneralPage; use Fisharebest\Webtrees\Http\RequestHandlers\SearchPhoneticPage; use Fisharebest\Webtrees\Http\RequestHandlers\SearchReplacePage; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Menu; use Fisharebest\Webtrees\Tree; use function route; /** * Class SearchMenuModule - provide a menu option for the search options */ class SearchMenuModule extends AbstractModule implements ModuleMenuInterface { use ModuleMenuTrait; /** * How should this module be identified in the control panel, etc.? * * @return string */ public function title(): string { /* I18N: Name of a module */ return I18N::translate('Search'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Search” module */ return I18N::translate('The search menu.'); } /** * The default position for this menu. It can be changed in the control panel. * * @return int */ public function defaultMenuOrder(): int { return 6; } /** * A menu, to be added to the main application menu. * * @param Tree $tree * * @return Menu|null */ public function getMenu(Tree $tree): ?Menu { $submenu = [ $this->menuSearchGeneral($tree), $this->menuSearchPhonetic($tree), $this->menuSearchAdvanced($tree), $this->menuSearchAndReplace($tree), ]; $submenu = array_filter($submenu); return new Menu(I18N::translate('Search'), '#', 'menu-search', ['rel' => 'nofollow'], $submenu); } /** * @param Tree $tree * * @return Menu */ protected function menuSearchGeneral(Tree $tree): Menu { return new Menu(I18N::translate('General search'), route(SearchGeneralPage::class, ['tree' => $tree->name()]), 'menu-search-general', ['rel' => 'nofollow']); } /** * @param Tree $tree * * @return Menu */ protected function menuSearchPhonetic(Tree $tree): Menu { $url = route(SearchPhoneticPage::class, ['tree' => $tree->name()]); /* I18N: search using “sounds like”, rather than exact spelling */ return new Menu(I18N::translate('Phonetic search'), $url, 'menu-search-soundex', ['rel' => 'nofollow']); } /** * @param Tree $tree * * @return Menu */ protected function menuSearchAdvanced(Tree $tree): Menu { $url = route(SearchAdvancedPage::class, ['tree' => $tree->name()]); return new Menu(I18N::translate('Advanced search'), $url, 'menu-search-advanced', ['rel' => 'nofollow']); } /** * @param Tree $tree * * @return Menu|null */ protected function menuSearchAndReplace(Tree $tree): ?Menu { if (Auth::isEditor($tree)) { $url = route(SearchReplacePage::class, ['tree' => $tree->name()]); return new Menu(I18N::translate('Search and replace'), $url, 'menu-search-replace'); } return null; } }