. */ declare(strict_types=1); namespace Fisharebest\Webtrees\SurnameTradition; use Fisharebest\Webtrees\Elements\NameType; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Individual; /** * Children take one surname from the mother and one surname from the father. * * Mother: Maria /AAAA/ /BBBB/ * Father: Jose /CCCC/ /DDDD/ * Child: Pablo /DDDD/ /BBBB/ */ class PortugueseSurnameTradition extends DefaultSurnameTradition { /** * The name of this surname tradition * * @return string */ public function name(): string { return I18N::translateContext('Surname tradition', 'Portuguese'); } /** * A short description of this surname tradition * * @return string */ public function description(): string { /* I18N: In the Portuguese surname tradition, ... */ return I18N::translate('Children take one surname from the mother and one surname from the father.'); } /** * 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 $father, ?Individual $mother, string $sex): array { if (preg_match(self::REGEX_SURNS, $this->extractName($father), $match_father)) { $father_surname = $match_father['SURN2']; } else { $father_surname = ''; } if (preg_match(self::REGEX_SURNS, $this->extractName($mother), $match_mother)) { $mother_surname = $match_mother['SURN2']; } else { $mother_surname = ''; } return [ $this->buildName('/' . $father_surname . '/ /' . $mother_surname . '/', [ 'TYPE' => NameType::VALUE_BIRTH, 'SURN' => trim($father_surname . ',' . $mother_surname, ','), ]), ]; } /** * 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 (preg_match(self::REGEX_SURNS, $this->extractName($child), $match)) { switch ($sex) { case 'M': return [ $this->buildName('// /' . $match['SURN1'] . '/', [ 'TYPE' => NameType::VALUE_BIRTH, 'SURN' => $match['SURN1'], ]), ]; case 'F': return [ $this->buildName('// /' . $match['SURN2'] . '/', [ 'TYPE' => NameType::VALUE_BIRTH, 'SURN' => $match['SURN2'], ]), ]; } } 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]), ]; } }