Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/TappNetwork/filament-timezone-field
https://github.com/TappNetwork/filament-timezone-field
hacktoberfest
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/TappNetwork/filament-timezone-field
- Owner: TappNetwork
- Created: 2022-05-05T21:47:08.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-05-22T15:04:04.000Z (9 months ago)
- Last Synced: 2024-05-22T16:27:52.583Z (9 months ago)
- Topics: hacktoberfest
- Language: PHP
- Homepage:
- Size: 413 KB
- Stars: 35
- Watchers: 5
- Forks: 7
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-filament - TappNetwork/filament-timezone-field - A Timezone field for FilamentPHP. (Fields)
README
# Filament Timezone Field
[data:image/s3,"s3://crabby-images/4ab26/4ab269072d4f54090a183afb17bd7239c7936289" alt="Latest Version on Packagist"](https://packagist.org/packages/tapp/filament-timezone-field)
data:image/s3,"s3://crabby-images/1a920/1a92052681dbf07f85a38b192efb4eb38c9d860b" alt="Code Style Action Status"
[data:image/s3,"s3://crabby-images/a056c/a056cb4b8d6ae3ca749378abd785e511dd717a6c" alt="Total Downloads"](https://packagist.org/packages/tapp/filament-timezone-field)A timezone select field for Laravel Filament.
## Installation
```bash
composer require tapp/filament-timezone-field:"^3.0"
```> **Note**
> For **Filament 2.x** check the **[2.x](https://github.com/TappNetwork/filament-timezone-field/tree/2.x)** branch## Usage
### Form Field
Add to your Filament resource:
```php
use Tapp\FilamentTimezoneField\Forms\Components\TimezoneSelect;public static function form(Form $form): Form
{
return $form
->schema([
// ...
TimezoneSelect::make('timezone'),
// ...
]);
}
```#### Appareance
data:image/s3,"s3://crabby-images/cd9de/cd9de5fcb14553a38eb723d21fab21f5346d6dd1" alt="Filament Timezone Field"
#### Options
To use GMT instead of UTC (default is UTC), add the `->timezoneType('GMT')` method:
```php
use Tapp\FilamentTimezoneField\Forms\Components\TimezoneSelect;public static function form(Form $form): Form
{
return $form
->schema([
// ...
TimezoneSelect::make('timezone')
->timezoneType('GMT'),
// ...
]);
}
```##### List timezones by country
To list only the timezones for a country, you can pass the country code to `->byCountry()` method. For example, to list only United States timezones:
```php
TimezoneSelect::make('timezone')
->byCountry('US')
```You can also pass an array with more than one country code:
```php
TimezoneSelect::make('timezone')
->byCountry(['US', 'AU'])
```##### List timezones by region
To list the timezones for a region use the `->byRegion()` method. You can specify a region with a [Region enum value](src/Enums/Region.php):
```php
use Tapp\FilamentTimezoneField\Enums\Region;TimezoneSelect::make('timezone')
->byRegion(Region::Australia)
```or you can use one of the [PHP's DateTimeZone predifined constants](https://www.php.net/manual/en/class.datetimezone.php):
```php
use DateTimeZone;TimezoneSelect::make('timezone')
->byRegion(DateTimeZone::AUSTRALIA)
```It's also possible to pass an array with more than one region:
```php
use Tapp\FilamentTimezoneField\Enums\Region;TimezoneSelect::make('timezone')
->byRegion([Region::Australia, Region::America])
```> [!TIP]
> All [Filament select field](https://filamentphp.com/docs/2.x/forms/fields#select) methods are available to use:
>
> ```php
> use Tapp\FilamentTimezoneField\Forms\Components\TimezoneSelect;
>
> public static function form(Form $form): Form
> {
> return $form
> ->schema([
> // ...
> TimezoneSelect::make('timezone')
> ->searchable()
> ->required(),
> // ...
> ]);
> }
> ```Optionally, hide either timezone offsets or timezone names, depending on your use case:
data:image/s3,"s3://crabby-images/18e11/18e11361beebdde916ab8a822c0606252bcef462" alt="Filament Timezone Display Options"
```php
use Tapp\FilamentTimezoneField\Forms\Components\TimezoneSelect;public static function form(Form $form): Form
{
return $form
->schema([
// ...
TimezoneSelect::make('timezone')
->hideNames(),
// ...
]);
}
``````php
use Tapp\FilamentTimezoneField\Forms\Components\TimezoneSelect;public static function form(Form $form): Form
{
return $form
->schema([
// ...
TimezoneSelect::make('timezone')
->hideOffset(),
// ...
]);
}
```### Table Column
```php
use Tapp\FilamentTimezoneField\Tables\Columns\TimezoneColumn;public static function table(Table $table): Table
{
return $table
->columns([
//...
TimezoneColumn::make('timezone')
->timezoneType('GMT')
->formattedOffsetAndTimezone(),
])
// ...
}
```#### Options
| Method | Description |
| --- | --- |
| ->formattedTimezone() | Show formatted timezone name |
| ->formattedOffsetAndTimezone() | Show formatted offset and timezone name |
| ->timezoneType('GMT') | Use GMT instead of UTC |### Table Filter
```php
use Tapp\FilamentTimezoneField\Tables\Filters\TimezoneSelectFilter;public static function table(Table $table): Table
{
return $table
//...
->filters([
TimezoneSelectFilter::make('timezone'),
// ...
])
}
```