swisnl/filament-geometry

Geometry form field for Filament PHP

Fund package maintenance!
swisnl

Installs: 1 628

Dependents: 0

Suggesters: 0

Security: 0

Stars: 1

Watchers: 1

Forks: 0

Open Issues: 0

pkg:composer/swisnl/filament-geometry

0.7.2 2025-11-24 09:27 UTC

README

Latest Version on Packagist Software License Buy us a tree GitHub Tests Action Status GitHub Code Style Action Status Total Downloads Made by SWIS

Filament geometry screenshot

Warning

Work in progress, not stable yet!

Installation

You can install the package via composer:

composer require swisnl/filament-geometry

Important

If you have not set up a custom theme and are using Filament Panels follow the instructions in the Filament Docs first.

After setting up a custom theme add the plugin's views to your theme css file or your app's css file if using the standalone packages.

@source '../../../../vendor/swisnl/filament-geometry/resources/**/*.blade.php';

Component

Geometry Field

The Geometry field displays a Leaflet map, with a set of configuration options.

Map Field

Usage

Geometry Field

Important

This field is designed to be used in conjunction with a database column of type (MULTI)POINT, (MULTI)LINESTRING, (MULTI)POLYGON or GEOMETRY. It currently does not support geometries with mixed types i.e. GEOMETRYCOLLECTION.

The form field can be used with no options, by simply adding this to your Filament form schema:

use Filament\Forms\Form;
use Swis\Filament\Geometry\Enums\DrawMode;
use Swis\Filament\Geometry\Forms\Geometry;

public function form(Form $form): Form
{
    return $form
        ->schema([
            Geometry::make('location'),
        ]);
}

Full options

The full set of options is as follows. Some option methods support closures, as well as direct values.

use Filament\Forms\Form;
use Swis\Filament\Geometry\Bounds;
use Swis\Filament\Geometry\Enums\ControlPosition;
use Swis\Filament\Geometry\Enums\DrawMode;
use Swis\Filament\Geometry\Forms\Geometry;
use Swis\Filament\Geometry\GeoSearchProviders\OpenStreetMap;
use Swis\Filament\Geometry\Icons\Marker;
use Swis\Filament\Geometry\TileLayers\Carto;

public function form(Form $form): Form
{
    return $form
        ->schema([
            Geometry::make('location')
                ->label(__('Location'))
            
                // Map configuration
                ->maxZoom(16)
                ->minZoom(4)
                ->center(52.164206390898904, 4.491920969490259)
                ->zoom(15)
                ->bounds(Bounds::make(49.5, -11, 61, 2)) // Example for British Isles
                ->tileLayer(Carto::make())
            
                // Marker configuration
                ->markerIcon(Marker::make('#3b82f6'))
                
                // Controls
                ->showFullscreenControl(true)
                ->showZoomControl(true)
                ->showAttributionControl(true)
                ->geoSearch(OpenStreetMap::make())
                ->drawModes([
                    DrawMode::Polygon,
                    DrawMode::Rectangle,
                ])
                ->multipart(false)
                ->drawControlPosition(ControlPosition::TopRight),
        ]);
}

Casts

The field automatically tries to detect the type of your attribute by checking the model's casts. We currently support the following casts out of the box:

If we cannot detect the type automatically, you can specify it manually using one of the following methods:

use Filament\Forms\Form;
use Swis\Filament\Geometry\Forms\Geometry;

public function form(Form $form): Form
{
    return $form
        ->schema([
            Geometry::make('location')
                // Use one of the following state cast methods:
                ->asString()
                ->asArray()
                ->asObject()
                ->asEloquentSpatial()
                // Or use a custom state cast that implements \Filament\Schemas\Components\StateCasts\Contracts\StateCast:
                ->stateCast(new YourCustomStateCast()),
        ]);
}

Testing

composer test

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.

SWIS ❤️ Open Source

SWIS is a web agency from Leiden, the Netherlands. We love working with open source software.