xref: /webtrees/app/Census/CensusColumnChildrenLiving.php (revision c1010eda29c0909ed4d5d463f32d32bfefdd4dfe)
1ef21b467SGreg Roach<?php
2ef21b467SGreg Roach/**
3ef21b467SGreg Roach * webtrees: online genealogy
41062a142SGreg Roach * Copyright (C) 2018 webtrees development team
5ef21b467SGreg Roach * This program is free software: you can redistribute it and/or modify
6ef21b467SGreg Roach * it under the terms of the GNU General Public License as published by
7ef21b467SGreg Roach * the Free Software Foundation, either version 3 of the License, or
8ef21b467SGreg Roach * (at your option) any later version.
9ef21b467SGreg Roach * This program is distributed in the hope that it will be useful,
10ef21b467SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
11ef21b467SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12ef21b467SGreg Roach * GNU General Public License for more details.
13ef21b467SGreg Roach * You should have received a copy of the GNU General Public License
14ef21b467SGreg Roach * along with this program. If not, see <http://www.gnu.org/licenses/>.
15ef21b467SGreg Roach */
1615d603e7SGreg Roach
17ef21b467SGreg Roachnamespace Fisharebest\Webtrees\Census;
18ef21b467SGreg Roach
1940150762SGreg Roachuse Fisharebest\Webtrees\Date;
20ef21b467SGreg Roachuse Fisharebest\Webtrees\Individual;
21ef21b467SGreg Roach
22ef21b467SGreg Roach/**
23ef21b467SGreg Roach * The number of children who are still living.
24ef21b467SGreg Roach */
25*c1010edaSGreg Roachclass CensusColumnChildrenLiving extends AbstractCensusColumn implements CensusColumnInterface
26*c1010edaSGreg Roach{
27ef21b467SGreg Roach    /**
28ef21b467SGreg Roach     * Generate the likely value of this census column, based on available information.
29ef21b467SGreg Roach     *
30ef21b467SGreg Roach     * @param Individual $individual
3115d603e7SGreg Roach     * @param Individual $head
32ef21b467SGreg Roach     *
33ef21b467SGreg Roach     * @return string
34ef21b467SGreg Roach     */
35*c1010edaSGreg Roach    public function generate(Individual $individual, Individual $head = null)
36*c1010edaSGreg Roach    {
3740150762SGreg Roach        if ($individual->getSex() !== 'F') {
38ef21b467SGreg Roach            return '';
39ef21b467SGreg Roach        }
4040150762SGreg Roach
4140150762SGreg Roach        $count = 0;
4240150762SGreg Roach        foreach ($individual->getSpouseFamilies() as $family) {
4340150762SGreg Roach            foreach ($family->getChildren() as $child) {
4444f3c149SGreg Roach                if (
4544f3c149SGreg Roach                    $child->getBirthDate()->isOK() &&
4644f3c149SGreg Roach                    Date::compare($child->getBirthDate(), $this->date()) < 0 &&
4744f3c149SGreg Roach                    $child->getBirthDate() != $child->getDeathDate() &&
4844f3c149SGreg Roach                    (!$child->getDeathDate()->isOK() || Date::compare($child->getDeathDate(), $this->date()) > 0)
4944f3c149SGreg Roach                ) {
5040150762SGreg Roach                    $count++;
5140150762SGreg Roach                }
5240150762SGreg Roach            }
5340150762SGreg Roach        }
5440150762SGreg Roach
5540150762SGreg Roach        return (string)$count;
5640150762SGreg Roach    }
57ef21b467SGreg Roach}
58