Files
einundzwanzig-app/app/Http/Controllers/Api/CountryController.php
T
HolgerHatGarKeineNode f93190f029 Add whereLike and orWhereLike macros for driver-agnostic case-insensitive searches
- 🔄 Replace `ilike`/`like` conditions with `whereLike` in API controllers and search tools for consistency.
- 🚀 Enhance query usability by ensuring cross-database compatibility (PostgreSQL and SQLite).
2026-06-14 01:32:03 +02:00

74 lines
2.3 KiB
PHP

<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Models\Country;
use Dedoc\Scramble\Attributes\ExcludeRouteFromDocs;
use Dedoc\Scramble\Attributes\Group;
use Dedoc\Scramble\Attributes\QueryParameter;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Http\Request;
#[Group(name: 'Stammdaten', weight: 5)]
class CountryController extends Controller
{
/**
* Länder auflisten und durchsuchen
*
* Öffentlicher Endpunkt; liefert id, name und code (Ländercode), alphabetisch sortiert. Ohne 'selected' wird das Ergebnis auf 10 Einträge begrenzt. Jedes Land enthält zusätzlich eine 'flag' (SVG-URL).
*/
#[QueryParameter(name: 'search', description: 'Suche in Name oder Code (Ländercode).', required: false, type: 'string')]
#[QueryParameter(name: 'selected', description: 'Lädt gezielt die angegebenen Codes oder IDs.', required: false, type: 'array')]
public function index(Request $request)
{
return Country::query()
->select('id', 'name', 'code')
->orderBy('name')
->when(
$request->search,
fn (Builder $query) => $query
->whereLike('name', "%{$request->search}%")
->orWhereLike('code', "%{$request->search}%"),
)
->when(
$request->exists('selected'),
fn (Builder $query) => $query
->whereIn('code', $request->input('selected', []))
->orWhereIn('id',
$request->input('selected', [])),
fn (Builder $query) => $query->limit(10),
)
->get()
->map(function (Country $country) {
$country->flag = asset('vendor/blade-flags/country-'.$country->code.'.svg');
return $country;
});
}
#[ExcludeRouteFromDocs]
public function store(Request $request)
{
//
}
#[ExcludeRouteFromDocs]
public function show(Country $country)
{
//
}
#[ExcludeRouteFromDocs]
public function update(Request $request, Country $country)
{
//
}
#[ExcludeRouteFromDocs]
public function destroy(Country $country)
{
//
}
}