17c7d1e03SGreg Roach<?php 27c7d1e03SGreg Roach 37c7d1e03SGreg Roach/** 47c7d1e03SGreg Roach * webtrees: online genealogy 5*d11be702SGreg Roach * Copyright (C) 2023 webtrees development team 67c7d1e03SGreg Roach * This program is free software: you can redistribute it and/or modify 77c7d1e03SGreg Roach * it under the terms of the GNU General Public License as published by 87c7d1e03SGreg Roach * the Free Software Foundation, either version 3 of the License, or 97c7d1e03SGreg Roach * (at your option) any later version. 107c7d1e03SGreg Roach * This program is distributed in the hope that it will be useful, 117c7d1e03SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 127c7d1e03SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 137c7d1e03SGreg Roach * GNU General Public License for more details. 147c7d1e03SGreg 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/>. 167c7d1e03SGreg Roach */ 177c7d1e03SGreg Roach 187c7d1e03SGreg Roachdeclare(strict_types=1); 197c7d1e03SGreg Roach 207c7d1e03SGreg Roachnamespace Fisharebest\Webtrees\Http\RequestHandlers; 217c7d1e03SGreg Roach 227c7d1e03SGreg Roachuse Fisharebest\Webtrees\Auth; 23e4ce91eaSGreg Roachuse Fisharebest\Webtrees\Family; 2416904038SGreg Roachuse Fisharebest\Webtrees\Individual; 256b9cb339SGreg Roachuse Fisharebest\Webtrees\Registry; 267c7d1e03SGreg Roachuse Fisharebest\Webtrees\Services\GedcomEditService; 278d9c2b68SGreg Roachuse Fisharebest\Webtrees\Validator; 287c7d1e03SGreg Roachuse Psr\Http\Message\ResponseInterface; 297c7d1e03SGreg Roachuse Psr\Http\Message\ServerRequestInterface; 307c7d1e03SGreg Roachuse Psr\Http\Server\RequestHandlerInterface; 317c7d1e03SGreg Roach 327c7d1e03SGreg Roachuse function redirect; 337c7d1e03SGreg Roach 347c7d1e03SGreg Roach/** 357c7d1e03SGreg Roach * Add a new spouse to a family. 367c7d1e03SGreg Roach */ 377c7d1e03SGreg Roachclass AddSpouseToFamilyAction implements RequestHandlerInterface 387c7d1e03SGreg Roach{ 39c4943cffSGreg Roach private GedcomEditService $gedcom_edit_service; 407c7d1e03SGreg Roach 417c7d1e03SGreg Roach /** 427c7d1e03SGreg Roach * @param GedcomEditService $gedcom_edit_service 437c7d1e03SGreg Roach */ 447c7d1e03SGreg Roach public function __construct(GedcomEditService $gedcom_edit_service) 457c7d1e03SGreg Roach { 467c7d1e03SGreg Roach $this->gedcom_edit_service = $gedcom_edit_service; 477c7d1e03SGreg Roach } 487c7d1e03SGreg Roach 497c7d1e03SGreg Roach /** 507c7d1e03SGreg Roach * @param ServerRequestInterface $request 517c7d1e03SGreg Roach * 527c7d1e03SGreg Roach * @return ResponseInterface 537c7d1e03SGreg Roach */ 547c7d1e03SGreg Roach public function handle(ServerRequestInterface $request): ResponseInterface 557c7d1e03SGreg Roach { 56b55cbc6bSGreg Roach $tree = Validator::attributes($request)->tree(); 57b55cbc6bSGreg Roach $xref = Validator::attributes($request)->isXref()->string('xref'); 58efd4768bSGreg Roach $family = Registry::familyFactory()->make($xref, $tree); 59efd4768bSGreg Roach $family = Auth::checkFamilyAccess($family, true); 60efd4768bSGreg Roach 61e4ce91eaSGreg Roach // Create the new spouse 62a92a07c7SGreg Roach $levels = Validator::parsedBody($request)->array('ilevels'); 63a92a07c7SGreg Roach $tags = Validator::parsedBody($request)->array('itags'); 64a92a07c7SGreg Roach $values = Validator::parsedBody($request)->array('ivalues'); 65e4ce91eaSGreg Roach $gedcom = $this->gedcom_edit_service->editLinesToGedcom(Individual::RECORD_TYPE, $levels, $tags, $values); 66e4ce91eaSGreg Roach $spouse = $tree->createIndividual("0 @@ INDI\n1 FAMS @" . $family->xref() . '@' . $gedcom); 677c7d1e03SGreg Roach 68efd4768bSGreg Roach // Link the spouse to the family 69efd4768bSGreg Roach $husb = $family->facts(['HUSB'], false, null, true)->first(); 70efd4768bSGreg Roach $wife = $family->facts(['WIFE'], false, null, true)->first(); 717c7d1e03SGreg Roach 72efd4768bSGreg Roach if ($husb === null && $spouse->sex() === 'M') { 73efd4768bSGreg Roach $link = 'HUSB'; 74efd4768bSGreg Roach } elseif ($wife === null && $spouse->sex() === 'F') { 75efd4768bSGreg Roach $link = 'WIFE'; 76efd4768bSGreg Roach } elseif ($husb === null) { 77efd4768bSGreg Roach $link = 'HUSB'; 78efd4768bSGreg Roach } elseif ($wife === null) { 79efd4768bSGreg Roach $link = 'WIFE'; 807c7d1e03SGreg Roach } else { 81efd4768bSGreg Roach // Family already has husband and wife 827c7d1e03SGreg Roach return redirect($family->url()); 837c7d1e03SGreg Roach } 84efd4768bSGreg Roach 85efd4768bSGreg Roach // Link the spouse to the family 86efd4768bSGreg Roach $family->createFact('1 ' . $link . ' @' . $spouse->xref() . '@', false); 87efd4768bSGreg Roach 88e4ce91eaSGreg Roach // Add any family facts 89a92a07c7SGreg Roach $levels = Validator::parsedBody($request)->array('flevels'); 90a92a07c7SGreg Roach $tags = Validator::parsedBody($request)->array('ftags'); 91a92a07c7SGreg Roach $values = Validator::parsedBody($request)->array('fvalues'); 92e4ce91eaSGreg Roach $gedcom = $this->gedcom_edit_service->editLinesToGedcom(Family::RECORD_TYPE, $levels, $tags, $values); 93e4ce91eaSGreg Roach 94e4ce91eaSGreg Roach if ($gedcom !== '') { 95e4ce91eaSGreg Roach $family->createFact($gedcom, false); 96e4ce91eaSGreg Roach } 97e4ce91eaSGreg Roach 98f507cef9SGreg Roach $url = Validator::parsedBody($request)->isLocalUrl()->string('url', $spouse->url()); 99551ad4afSGreg Roach 100551ad4afSGreg Roach return redirect($url); 101efd4768bSGreg Roach } 1027c7d1e03SGreg Roach} 103