. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Menu; use Fisharebest\Webtrees\Registry; use Fisharebest\Webtrees\Services\ModuleService; use Fisharebest\Webtrees\Tree; use Fisharebest\Webtrees\Validator; use Psr\Http\Message\ServerRequestInterface; /** * Class ChartsMenuModule - provide a menu option for the charts */ class ChartsMenuModule extends AbstractModule implements ModuleMenuInterface { use ModuleMenuTrait; private ModuleService $module_service; /** * @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'); } 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. */ public function getMenu(Tree $tree): Menu|null { $request = Registry::container()->get(ServerRequestInterface::class); $xref = Validator::attributes($request)->isXref()->string('xref', ''); $individual = $tree->significantIndividual(Auth::user(), $xref); $submenus = $this->module_service->findByComponent(ModuleChartInterface::class, $tree, Auth::user()) ->map(static fn (ModuleChartInterface $module): Menu => $module->chartMenu($individual)) ->sort(static fn (Menu $x, Menu $y): int => I18N::comparator()($x->getLabel(), $y->getLabel())); if ($submenus->isEmpty()) { return null; } return new Menu(I18N::translate('Charts'), '#', 'menu-chart', ['rel' => 'nofollow'], $submenus->all()); } }