xref: /webtrees/app/Http/RequestHandlers/TomSelectLocation.php (revision d5f5ec85f2c6136039890f84f4b64eece6733d09)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2021 webtrees development team
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <https://www.gnu.org/licenses/>.
16 */
17
18declare(strict_types=1);
19
20namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22use Fisharebest\Webtrees\Registry;
23use Fisharebest\Webtrees\Services\SearchService;
24use Fisharebest\Webtrees\Location;
25use Fisharebest\Webtrees\Tree;
26use Illuminate\Support\Collection;
27
28use function array_filter;
29use function explode;
30use function view;
31
32/**
33 * Autocomplete for locations.
34 */
35class TomSelectLocation extends AbstractTomSelectHandler
36{
37    protected SearchService $search_service;
38
39    /**
40     * TomSelectLocation constructor.
41     *
42     * @param SearchService $search_service
43     */
44    public function __construct(
45        SearchService $search_service
46    ) {
47        $this->search_service = $search_service;
48    }
49
50    /**
51     * Perform the search
52     *
53     * @param Tree   $tree
54     * @param string $query
55     * @param int    $offset
56     * @param int    $limit
57     * @param string $at
58     *
59     * @return Collection<int,array{text:string,value:string}>
60     */
61    protected function search(Tree $tree, string $query, int $offset, int $limit, string $at): Collection
62    {
63        // Search by XREF
64        $location = Registry::locationFactory()->make($query, $tree);
65
66        if ($location instanceof Location) {
67            $results = new Collection([$location]);
68        } else {
69            $search  = array_filter(explode(' ', $query));
70            $results = $this->search_service->searchLocations([$tree], $search, $offset, $limit);
71        }
72
73        return $results->map(static function (Location $location) use ($at): array {
74            return [
75                'text'  => view('selects/location', ['location' => $location]),
76                'value' => $at . $location->xref() . $at,
77            ];
78        });
79    }
80}
81