salemaljebaly / filament-map-picker
A Leaflet / OpenStreetMap map picker field for Filament v5.
Installs: 284
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
Language:Blade
pkg:composer/salemaljebaly/filament-map-picker
Requires
- php: ^8.2
- filament/filament: ^5.0
- illuminate/support: ^11.0|^12.0
Requires (Dev)
- orchestra/testbench: ^9.0|^10.0
- phpunit/phpunit: ^11.0
README
A simple, polished Filament v5 map picker field built on Leaflet + OpenStreetMap (free services only).
Screenshots
Light Mode — Search & Suggestions
Dark Mode — Controls & Theme Matching
Goals (v1)
- Fast to install, no API keys required
- Great UX: search, collapsible search, my-location, reset, fullscreen, zoom buttons
- Dark / light theme compatible
- RTL-friendly search input (
dir="auto") - SPA-safe (cleans up on Filament/Livewire navigation)
Non-goals (v1)
- Paid providers (Google / Mapbox)
- Drawing tools (polygons, GeoJSON, etc.)
Requirements
- PHP
^8.2 - Laravel
^11or^12 - Filament
^5
Installation
composer require salemaljebaly/filament-map-picker
Publish config (optional):
php artisan vendor:publish --tag=filament-map-picker-config
Basic Usage (Form)
This component writes to your latitude/longitude fields. Keep the map field itself non-dehydrated.
use Filament\Forms; use SalemAljebaly\FilamentMapPicker\MapPicker; Forms\Components\Hidden::make('latitude')->rules(['nullable', 'numeric']), Forms\Components\Hidden::make('longitude')->rules(['nullable', 'numeric']), MapPicker::make('location') ->label('Location') ->latlngFields('latitude', 'longitude') ->searchable() ->collapsibleSearch() ->draggable() ->height(320),
Usage (Infolist / View)
use SalemAljebaly\FilamentMapPicker\MapView; MapView::make('location') ->label('Location') ->latlngFields('latitude', 'longitude') ->height(240),
Configuration
Defaults live in config/filament-map-picker.php.
Common options:
default_location.lat,default_location.lngdefault_zoomheightmarker.color,marker.draggableauto_dark_modetile_provider(osm,cartodb_light,cartodb_dark)controls.my_location,controls.fullscreen,controls.resetcontrol_position(topleft,topright,bottomleft,bottomright)search.enabled,search.collapsible,search.throttle_ms,search.min_length,search.limitsearch.nominatim.email(env:NOMINATIM_EMAIL)
Customizing Icons
Icons are Blade views under:
resources/views/icons/*.blade.php
To override icons in your app, create matching files here:
resources/views/vendor/filament-map-picker/icons/*.blade.php
For consistent theming, make sure your SVGs use stroke="currentColor" / fill="currentColor" instead of hard-coded colors.
Geolocation Notes
The browser geolocation API requires HTTPS (except localhost). If it fails, it’s usually due to:
- Permission denied in the browser
- Non-HTTPS site
- Location services disabled (OS / browser)
Nominatim (Search) Notes
Nominatim has usage policies and rate limits. Browser requests can’t reliably set a custom User-Agent header.
If you expect heavy usage, proxy geocoding through your backend. For light usage, configure:
NOMINATIM_EMAIL="you@example.com"

