. */ 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 child to a family. */ class AddChildToFamilyPage 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']; $family = Registry::familyFactory()->make($xref, $tree); $family = Auth::checkFamilyAccess($family, true); $gender = $request->getQueryParams()['gender']; $subtitles = [ 'M' => I18N::translate('Add a son'), 'F' => I18N::translate('Add a daughter'), 'U' => I18N::translate('Add a child'), ]; $subtitle = $subtitles[$gender] ?? $subtitles['U']; $title = $family->fullName() . ' - ' . $subtitle; return $this->viewResponse('edit/new-individual', [ 'next_action' => AddChildToFamilyAction::class, 'tree' => $tree, 'title' => $title, 'individual' => null, 'family' => $family, 'name_fact' => null, 'famtag' => 'CHIL', 'gender' => $gender, ]); } }