. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Menu; use Fisharebest\Webtrees\Site; use Fisharebest\Webtrees\Tree; /** * Class TreesMenuModule - provide a menu option for the trees options */ class TreesMenuModule extends AbstractModule implements ModuleInterface, ModuleMenuInterface { use ModuleMenuTrait; /** * How should this module be labelled on tabs, menus, etc.? * * @return string */ public function title(): string { /* I18N: Name of a module */ return I18N::translate('Family trees'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Reports” module */ return I18N::translate('The family trees menu.'); } /** * The default position for this menu. It can be changed in the control panel. * * @return int */ public function defaultMenuOrder(): int { return 1; } /** * A menu, to be added to the main application menu. * * @param Tree $tree * * @return Menu|null */ public function getMenu(Tree $tree): ?Menu { if (Tree::all()->count() === 1 || Site::getPreference('ALLOW_CHANGE_GEDCOM') !== '1') { return new Menu(I18N::translate('Family tree'), route('tree-page', ['ged' => $tree->name()]), 'menu-tree'); } $submenus = []; foreach (Tree::all() as $menu_tree) { if ($menu_tree->id() === $tree->id()) { $active = 'active '; } else { $active = ''; } $submenus[] = new Menu(e($menu_tree->title()), route('tree-page', ['ged' => $menu_tree->name()]), $active . 'menu-tree-' . $menu_tree->id()); } return new Menu(I18N::translate('Family trees'), '#', 'menu-tree', [], $submenus); } }