. */ 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 ChartsMenuModule - provide a menu option for the charts */ class ChartsMenuModule 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('Charts'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Reports” 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 = Request::createFromGlobals(); $xref = $request->get('xref', ''); $individual = Individual::getInstance($xref, $tree) ?? $tree->significantIndividual(Auth::user()); $submenus = Module::activeCharts($tree) ->map(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()); } }