lbcdev / filament-maps-widgets
Interactive map widgets for Filament panels
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/lbcdev/filament-maps-widgets
Requires
- php: ^8.2|^8.3
- filament/filament: ^3.0
- illuminate/contracts: ^10.0|^11.0|^12.0
- lbcdev/livewire-maps-core: ^1.0.0
- lbcdev/map-geometries: ^1.0.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- orchestra/testbench: ^8.0|^9.0
- phpunit/phpunit: ^10.0|^11.0
README
Interactive map widgets for Filament panels, built on top of livewire-maps-core and map-geometries.
Installation
You can install the package via composer:
composer require lbcdev/filament-maps-widgets
Optionally, you can publish the config file with:
php artisan vendor:publish --tag="filament-maps-widgets-config"
Quick Start
Create a map widget by extending MapWidget:
namespace App\Filament\Widgets; use LBCDev\FilamentMapsWidgets\Widgets\MapWidget; use LBCDev\MapGeometries\Marker; use LBCDev\MapGeometries\MarkerCollection; class LocationsMap extends MapWidget { protected function getMarkers(): MarkerCollection { $markers = new MarkerCollection(); $markers->add( Marker::make('home') ->lat(40.7128) ->lng(-74.0060) ->popup('New York City') ); return $markers; } protected function getMapCenter(): array { return ['lat' => 40.7128, 'lng' => -74.0060]; } }
Features
- πΊοΈ Easy Integration: Built specifically for Filament panels
- π¨ Customizable: Configure map center, zoom, options, and more
- π― Actions System: Add custom actions/controls to your maps
- π§© Modular: Built on top of separate core and geometries packages
- β Well Tested: Comprehensive test coverage
- π Documented: Full API documentation
Basic Usage
Simple Map Widget
use LBCDev\FilamentMapsWidgets\Widgets\MapWidget; use LBCDev\MapGeometries\Marker; class MyMap extends MapWidget { protected function getMarkers(): array { return [ Marker::make('marker-1') ->lat(51.505) ->lng(-0.09) ->popup('London'), ]; } }
Custom Map Configuration
class MyMap extends MapWidget { protected function getMapCenter(): array { return ['lat' => 51.505, 'lng' => -0.09]; } protected function getMapZoom(): int { return 13; } protected function getMapOptions(): array { return [ 'scrollWheelZoom' => true, 'dragging' => true, 'minZoom' => 10, 'maxZoom' => 18, ]; } }
Dynamic Markers from Database
use App\Models\Location; class LocationsMap extends MapWidget { protected function getMarkers(): MarkerCollection { $markers = new MarkerCollection(); Location::all()->each(function ($location) use ($markers) { $markers->add( Marker::make($location->id) ->lat($location->latitude) ->lng($location->longitude) ->color($location->is_active ? 'green' : 'red') ->popup("<b>{$location->name}</b><br>{$location->address}") ); }); return $markers; } }
Adding Actions
use LBCDev\FilamentMapsWidgets\Actions\ZoomAction; class MyMap extends MapWidget { protected function getActions(): array { return [ ZoomAction::make() ->position('topright'), ]; } }
Configuration
The package comes with sensible defaults, but you can customize everything via the config file:
return [ 'default_center' => [ 'lat' => 0, 'lng' => 0, ], 'default_zoom' => 10, 'default_height' => '500px', 'map_options' => [ 'scrollWheelZoom' => true, 'dragging' => true, // ... more options ], ];
Advanced Usage
Reactive Widgets with Filters
class FilteredMap extends MapWidget { public array $filters = []; protected $listeners = [ 'filtersUpdated' => 'handleFiltersUpdated', ]; public function mount(array $filters = []): void { $this->filters = $filters; parent::mount(); } protected function getMarkers(): MarkerCollection { // Apply filters to your query $query = Location::query(); if ($this->filters['category'] ?? null) { $query->where('category_id', $this->filters['category']); } // Build markers from filtered results // ... } public function handleFiltersUpdated(array $filters): void { $this->filters = $filters; $this->refresh(); } }
Custom Height and Styling
class MyMap extends MapWidget { public string $height = '700px'; protected bool $hasBorder = true; }
Testing
composer test
Or with coverage:
composer test-coverage
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.
Related Packages
This package is part of the LBCDev Maps Suite:
- livewire-maps-core - Core Livewire map component
- map-geometries - Map geometry classes (Marker, Polyline, etc.)
- filament-maps-fields - Map form fields for Filament
- lbcdev-filament-maps-suite - Meta-package for all components