. */ 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\Services\ModuleService; use Fisharebest\Webtrees\Tree; use Psr\Http\Message\ServerRequestInterface; use function app; /** * Class ReportsMenuModule - provide a menu option for the reports */ class ReportsMenuModule extends AbstractModule implements ModuleMenuInterface { use ModuleMenuTrait; /** * @var ModuleService */ private $module_service; /** * ChartsMenuModule constructor. * * @param ModuleService $module_service */ public function __construct(ModuleService $module_service) { $this->module_service = $module_service; } /** * How should this module be identified in the control panel, 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 5; } /** * A menu, to be added to the main application menu. * * @param Tree $tree * * @return Menu|null */ public function getMenu(Tree $tree): ?Menu { $request = app(ServerRequestInterface::class); $xref = $request->getAttribute('xref', ''); $individual = $tree->significantIndividual(Auth::user(), $xref); $submenus = $this->module_service->findByComponent(ModuleReportInterface::class, $tree, Auth::user()) ->map(static 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()); } }