. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; use Fisharebest\Webtrees\Elements\NameType; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Individual; /** * Children take a patronym instead of a surname. * * Sons get their father’s given name plus “sson” * Daughters get their father’s given name plus “sdottir” */ class IcelandicSurnameTradition extends DefaultSurnameTradition { /** * The name of this surname tradition * * @return string */ public function name(): string { return I18N::translateContext('Surname tradition', 'Icelandic'); } /** * A short description of this surname tradition * * @return string */ public function description(): string { /* I18N: In the Icelandic surname tradition, ... */ return I18N::translate('Children take a patronym instead of a surname.'); } /** * A default/empty name * * @return string */ public function defaultName(): string { return ''; } /** * What name is given to a new child * * @param Individual|null $father * @param Individual|null $mother * @param string $sex * * @return array */ public function newChildNames(Individual|null $father, Individual|null $mother, string $sex): array { if (preg_match(self::REGEX_GIVN, $this->extractName($father), $match) === 1) { switch ($sex) { case 'M': $givn = $match['GIVN'] . 'sson'; return [ $this->buildName($givn, ['TYPE' => NameType::VALUE_BIRTH, 'GIVN' => $givn]), ]; case 'F': $givn = $match['GIVN'] . 'sdottir'; return [ $this->buildName($givn, ['TYPE' => NameType::VALUE_BIRTH, 'GIVN' => $givn]), ]; } } return [ $this->buildName('', ['TYPE' => NameType::VALUE_BIRTH]), ]; } /** * What name is given to a new parent * * @param Individual $child * @param string $sex * * @return array */ public function newParentNames(Individual $child, string $sex): array { if ($sex === 'M' && preg_match('~(?[^ /]+)(:?sson)$~', $this->extractName($child), $match) === 1) { return [ $this->buildName($match['GIVN'], ['TYPE' => NameType::VALUE_BIRTH, 'GIVN' => $match['GIVN']]), ]; } if ($sex === 'F' && preg_match('~(?[^ /]+)(:?sdottir)$~', $this->extractName($child), $match) === 1) { return [ $this->buildName($match['GIVN'], ['TYPE' => NameType::VALUE_BIRTH, 'GIVN' => $match['GIVN']]), ]; } return [ $this->buildName('', ['TYPE' => NameType::VALUE_BIRTH]), ]; } /** * What names are given to a new spouse * * @param Individual $spouse * @param string $sex * * @return array */ public function newSpouseNames(Individual $spouse, string $sex): array { return [ $this->buildName('', ['TYPE' => NameType::VALUE_BIRTH]), ]; } }