. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Fact; use Fisharebest\Webtrees\Functions\Functions; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Individual; /** * Class SourcesTabModule */ class SourcesTabModule extends AbstractModule implements ModuleTabInterface { use ModuleTabTrait; /** @var Fact[] All facts belonging to this source. */ private $facts; /** * How should this module be labelled on tabs, menus, etc.? * * @return string */ public function title(): string { /* I18N: Name of a module */ return I18N::translate('Sources'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Sources” module */ return I18N::translate('A tab showing the sources linked to an individual.'); } /** * The default position for this tab. It can be changed in the control panel. * * @return int */ public function defaultTabOrder(): int { return 4; } /** {@inheritdoc} */ public function hasTabContent(Individual $individual): bool { return $individual->canEdit() || $this->getFactsWithSources($individual); } /** {@inheritdoc} */ public function isGrayedOut(Individual $individual): bool { return !$this->getFactsWithSources($individual); } /** {@inheritdoc} */ public function getTabContent(Individual $individual): string { return view('modules/sources_tab/tab', [ 'can_edit' => $individual->canEdit(), 'individual' => $individual, 'facts' => $this->getFactsWithSources($individual), ]); } /** * Get all the facts for an individual which contain sources. * * @param Individual $individual * * @return Fact[] */ private function getFactsWithSources(Individual $individual): array { if ($this->facts === null) { $facts = $individual->facts(); foreach ($individual->getSpouseFamilies() as $family) { if ($family->canShow()) { foreach ($family->facts() as $fact) { $facts[] = $fact; } } } $this->facts = []; foreach ($facts as $fact) { if (preg_match('/(?:^1|\n\d) SOUR/', $fact->gedcom())) { $this->facts[] = $fact; } } Functions::sortFacts($this->facts); } return $this->facts; } /** {@inheritdoc} */ public function canLoadAjax(): bool { return false; } }