. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Elements; use Fisharebest\Webtrees\Contracts\GedcomRecordFactoryInterface; use Fisharebest\Webtrees\Gedcom; use Fisharebest\Webtrees\GedcomRecord; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Tree; use function e; use function preg_match; /** * Common behaviour for all XREF links */ class AbstractXrefElement extends AbstractElement { /** * Should we collapse the children of this element when editing? * * @return bool */ public function collapseChildren(): bool { return true; } /** * Escape @ signs in a GEDCOM export. * * @param string $value * * @return string */ public function escape(string $value): string { return $value; } /** * Display the value of this type of element - convert XREFs to links. * * @param string $value * @param Tree $tree * @param GedcomRecordFactoryInterface $factory * * @return string */ protected function valueXrefLink(string $value, Tree $tree, GedcomRecordFactoryInterface $factory): string { if ($value === '@VOID@') { // I18N: The record was not recorded in this GEDCOM file. return I18N::translate('Not recorded'); } if (preg_match('/^@(' . Gedcom::REGEX_XREF . ')@$/', $value, $match)) { $record = $factory->make($match[1], $tree); if ($record instanceof GedcomRecord) { return '' . $record->fullName() . ''; } } return '' . e($value) . ''; } }