xref: /webtrees/app/Census/CensusColumnMonthIfMarriedWithinYear.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
22ef21b467SGreg Roachuse Fisharebest\Webtrees\Individual;
23ef21b467SGreg Roach
24ef21b467SGreg Roach/**
25ef21b467SGreg Roach * The month of marriage, if within the last year.
26ef21b467SGreg Roach */
27c1010edaSGreg Roachclass CensusColumnMonthIfMarriedWithinYear extends AbstractCensusColumn implements CensusColumnInterface
28c1010edaSGreg Roach{
29ef21b467SGreg Roach    /**
30ef21b467SGreg Roach     * Generate the likely value of this census column, based on available information.
31ef21b467SGreg Roach     *
32ef21b467SGreg Roach     * @param Individual $individual
3315d603e7SGreg Roach     * @param Individual $head
34ef21b467SGreg Roach     *
35ef21b467SGreg Roach     * @return string
36ef21b467SGreg Roach     */
378f53f488SRico Sonntag    public function generate(Individual $individual, Individual $head): string
38c1010edaSGreg Roach    {
3939ca88baSGreg Roach        foreach ($individual->spouseFamilies() as $family) {
408d0ebef0SGreg Roach            foreach ($family->facts(['MARR']) as $fact) {
412decada7SGreg Roach                $marriage_jd = $fact->date()->julianDay();
424fc9500eSGreg Roach                $census_jd   = $this->date()->julianDay();
434fc9500eSGreg Roach                if ($marriage_jd <= $census_jd && $marriage_jd >= $census_jd - 365) {
4444f3c149SGreg Roach                    // Use the GEDCOM month, as we need this in English - for the US census
452decada7SGreg Roach                    return ucfirst(strtolower($fact->date()->minimumDate()->format('%O')));
4644f3c149SGreg Roach                }
4744f3c149SGreg Roach            }
4844f3c149SGreg Roach        }
4944f3c149SGreg Roach
50ef21b467SGreg Roach        return '';
51ef21b467SGreg Roach    }
52ef21b467SGreg Roach}
53