. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Module\ModuleBlockInterface; use Fisharebest\Webtrees\Services\HomePageService; use Fisharebest\Webtrees\Tree; use Illuminate\Support\Collection; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function assert; use function redirect; use function route; /** * Save updated blocks on a tree's page. */ class TreePageUpdate implements RequestHandlerInterface { /** @var HomePageService */ private $home_page_service; /** * @param HomePageService $home_page_service */ public function __construct(HomePageService $home_page_service) { $this->home_page_service = $home_page_service; } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $tree = $request->getAttribute('tree'); assert($tree instanceof Tree); $params = (array) $request->getParsedBody(); $defaults = (bool) ($params['defaults'] ?? false); if ($defaults) { $main_blocks = $this->home_page_service->treeBlocks(-1, ModuleBlockInterface::MAIN_BLOCKS) ->map(static function (ModuleBlockInterface $block) { return $block->name(); }); $side_blocks = $this->home_page_service->treeBlocks(-1, ModuleBlockInterface::SIDE_BLOCKS) ->map(static function (ModuleBlockInterface $block) { return $block->name(); }); } else { $main_blocks = new Collection($params[ModuleBlockInterface::MAIN_BLOCKS] ?? []); $side_blocks = new Collection($params[ModuleBlockInterface::SIDE_BLOCKS] ?? []); } $this->home_page_service->updateTreeBlocks($tree->id(), $main_blocks, $side_blocks); return redirect(route(TreePage::class, ['tree' => $tree->name()])); } }