. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Individual; use Fisharebest\Webtrees\Menu; use Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Tree; use Symfony\Component\HttpFoundation\Request; /** * Class ReportsMenuModule - provide a menu option for the reports */ class ReportsMenuModule extends AbstractModule implements ModuleInterface, ModuleMenuInterface { use ModuleMenuTrait; /** * How should this module be labelled on tabs, menus, etc.? * * @return string */ /** {@inheritdoc} */ public function title(): string { /* I18N: Name of a module */ return I18N::translate('Reports'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Reports” module */ return I18N::translate('The reports menu.'); } /** * The default position for this menu. It can be changed in the control panel. * * @return int */ public function defaultMenuOrder(): int { return 50; } /** * A menu, to be added to the main application menu. * * @param Tree $tree * * @return Menu|null */ public function getMenu(Tree $tree): ?Menu { $request = Request::createFromGlobals(); $xref = $request->get('xref', ''); $individual = Individual::getInstance($xref, $tree) ?? $tree->significantIndividual(Auth::user()); $submenus = Module::activeReports($tree) ->map(function (ModuleReportInterface $module) use ($individual): Menu { return $module->getReportMenu($individual); }); if ($submenus->isEmpty()) { return null; } return new Menu(I18N::translate('Reports'), '#', 'menu-report', ['rel' => 'nofollow'], $submenus->all()); } }