. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Factory; use Fisharebest\Webtrees\Http\ViewResponseTrait; use Fisharebest\Webtrees\I18N; 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 spouse to an individual, creating a new family. */ class AddSpouseToIndividualPage 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 = Factory::individual()->make($xref, $tree); $individual = Auth::checkIndividualAccess($individual, true); if ($individual->sex() === 'F') { $title = $individual->fullName() . ' - ' . I18N::translate('Add a husband'); $famtag = 'HUSB'; $gender = 'M'; } else { $title = $individual->fullName() . ' - ' . I18N::translate('Add a wife'); $famtag = 'WIFE'; $gender = 'F'; } return $this->viewResponse('edit/new-individual', [ 'next_action' => AddSpouseToIndividualAction::class, 'tree' => $tree, 'title' => $title, 'individual' => $individual, 'family' => null, 'name_fact' => null, 'famtag' => $famtag, 'gender' => $gender, ]); } }