1c2ed51d1SGreg Roach<?php 2c2ed51d1SGreg Roach 3c2ed51d1SGreg Roach/** 4c2ed51d1SGreg Roach * webtrees: online genealogy 5d11be702SGreg Roach * Copyright (C) 2023 webtrees development team 6c2ed51d1SGreg Roach * This program is free software: you can redistribute it and/or modify 7c2ed51d1SGreg Roach * it under the terms of the GNU General Public License as published by 8c2ed51d1SGreg Roach * the Free Software Foundation, either version 3 of the License, or 9c2ed51d1SGreg Roach * (at your option) any later version. 10c2ed51d1SGreg Roach * This program is distributed in the hope that it will be useful, 11c2ed51d1SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 12c2ed51d1SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13c2ed51d1SGreg Roach * GNU General Public License for more details. 14c2ed51d1SGreg Roach * You should have received a copy of the GNU General Public License 15c2ed51d1SGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 16c2ed51d1SGreg Roach */ 17c2ed51d1SGreg Roach 18c2ed51d1SGreg Roachdeclare(strict_types=1); 19c2ed51d1SGreg Roach 20c2ed51d1SGreg Roachnamespace Fisharebest\Webtrees\Elements; 21c2ed51d1SGreg Roach 22*eb7ab465SGreg Roachuse Fisharebest\Webtrees\Contracts\GedcomRecordFactoryInterface; 23c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Gedcom; 24c2ed51d1SGreg Roachuse Fisharebest\Webtrees\GedcomRecord; 25701f5d18SGreg Roachuse Fisharebest\Webtrees\I18N; 26c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Tree; 27c2ed51d1SGreg Roach 28c2ed51d1SGreg Roachuse function e; 29c2ed51d1SGreg Roachuse function preg_match; 30c2ed51d1SGreg Roach 31c2ed51d1SGreg Roach/** 32c2ed51d1SGreg Roach * Common behaviour for all XREF links 33c2ed51d1SGreg Roach */ 34c2ed51d1SGreg Roachclass AbstractXrefElement extends AbstractElement 35c2ed51d1SGreg Roach{ 36c2ed51d1SGreg Roach /** 374e09581bSGreg Roach * Should we collapse the children of this element when editing? 384e09581bSGreg Roach * 394e09581bSGreg Roach * @return bool 404e09581bSGreg Roach */ 414e09581bSGreg Roach public function collapseChildren(): bool 424e09581bSGreg Roach { 434e09581bSGreg Roach return true; 444e09581bSGreg Roach } 454e09581bSGreg Roach 464e09581bSGreg Roach /** 47c2ed51d1SGreg Roach * Escape @ signs in a GEDCOM export. 48c2ed51d1SGreg Roach * 49c2ed51d1SGreg Roach * @param string $value 50c2ed51d1SGreg Roach * 51c2ed51d1SGreg Roach * @return string 52c2ed51d1SGreg Roach */ 53c2ed51d1SGreg Roach public function escape(string $value): string 54c2ed51d1SGreg Roach { 55c2ed51d1SGreg Roach return $value; 56c2ed51d1SGreg Roach } 57c2ed51d1SGreg Roach 58c2ed51d1SGreg Roach /** 59c2ed51d1SGreg Roach * Display the value of this type of element - convert XREFs to links. 60c2ed51d1SGreg Roach * 61c2ed51d1SGreg Roach * @param string $value 62c2ed51d1SGreg Roach * @param Tree $tree 63*eb7ab465SGreg Roach * @param GedcomRecordFactoryInterface $factory 64c2ed51d1SGreg Roach * 65c2ed51d1SGreg Roach * @return string 66c2ed51d1SGreg Roach */ 67*eb7ab465SGreg Roach protected function valueXrefLink(string $value, Tree $tree, GedcomRecordFactoryInterface $factory): string 68c2ed51d1SGreg Roach { 69701f5d18SGreg Roach if ($value === '@VOID@') { 70701f5d18SGreg Roach // I18N: The record was not recorded in this GEDCOM file. 71701f5d18SGreg Roach return I18N::translate('Not recorded'); 72701f5d18SGreg Roach } 73701f5d18SGreg Roach 74c2ed51d1SGreg Roach if (preg_match('/^@(' . Gedcom::REGEX_XREF . ')@$/', $value, $match)) { 75c2ed51d1SGreg Roach $record = $factory->make($match[1], $tree); 76c2ed51d1SGreg Roach 77c2ed51d1SGreg Roach if ($record instanceof GedcomRecord) { 78c2ed51d1SGreg Roach return '<a href="' . e($record->url()) . '">' . $record->fullName() . '</a>'; 79c2ed51d1SGreg Roach } 80c2ed51d1SGreg Roach } 81c2ed51d1SGreg Roach 82c2ed51d1SGreg Roach return '<span class="error">' . e($value) . '</span>'; 83c2ed51d1SGreg Roach } 84c2ed51d1SGreg Roach} 85