. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Http\ViewResponseTrait; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Registry; use Fisharebest\Webtrees\Tree; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function assert; /** * Add a new parent to an individual, creating a one-parent family. */ class AddParentToIndividualPage implements RequestHandlerInterface { use ViewResponseTrait; /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $tree = $request->getAttribute('tree'); assert($tree instanceof Tree); $xref = $request->getQueryParams()['xref']; $individual = Registry::individualFactory()->make($xref, $tree); $individual = Auth::checkIndividualAccess($individual, true); $gender = $request->getQueryParams()['gender']; if ($gender === 'F') { $title = $individual->fullName() . ' - ' . I18N::translate('Add a mother'); $famtag = 'WIFE'; } else { $title = $individual->fullName() . ' - ' . I18N::translate('Add a father'); $famtag = 'HUSB'; } return $this->viewResponse('edit/new-individual', [ 'next_action' => AddParentToIndividualAction::class, 'tree' => $tree, 'title' => $title, 'individual' => $individual, 'family' => null, 'name_fact' => null, 'famtag' => $famtag, 'gender' => $gender, ]); } }