. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; use Fisharebest\Webtrees\Elements\NameType; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Individual; /** * Children take their mother’s surname. */ class MatrilinealSurnameTradition extends DefaultSurnameTradition { /** * The name of this surname tradition * * @return string */ public function name(): string { /* I18N: A system where children take their mother’s surname */ return I18N::translate('matrilineal'); } /** * A short description of this surname tradition * * @return string */ public function description(): string { /* I18N: In the matrilineal surname tradition, ... */ return I18N::translate('Children take their mother’s surname.'); } /** * 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 $father, ?Individual $mother, string $sex): array { if (preg_match(self::REGEX_SPFX_SURN, $this->extractName($mother), $match) === 1) { $name = $match['NAME']; $spfx = $match['SPFX']; $surn = $match['SURN']; return [ $this->buildName($name, ['TYPE' => NameType::VALUE_BIRTH, 'SPFX' => $spfx, 'SURN' => $surn]), ]; } return parent::newChildNames($father, $mother, $sex); } /** * 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 === 'F' && preg_match(self::REGEX_SPFX_SURN, $this->extractName($child), $match) === 1) { $name = $match['NAME']; $spfx = $match['SPFX']; $surn = $match['SURN']; return [ $this->buildName($name, ['TYPE' => NameType::VALUE_BIRTH, 'SPFX' => $spfx, 'SURN' => $surn]), ]; } return parent::newParentNames($child, $sex); } }