. */ 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; /** * Class ChartsMenuModule - provide a menu option for the charts */ class ChartsMenuModule 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 */ public function title(): string { /* I18N: Name of a module */ return I18N::translate('Charts'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Charts” module */ return I18N::translate('The charts menu.'); } /** * The default position for this menu. It can be changed in the control panel. * * @return int */ public function defaultMenuOrder(): int { return 2; } /** * 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(ModuleChartInterface::class, $tree, Auth::user()) ->map(static function (ModuleChartInterface $module) use ($individual): Menu { return $module->chartMenu($individual); }); if ($submenus->isEmpty()) { return null; } return new Menu(I18N::translate('Charts'), '#', 'menu-chart', ['rel' => 'nofollow'], $submenus->all()); } }