xref: /webtrees/app/Census/CensusColumnChildrenLiving.php (revision d11be7027e34e3121be11cc025421873364403f9)
1ef21b467SGreg Roach<?php
23976b470SGreg Roach
3ef21b467SGreg Roach/**
4ef21b467SGreg Roach * webtrees: online genealogy
5*d11be702SGreg Roach * Copyright (C) 2023 webtrees development team
6ef21b467SGreg Roach * This program is free software: you can redistribute it and/or modify
7ef21b467SGreg Roach * it under the terms of the GNU General Public License as published by
8ef21b467SGreg Roach * the Free Software Foundation, either version 3 of the License, or
9ef21b467SGreg Roach * (at your option) any later version.
10ef21b467SGreg Roach * This program is distributed in the hope that it will be useful,
11ef21b467SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
12ef21b467SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13ef21b467SGreg Roach * GNU General Public License for more details.
14ef21b467SGreg Roach * You should have received a copy of the GNU General Public License
1589f7189bSGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>.
16ef21b467SGreg Roach */
17fcfa147eSGreg Roach
18e7f56f2aSGreg Roachdeclare(strict_types=1);
1915d603e7SGreg Roach
20ef21b467SGreg Roachnamespace Fisharebest\Webtrees\Census;
21ef21b467SGreg Roach
2240150762SGreg Roachuse Fisharebest\Webtrees\Date;
23ef21b467SGreg Roachuse Fisharebest\Webtrees\Individual;
24ef21b467SGreg Roach
25ef21b467SGreg Roach/**
26ef21b467SGreg Roach * The number of children who are still living.
27ef21b467SGreg Roach */
28c1010edaSGreg Roachclass CensusColumnChildrenLiving extends AbstractCensusColumn implements CensusColumnInterface
29c1010edaSGreg Roach{
30ef21b467SGreg Roach    /**
31ef21b467SGreg Roach     * Generate the likely value of this census column, based on available information.
32ef21b467SGreg Roach     *
33ef21b467SGreg Roach     * @param Individual $individual
3415d603e7SGreg Roach     * @param Individual $head
35ef21b467SGreg Roach     *
36ef21b467SGreg Roach     * @return string
37ef21b467SGreg Roach     */
388f53f488SRico Sonntag    public function generate(Individual $individual, Individual $head): string
39c1010edaSGreg Roach    {
40ff7d8543SGreg Roach        $family = $this->spouseFamily($individual);
41ff7d8543SGreg Roach
42ff7d8543SGreg Roach        if ($family === null || $individual->sex() !== 'F') {
43ef21b467SGreg Roach            return '';
44ef21b467SGreg Roach        }
4540150762SGreg Roach
46ff7d8543SGreg Roach        return (string) $family->children()
47ff7d8543SGreg Roach            ->filter(function (Individual $child): bool {
4883d28054SGreg Roach                $birth = $child->getBirthDate();
4983d28054SGreg Roach                $death = $child->getDeathDate();
5083d28054SGreg Roach
5183d28054SGreg Roach                $born_before = $birth->isOK() && Date::compare($birth, $this->date()) < 0;
5283d28054SGreg Roach                $died_after  = $death->isOK() && Date::compare($death, $this->date()) > 0 || !$death->isOK();
5383d28054SGreg Roach
54ff7d8543SGreg Roach                return $born_before && $died_after;
55ff7d8543SGreg Roach            })
56ff7d8543SGreg Roach            ->count();
5740150762SGreg Roach    }
58ef21b467SGreg Roach}
59