xoshbin/filament-create-on-search-select

This is my package filament-create-on-search-select

Fund package maintenance!
Xoshbin

Installs: 0

Dependents: 0

Suggesters: 0

Security: 0

Stars: 1

Watchers: 0

Forks: 0

pkg:composer/xoshbin/filament-create-on-search-select

v0.0.1-alpha 2025-08-30 20:55 UTC

This package is auto-updated.

Last update: 2025-10-13 16:50:22 UTC


README

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

Filament Create On Search Select Preview

A space-efficient Filament form field that solves the interface clutter problem of the original Select field's creation functionality. While Filament's native Select field adds a suffix button and icon for creating new records (which takes up valuable interface space), this component provides a cleaner, more intuitive solution.

The Problem This Solves

Filament's default Select field with createOptionForm() adds visual clutter:

  • ➕ Suffix button takes up horizontal space
  • 🎯 Icon makes the field wider and less clean

The Solution

This component provides the same searchable Select functionality as the original, but with a smarter approach to record creation:

Clean Interface: No suffix buttons or icons cluttering your forms ✅ Smart Suggestions: When searching for a record that doesn't exist, shows "Create [search term]" suggestion ✅ Seamless UX: Click the suggestion to open the same modal creation experience ✅ Space Efficient: Maintains the original Select field's compact design ✅ Fully Customizable: All the same customization options as the original field

Installation

You can install the package via composer:

composer require xoshbin/filament-create-on-search-select

How It Works

  1. Search Experience: Users type to search through existing records (same as original Select)
  2. Smart Detection: When no matching records are found, shows "Create [search term]" suggestion
  3. Modal Creation: Clicking the suggestion opens the familiar Filament modal for creating new records
  4. Seamless Integration: New record is automatically selected and form continues normally

Usage

Basic Usage

Replace your existing Select field with CreateOnSearchSelect:

use Xoshbin\FilamentCreateOnSearchSelect\CreateOnSearchSelect;
use Filament\Forms\Components\TextInput;

// Instead of this cluttered approach:
// Select::make('category_id')
//     ->options(Category::pluck('name', 'id'))
//     ->searchable()
//     ->createOptionForm([...]) // Adds suffix button + icon

// Use this clean approach:
CreateOnSearchSelect::make('category_id')
    ->label('Category')
    ->options(Category::pluck('name', 'id'))
    ->canCreateOption()
    ->createOptionForm([
        TextInput::make('name')
            ->label('Category Name')
            ->required()
            ->maxLength(255),
    ])
    ->createOptionAction(function (array $data) {
        return Category::create([
            'name' => $data['name'],
            'company_id' => auth()->user()->company_id,
        ]);
    })

Advanced Usage

Custom Create Form

You can customize the form fields shown in the create modal using Filament form components:

use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Textarea;

CreateOnSearchSelect::make('customer_id')
    ->label('Customer')
    ->options(Partner::where('type', 'customer')->pluck('name', 'id'))
    ->canCreateOption()
    ->createOptionForm([
        TextInput::make('name')
            ->label('Customer Name')
            ->required()
            ->maxLength(255),
        TextInput::make('email')
            ->label('Email Address')
            ->email()
            ->maxLength(255),
        TextInput::make('phone')
            ->label('Phone Number')
            ->tel()
            ->maxLength(20),
        Textarea::make('address')
            ->label('Address')
            ->rows(3),
    ])
    ->createOptionAction(function (array $data) {
        return Partner::create([
            'name' => $data['name'],
            'email' => $data['email'] ?? null,
            'phone' => $data['phone'] ?? null,
            'address' => $data['address'] ?? null,
            'type' => 'customer',
            'company_id' => auth()->user()->company_id,
        ]);
    })

Custom Modal Labels

Customize the modal heading and button labels:

CreateOnSearchSelect::make('category_id')
    ->label('Category')
    ->options(Category::pluck('name', 'id'))
    ->canCreateOption()
    ->createOptionModalHeading('Create New Category')
    ->createOptionModalSubmitActionLabel('Create Category')
    ->createOptionModalCancelActionLabel('Cancel')
    ->createOptionAction(function (array $data) {
        return Category::create([
            'name' => $data['name'],
        ]);
    })

Available Methods

Method Description
canCreateOption(bool $condition = true) Enable/disable the create option functionality
createOptionAction(Closure $action) Define the action to create a new option
createOptionForm(string $form) Custom HTML form for the create modal
createOptionModalHeading(string $heading) Set the modal heading text
createOptionModalSubmitActionLabel(string $label) Set the submit button text
createOptionModalCancelActionLabel(string $label) Set the cancel button text

Key Features

Interface Benefits:

  • No visual clutter - No suffix buttons or icons taking up space
  • Clean design - Maintains the original Select field appearance
  • Intuitive UX - "Create [search term]" suggestions feel natural

Technical Features:

  • ✅ Extends Filament's native Select component
  • ✅ Modal-based option creation (same as original)
  • ✅ Fully searchable with real-time filtering
  • ✅ Customizable form fields and validation
  • ✅ Dark mode support
  • ✅ Accessible keyboard navigation (Arrow keys, Enter, Escape)
  • ✅ Works with relationships and custom models
  • ✅ Supports all original Select field options

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.