xref: /webtrees/app/Census/CensusColumnMonthIfMarriedWithinYear.php (revision 1062a1429914c995339f502856821457aa975a5a)
1ef21b467SGreg Roach<?php
2ef21b467SGreg Roach/**
3ef21b467SGreg Roach * webtrees: online genealogy
4*1062a142SGreg 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
19ef21b467SGreg Roachuse Fisharebest\Webtrees\Individual;
20ef21b467SGreg Roach
21ef21b467SGreg Roach/**
22ef21b467SGreg Roach * The month of marriage, if within the last year.
23ef21b467SGreg Roach */
24ef21b467SGreg Roachclass CensusColumnMonthIfMarriedWithinYear extends AbstractCensusColumn implements CensusColumnInterface {
25ef21b467SGreg Roach	/**
26ef21b467SGreg Roach	 * Generate the likely value of this census column, based on available information.
27ef21b467SGreg Roach	 *
28ef21b467SGreg Roach	 * @param Individual $individual
2915d603e7SGreg Roach	 * @param Individual $head
30ef21b467SGreg Roach	 *
31ef21b467SGreg Roach	 * @return string
32ef21b467SGreg Roach	 */
33ad51e0bbSGreg Roach	public function generate(Individual $individual, Individual $head = null) {
3444f3c149SGreg Roach		foreach ($individual->getSpouseFamilies() as $family) {
3544f3c149SGreg Roach			foreach ($family->getFacts('MARR') as $fact) {
364fc9500eSGreg Roach				$marriage_jd = $fact->getDate()->julianDay();
374fc9500eSGreg Roach				$census_jd   = $this->date()->julianDay();
384fc9500eSGreg Roach				if ($marriage_jd <= $census_jd && $marriage_jd >= $census_jd - 365) {
3944f3c149SGreg Roach					// Use the GEDCOM month, as we need this in English - for the US census
4044f3c149SGreg Roach					return ucfirst(strtolower($fact->getDate()->minimumDate()->format('%O')));
4144f3c149SGreg Roach				}
4244f3c149SGreg Roach			}
4344f3c149SGreg Roach		}
4444f3c149SGreg Roach
45ef21b467SGreg Roach		return '';
46ef21b467SGreg Roach	}
47ef21b467SGreg Roach}
48