xref: /webtrees/app/Census/CensusColumnYearsMarried.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
22054771e9SGreg Roachuse Fisharebest\Webtrees\Age;
237338314fSGreg Roachuse Fisharebest\Webtrees\Date;
24054771e9SGreg Roachuse Fisharebest\Webtrees\I18N;
25ef21b467SGreg Roachuse Fisharebest\Webtrees\Individual;
26ef21b467SGreg Roach
27ef21b467SGreg Roach/**
28ef21b467SGreg Roach * For how many years has the individual been married.
29ef21b467SGreg Roach */
30c1010edaSGreg Roachclass CensusColumnYearsMarried extends AbstractCensusColumn implements CensusColumnInterface
31c1010edaSGreg Roach{
32ef21b467SGreg Roach    /**
33ef21b467SGreg Roach     * Generate the likely value of this census column, based on available information.
34ef21b467SGreg Roach     *
35ef21b467SGreg Roach     * @param Individual $individual
3615d603e7SGreg Roach     * @param Individual $head
37ef21b467SGreg Roach     *
38ef21b467SGreg Roach     * @return string
39ef21b467SGreg Roach     */
405a62e0a6SGreg Roach    public function generate(Individual $individual, Individual $head): string
41c1010edaSGreg Roach    {
427338314fSGreg Roach        $marriage_date = null;
437338314fSGreg Roach
4439ca88baSGreg Roach        foreach ($individual->spouseFamilies() as $family) {
458d0ebef0SGreg Roach            foreach ($family->facts(['MARR'], true) as $fact) {
462decada7SGreg Roach                if ($fact->date()->isOK() && Date::compare($fact->date(), $this->date()) <= 0) {
472decada7SGreg Roach                    $marriage_date = $fact->date();
487338314fSGreg Roach                }
497338314fSGreg Roach            }
507338314fSGreg Roach        }
517338314fSGreg Roach
527338314fSGreg Roach        if ($marriage_date === null) {
53ef21b467SGreg Roach            return '';
547338314fSGreg Roach        }
55b2ce94c6SRico Sonntag
56054771e9SGreg Roach        $age = new Age($marriage_date, $this->date());
57054771e9SGreg Roach
58054771e9SGreg Roach        return I18N::number($age->ageYears());
59ef21b467SGreg Roach    }
60ef21b467SGreg Roach}
61