. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Census; use Fisharebest\Webtrees\Date; use Fisharebest\Webtrees\Individual; /** * The number of children who are still living. */ class CensusColumnChildrenLiving extends AbstractCensusColumn implements CensusColumnInterface { /** * Generate the likely value of this census column, based on available information. * * @param Individual $individual * @param Individual $head * * @return string */ public function generate(Individual $individual, Individual $head): string { if ($individual->sex() !== 'F') { return ''; } $count = 0; foreach ($individual->spouseFamilies() as $family) { foreach ($family->children() as $child) { $birth = $child->getBirthDate(); $death = $child->getDeathDate(); $born_before = $birth->isOK() && Date::compare($birth, $this->date()) < 0; $died_after = $death->isOK() && Date::compare($death, $this->date()) > 0 || !$death->isOK(); if ($born_before && $died_after) { $count++; } } } return (string) $count; } }