craft-forge/filament-language-switcher

Zero-config language switcher for Filament admin panels. Automatically scans available translations, renders dropdown with country flags, persists selection via sessions.

Installs: 11 147

Dependents: 0

Suggesters: 0

Security: 0

Stars: 9

Watchers: 0

Forks: 2

Open Issues: 0

pkg:composer/craft-forge/filament-language-switcher

v1.2.0 2026-02-08 13:27 UTC

This package is auto-updated.

Last update: 2026-02-13 02:06:42 UTC


README

A simple and elegant language switcher plugin for Filament admin panels. Automatically detects available Filament translations or allows custom language configuration with optional flag icons. Supports auth pages, cookie persistence, and locale change events.

Language Switcher Demo

Language Switcher In Dark Mode

Installation

Plugin Version Filament Version PHP Version
1.x 3.x, 4.x, 5.x > 8.1

1. Install the package via Composer:

composer require craft-forge/filament-language-switcher

2. Register the plugin in your Filament panel configuration (e.g. AdminPanelProvider):

use CraftForge\FilamentLanguageSwitcher\FilamentLanguageSwitcherPlugin;

public function panel(Panel $panel): Panel
{
    return $panel
        ->plugins([
            FilamentLanguageSwitcherPlugin::make(),
        ]);
}

The plugin will automatically detect available Filament language files and display them in a dropdown menu.

Configuration

Custom Languages

Define your own language list instead of auto-detection:

FilamentLanguageSwitcherPlugin::make()
    ->locales(['en', 'fr', 'de'])

The plugin automatically resolves language names and flag icons from its built-in dictionary (200+ languages including regional variants). For full control over names and flags, pass an array of arrays:

FilamentLanguageSwitcherPlugin::make()
    ->locales([
        ['code' => 'en', 'name' => 'English', 'flag' => 'us'],
        ['code' => 'fr', 'name' => 'Français', 'flag' => 'fr'],
        ['code' => 'de', 'name' => 'Deutsch', 'flag' => 'de'],
    ])

Flag codes reference: https://flagicons.lipis.dev.

Alternatively, pass a Closure to load languages dynamically (e.g. from a database):

FilamentLanguageSwitcherPlugin::make()
    ->locales(fn () => Language::pluck('code')->toArray())

Language Switcher Custom Languages

Remember Locale

Store the selected locale in a cookie to persist across browser sessions (e.g. after logout):

FilamentLanguageSwitcherPlugin::make()
    ->rememberLocale()          // forever
    ->rememberLocale(days: 30)  // for 30 days

Custom Render Hook

Change where the language switcher appears in the panel:

use Filament\View\PanelsRenderHook;

FilamentLanguageSwitcherPlugin::make()
    ->renderHook(PanelsRenderHook::USER_MENU_PROFILE_AFTER)

Popular placements:

  • USER_MENU_BEFORE — before the user menu (default)
  • USER_MENU_PROFILE_AFTER — after user profile in dropdown
  • USER_MENU_AFTER — after the user menu
  • SIDEBAR_FOOTER — at the bottom of sidebar
  • FOOTER — in the page footer

All available render hooks: https://filamentphp.com/docs/5.x/advanced/render-hooks

Language Switcher Render Hook

Show on Auth Pages

Display the language switcher on login, register, and password reset pages:

FilamentLanguageSwitcherPlugin::make()
    ->showOnAuthPages()

Language Switcher on Auth Pages

Hide Flags

Display only language names without flag icons:

FilamentLanguageSwitcherPlugin::make()
    ->showFlags(false)

Events

PHP

The plugin dispatches a LocaleChanged event whenever a user switches locale, providing both the new and previous locale:

use CraftForge\FilamentLanguageSwitcher\Events\LocaleChanged;
use Illuminate\Support\Facades\Event;

Event::listen(LocaleChanged::class, function (LocaleChanged $event) {
    // auth()->user()->update(['preferred_locale' => $event->newLocale]);
    // Log::info("Locale changed from {$event->oldLocale} to {$event->newLocale}");
});

JavaScript

A filament-locale-changed browser event is dispatched after the page reloads following a locale change:

window.addEventListener('filament-locale-changed', (e) => {
    // console.log('Locale changed from', e.detail.oldLocale, 'to', e.detail.newLocale);
});

License

The MIT License (MIT). Please see License File for more information.