rodrigofs / filament-maskinput
Alternative the alpine mask.
Fund package maintenance!
rodrigofs
Installs: 3 122
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 1
Forks: 3
Open Issues: 1
Language:JavaScript
Requires
- php: ^8.1
- filament/filament: v3.*
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- larastan/larastan: v2.7.0
- laravel/pint: ^1.0
- nunomaduro/collision: ^v7.8.1
- orchestra/testbench: ^8.0
- pestphp/pest: ^v2.24.3
- pestphp/pest-plugin-laravel: v2.2.0
- pestphp/pest-plugin-livewire: v2.1.0
- phpunit/phpunit: ^10
README
Motivation for Creating the Filament Mask Input Package
The Problem:
While working with data input masks in web applications, I encountered a specific challenge related to the Firefox browser. The issue was that the implemented masks did not function as expected in this browser, leading to inconsistencies and problems in the user experience.
Furthermore, when considering the use of Alpine.js's native x-mask as an alternative solution, I encountered another hurdle. There seemed to be an issue in the interaction between Alpine.js and Livewire, particularly in how the state was updated. This behavior resulted in the unexpected removal of input masks, affecting the usability and functionality of the application.
The Solution:
Faced with these challenges, I decided to create the filament-maskinput package. It is designed to implement input masks efficiently, overcoming the issues found with Firefox and the Alpine.js-Livewire interaction. This package ensures browser compatibility and maintains input masks reliably during Livewire's lifecycle.
Filament Mask Input Package
Overview
The filament-maskinput
package enhances FilamentPHP applications by adding masked input functionalities. It allows for the creation of inputs with various masking patterns, including monetary, dynamic, and fixed patterns.
Installation
Install the package via composer:
composer require rodrigofs/filament-maskinput
Configuration
You can configure the filament-maskinput package through the config/filament-maskinput.php file, setting default values for parameters like allowNegative, decimalPrecision, thousandsSeparator and decimalSeparator.
Optionally, you can publish the config using
php artisan vendor:publish --tag="config"
Usage
MaskInput Component
MaskInput is an extension of TextInput in FilamentPHP, designed to create input fields with custom masking patterns.
Methods
-
money
- Description: Configures the input field for monetary values.
- Parameters:
$decimalPrecision
(int|null): Decimal precision.$decimalSeparator
(string|null): Decimal separator.$thousandsSeparator
(string|null): Thousands delimiter.$allowNegative
(bool|null): Allow negative.
-
mask
- Description: Sets the mask pattern for the input.
- Parameters:
$mask
(string | Closure | RawJs | null): The mask pattern or function.
-
maxLength
- Description: For dynamic masks,
maxLength
acts as a trigger to switch between mask patterns. It's essential when using dynamic masks. - Parameters:
$length
(int | Closure): Maximum length for the input.
- Description: For dynamic masks,
Examples
Money Input
MaskInput::make('money') ->money(); MaskInput::make('money') ->money(decimalPrecision: 3, allowNegative: true); output: "-1.234,560"
Dynamic Input
MaskInput::make('dynamic') ->mask(RawJs::make("['999.999.999-99', '99.999.999/9999-99']")) ->stripCharacters(['.','-', '/']) ->maxLength(14) // Acts as a trigger for mask switching output: "123.456.789-01" or "12.345.678/9012-34"
Pattern Input
MaskInput::make('pattern') ->mask('99999-999') ->stripCharacters(['-']) output: "12345-678"
MaskInput::make('pattern') ->mask('SS.SS.SSSSS.S.S.SSSSSS') ->stripCharacters(['.']) output: "9B.GR.D08X0.4.G.117974"
MaskInput::make('pattern') ->mask('AAA-9999') ->stripCharacters(['-']) output: "ABC-1234"
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.