17c7d1e03SGreg Roach<?php 27c7d1e03SGreg Roach 37c7d1e03SGreg Roach/** 47c7d1e03SGreg Roach * webtrees: online genealogy 57c7d1e03SGreg Roach * Copyright (C) 2020 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 157c7d1e03SGreg Roach * along with this program. If not, see <http://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; 237c7d1e03SGreg Roachuse Fisharebest\Webtrees\Fact; 24*6b9cb339SGreg Roachuse Fisharebest\Webtrees\Registry; 257c7d1e03SGreg Roachuse Fisharebest\Webtrees\Services\GedcomEditService; 267c7d1e03SGreg Roachuse Fisharebest\Webtrees\Tree; 277c7d1e03SGreg Roachuse Psr\Http\Message\ResponseInterface; 287c7d1e03SGreg Roachuse Psr\Http\Message\ServerRequestInterface; 297c7d1e03SGreg Roachuse Psr\Http\Server\RequestHandlerInterface; 307c7d1e03SGreg Roach 317c7d1e03SGreg Roachuse function assert; 327c7d1e03SGreg Roachuse function preg_match_all; 337c7d1e03SGreg Roachuse function redirect; 347c7d1e03SGreg Roachuse function trim; 357c7d1e03SGreg Roach 367c7d1e03SGreg Roach/** 377c7d1e03SGreg Roach * Add a new spouse to a family. 387c7d1e03SGreg Roach */ 397c7d1e03SGreg Roachclass AddSpouseToFamilyAction implements RequestHandlerInterface 407c7d1e03SGreg Roach{ 417c7d1e03SGreg Roach /** @var GedcomEditService */ 427c7d1e03SGreg Roach private $gedcom_edit_service; 437c7d1e03SGreg Roach 447c7d1e03SGreg Roach /** 457c7d1e03SGreg Roach * AddChildToFamilyAction constructor. 467c7d1e03SGreg Roach * 477c7d1e03SGreg Roach * @param GedcomEditService $gedcom_edit_service 487c7d1e03SGreg Roach */ 497c7d1e03SGreg Roach public function __construct(GedcomEditService $gedcom_edit_service) 507c7d1e03SGreg Roach { 517c7d1e03SGreg Roach $this->gedcom_edit_service = $gedcom_edit_service; 527c7d1e03SGreg Roach } 537c7d1e03SGreg Roach 547c7d1e03SGreg Roach /** 557c7d1e03SGreg Roach * @param ServerRequestInterface $request 567c7d1e03SGreg Roach * 577c7d1e03SGreg Roach * @return ResponseInterface 587c7d1e03SGreg Roach */ 597c7d1e03SGreg Roach public function handle(ServerRequestInterface $request): ResponseInterface 607c7d1e03SGreg Roach { 617c7d1e03SGreg Roach $tree = $request->getAttribute('tree'); 627c7d1e03SGreg Roach assert($tree instanceof Tree); 637c7d1e03SGreg Roach 647c7d1e03SGreg Roach $xref = $request->getQueryParams()['xref']; 65*6b9cb339SGreg Roach $family = Registry::familyFactory()->make($xref, $tree); 667c7d1e03SGreg Roach $family = Auth::checkFamilyAccess($family, true); 677c7d1e03SGreg Roach 687c7d1e03SGreg Roach $params = (array) $request->getParsedBody(); 697c7d1e03SGreg Roach 707c7d1e03SGreg Roach $this->gedcom_edit_service->glevels = $params['glevels'] ?? []; 717c7d1e03SGreg Roach $this->gedcom_edit_service->tag = $params['tag'] ?? []; 727c7d1e03SGreg Roach $this->gedcom_edit_service->text = $params['text'] ?? []; 737c7d1e03SGreg Roach $this->gedcom_edit_service->islink = $params['islink'] ?? []; 747c7d1e03SGreg Roach 757c7d1e03SGreg Roach // Create the new spouse 767c7d1e03SGreg Roach $this->gedcom_edit_service->splitSource(); // separate SOUR record from the rest 777c7d1e03SGreg Roach 787c7d1e03SGreg Roach $gedrec = '0 @@ INDI'; 797c7d1e03SGreg Roach $gedrec .= $this->gedcom_edit_service->addNewName($request, $tree); 807c7d1e03SGreg Roach $gedrec .= $this->gedcom_edit_service->addNewSex($request); 817c7d1e03SGreg Roach if (preg_match_all('/([A-Z0-9_]+)/', $tree->getPreference('QUICK_REQUIRED_FACTS'), $matches)) { 827c7d1e03SGreg Roach foreach ($matches[1] as $match) { 837c7d1e03SGreg Roach $gedrec .= $this->gedcom_edit_service->addNewFact($request, $tree, $match); 847c7d1e03SGreg Roach } 857c7d1e03SGreg Roach } 867c7d1e03SGreg Roach 877c7d1e03SGreg Roach if ($params['SOUR_INDI'] ?? false) { 887c7d1e03SGreg Roach $gedrec = $this->gedcom_edit_service->handleUpdates($gedrec); 897c7d1e03SGreg Roach } else { 907c7d1e03SGreg Roach $gedrec = $this->gedcom_edit_service->updateRest($gedrec); 917c7d1e03SGreg Roach } 927c7d1e03SGreg Roach $gedrec .= "\n1 FAMS @" . $family->xref() . '@'; 937c7d1e03SGreg Roach $spouse = $tree->createIndividual($gedrec); 947c7d1e03SGreg Roach 957c7d1e03SGreg Roach // Update the existing family - add marriage, etc 967c7d1e03SGreg Roach if ($family->facts(['HUSB'])->first() instanceof Fact) { 977c7d1e03SGreg Roach $family->createFact('1 WIFE @' . $spouse->xref() . '@', true); 987c7d1e03SGreg Roach } else { 997c7d1e03SGreg Roach $family->createFact('1 HUSB @' . $spouse->xref() . '@', true); 1007c7d1e03SGreg Roach } 1017c7d1e03SGreg Roach $famrec = ''; 1027c7d1e03SGreg Roach if (preg_match_all('/([A-Z0-9_]+)/', $tree->getPreference('QUICK_REQUIRED_FAMFACTS'), $matches)) { 1037c7d1e03SGreg Roach foreach ($matches[1] as $match) { 1047c7d1e03SGreg Roach $famrec .= $this->gedcom_edit_service->addNewFact($request, $tree, $match); 1057c7d1e03SGreg Roach } 1067c7d1e03SGreg Roach } 1077c7d1e03SGreg Roach if ($params['SOUR_FAM'] ?? false) { 1087c7d1e03SGreg Roach $famrec = $this->gedcom_edit_service->handleUpdates($famrec); 1097c7d1e03SGreg Roach } else { 1107c7d1e03SGreg Roach $famrec = $this->gedcom_edit_service->updateRest($famrec); 1117c7d1e03SGreg Roach } 1127c7d1e03SGreg Roach $family->createFact(trim($famrec), true); // trim leading \n 1137c7d1e03SGreg Roach 1147c7d1e03SGreg Roach if (($params['goto'] ?? '') === 'new') { 1157c7d1e03SGreg Roach return redirect($spouse->url()); 1167c7d1e03SGreg Roach } 1177c7d1e03SGreg Roach 1187c7d1e03SGreg Roach return redirect($family->url()); 1197c7d1e03SGreg Roach } 1207c7d1e03SGreg Roach} 121