xref: /webtrees/app/Module/HourglassChartModule.php (revision e65629820189baa4ae743eb866cb88cc852d5956)
1168ff6f3Sric2016<?php
2168ff6f3Sric2016/**
3168ff6f3Sric2016 * webtrees: online genealogy
48fcd0d32SGreg Roach * Copyright (C) 2019 webtrees development team
5168ff6f3Sric2016 * This program is free software: you can redistribute it and/or modify
6168ff6f3Sric2016 * it under the terms of the GNU General Public License as published by
7168ff6f3Sric2016 * the Free Software Foundation, either version 3 of the License, or
8168ff6f3Sric2016 * (at your option) any later version.
9168ff6f3Sric2016 * This program is distributed in the hope that it will be useful,
10168ff6f3Sric2016 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11168ff6f3Sric2016 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12168ff6f3Sric2016 * GNU General Public License for more details.
13168ff6f3Sric2016 * You should have received a copy of the GNU General Public License
14168ff6f3Sric2016 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15168ff6f3Sric2016 */
16e7f56f2aSGreg Roachdeclare(strict_types=1);
17e7f56f2aSGreg Roach
18168ff6f3Sric2016namespace Fisharebest\Webtrees\Module;
19168ff6f3Sric2016
20168ff6f3Sric2016use Fisharebest\Webtrees\I18N;
21168ff6f3Sric2016use Fisharebest\Webtrees\Individual;
22e46b0479SScrutinizer Auto-Fixeruse Fisharebest\Webtrees\Menu;
23168ff6f3Sric2016
24168ff6f3Sric2016/**
25168ff6f3Sric2016 * Class HourglassChartModule
26168ff6f3Sric2016 */
2749a243cbSGreg Roachclass HourglassChartModule extends AbstractModule implements ModuleInterface, ModuleChartInterface
28c1010edaSGreg Roach{
2949a243cbSGreg Roach    use ModuleChartTrait;
3049a243cbSGreg Roach
31168ff6f3Sric2016    /**
32168ff6f3Sric2016     * How should this module be labelled on tabs, menus, etc.?
33168ff6f3Sric2016     *
34168ff6f3Sric2016     * @return string
35168ff6f3Sric2016     */
3649a243cbSGreg Roach    public function title(): string
37c1010edaSGreg Roach    {
38bbb76c12SGreg Roach        /* I18N: Name of a module/chart */
39bbb76c12SGreg Roach        return I18N::translate('Hourglass chart');
40168ff6f3Sric2016    }
41168ff6f3Sric2016
42168ff6f3Sric2016    /**
43168ff6f3Sric2016     * A sentence describing what this module does.
44168ff6f3Sric2016     *
45168ff6f3Sric2016     * @return string
46168ff6f3Sric2016     */
4749a243cbSGreg Roach    public function description(): string
48c1010edaSGreg Roach    {
49bbb76c12SGreg Roach        /* I18N: Description of the “HourglassChart” module */
50bbb76c12SGreg Roach        return I18N::translate('An hourglass chart of an individual’s ancestors and descendants.');
51168ff6f3Sric2016    }
52168ff6f3Sric2016
53168ff6f3Sric2016    /**
544eb71cfaSGreg Roach     * Return a menu item for this chart - for use in individual boxes.
554eb71cfaSGreg Roach     *
5660bc3e3fSGreg Roach     * @param Individual $individual
5760bc3e3fSGreg Roach     *
584eb71cfaSGreg Roach     * @return Menu|null
594eb71cfaSGreg Roach     */
60*e6562982SGreg Roach    public function chartMenuIndividual(Individual $individual): ?Menu
61c1010edaSGreg Roach    {
62*e6562982SGreg Roach        return $this->chartMenu($individual);
63*e6562982SGreg Roach    }
64*e6562982SGreg Roach
65*e6562982SGreg Roach    /**
66*e6562982SGreg Roach     * The URL for this chart.
67*e6562982SGreg Roach     *
68*e6562982SGreg Roach     * @param Individual $individual
69*e6562982SGreg Roach     * @param string[]   $parameters
70*e6562982SGreg Roach     *
71*e6562982SGreg Roach     * @return string
72*e6562982SGreg Roach     */
73*e6562982SGreg Roach    public function chartUrl(Individual $individual, array $parameters = []): string
74*e6562982SGreg Roach    {
75*e6562982SGreg Roach        return route('hourglass', [
76*e6562982SGreg Roach            'xref' => $individual->xref(),
77*e6562982SGreg Roach            'ged' => $individual->tree()->name(),
78*e6562982SGreg Roach        ] + $parameters);
79*e6562982SGreg Roach    }
80*e6562982SGreg Roach
81*e6562982SGreg Roach    /**
82*e6562982SGreg Roach     * CSS class for the URL.
83*e6562982SGreg Roach     *
84*e6562982SGreg Roach     * @return string
85*e6562982SGreg Roach     */
86*e6562982SGreg Roach    public function chartUrlClasss(): string
87*e6562982SGreg Roach    {
88*e6562982SGreg Roach        return 'menu-chart-hourglass';
89168ff6f3Sric2016    }
90168ff6f3Sric2016}
91