. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Factory; use Fisharebest\Webtrees\Tree; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function array_merge; use function array_search; use function assert; use function implode; use function is_array; use function is_string; use function redirect; use function uksort; /** * Reorder the names of an individual. */ class ReorderNamesAction implements RequestHandlerInterface { /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $tree = $request->getAttribute('tree'); assert($tree instanceof Tree); $xref = $request->getAttribute('xref'); assert(is_string($xref)); $individual = Factory::individual()->make($xref, $tree); $individual = Auth::checkIndividualAccess($individual, true); $params = (array) $request->getParsedBody(); $order = $params['order']; assert(is_array($order)); $dummy_facts = ['0 @' . $individual->xref() . '@ INDI']; $sort_facts = []; $keep_facts = []; // Split facts into NAME and other foreach ($individual->facts() as $fact) { if ($fact->getTag() === 'NAME') { $sort_facts[$fact->id()] = $fact->gedcom(); } else { $keep_facts[] = $fact->gedcom(); } } // Sort the facts uksort($sort_facts, static function (string $x, string $y) use ($order): int { return array_search($x, $order, true) <=> array_search($y, $order, true); }); // Merge the facts $gedcom = implode("\n", array_merge($dummy_facts, $sort_facts, $keep_facts)); $individual->updateRecord($gedcom, false); return redirect($individual->url()); } }