. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Census; use Fisharebest\Webtrees\Date; use Fisharebest\Webtrees\Family; use Fisharebest\Webtrees\Individual; /** * The number of children born alive. */ class CensusColumnChildrenBornAlive 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 { $family = $this->spouseFamily($individual); if ($family === null || $individual->sex() !== 'F') { return ''; } return (string) $family->children() ->filter(function (Individual $child): bool { return $child->getBirthDate()->isOK() && Date::compare($child->getBirthDate(), $this->date()) < 0 && $child->getBirthDate()->minimumJulianDay() !== $child->getDeathDate()->minimumJulianDay(); }) ->count(); } }