xref: /webtrees/app/Census/CensusColumnChildrenDied.php (revision 449b311ecf65f677a2595e1e29f712d11ef22f34)
1ef21b467SGreg Roach<?php
23976b470SGreg Roach
3ef21b467SGreg Roach/**
4ef21b467SGreg Roach * webtrees: online genealogy
5d11be702SGreg 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 have died.
27ef21b467SGreg Roach */
28c1010edaSGreg Roachclass CensusColumnChildrenDied 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()
47*f25fc0f9SGreg Roach            ->filter(fn (Individual $child): bool => $child->getBirthDate()->isOK() &&
4844f3c149SGreg Roach                Date::compare($child->getBirthDate(), $this->date()) < 0 &&
49ff7d8543SGreg Roach                $child->getBirthDate()->minimumJulianDay() !== $child->getDeathDate()->minimumJulianDay() &&
5044f3c149SGreg Roach                $child->getDeathDate()->isOK() &&
51*f25fc0f9SGreg Roach                Date::compare($child->getDeathDate(), $this->date()) < 0)
52ff7d8543SGreg Roach            ->count();
5340150762SGreg Roach    }
54ef21b467SGreg Roach}
55