. */ 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 spouse to a family. */ class AddSpouseToFamilyPage 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']; $famtag = $request->getQueryParams()['famtag']; $family = Registry::familyFactory()->make($xref, $tree); $family = Auth::checkFamilyAccess($family, true); if ($famtag === 'WIFE') { $title = I18N::translate('Add a wife'); $gender = 'F'; } else { $title = I18N::translate('Add a husband'); $gender = 'M'; } return $this->viewResponse('edit/new-individual', [ 'next_action' => AddSpouseToFamilyAction::class, 'tree' => $tree, 'title' => $title, 'individual' => null, 'family' => $family, 'name_fact' => null, 'famtag' => $famtag, 'gender' => $gender, ]); } }