Workspace Tabs plugin screenshot
Dark mode ready
Multilingual support
Supports v5.x

Workspace Tabs

Browser-like tabs for Filament panels. Open multiple pages in tabs without losing context, drag to reorder, pin frequently accessed pages, and right-click for quick actions.

Tags: Panels Kit Developer Tool
Supported versions:
5.x 4.x
Mustafa Khaled avatar Author: Mustafa Khaled

Documentation

Browser-like tabs for Filament panels. Open multiple pages in tabs without losing context, drag to reorder, pin frequently accessed pages, and right-click for quick actions.

#Features

  • Tab per page — Every navigation opens a new tab. Revisiting a URL activates the existing tab.
  • Drag to reorder — Rearrange tabs via drag-and-drop (powered by SortableJS).
  • Pin tabs — Double-click a tab to pin/unpin it. Pinned tabs can't be closed and stick to the left.
  • Context menu — Right-click any tab for: Close, Close Others, Close to the Right, Duplicate, Pin/Unpin, Close All.
  • Recently closed — Reopen closed tabs from the dropdown (last 50 stored).
  • Keyboard shortcutsCtrl+W / Cmd+W to close the active tab.
  • Middle-click — Middle-click or Ctrl+click sidebar links to open in a new tab.
  • Persistent — Tabs survive page reloads via localStorage.
  • Dark mode — Full support for Filament's dark mode.
  • SPA-ready — Works with Filament's ->spa() mode and Livewire's wire:navigate.

#Requirements

  • PHP 8.2+
  • Filament v4 or v5
  • Laravel 11+

#Installation

composer require wezlo/filament-workspace-tabs

#Setup

#1. Register the plugin

Add the plugin to your panel provider:

use Wezlo\FilamentWorkspaceTabs\WorkspaceTabsPlugin;

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

#2. Add the Tailwind source

Add the package views to your Filament theme CSS so Tailwind can scan utility classes:

/* resources/css/filament/{panel}/theme.css */
@source '../../../../vendor/wezlo/filament-workspace-tabs/resources/views/**/*';

Then rebuild your frontend assets:

npm run build

#Configuration

All options are available as fluent methods on the plugin:

WorkspaceTabsPlugin::make()
    ->maxTabs(25)                          // Maximum open tabs (default: 20)
    ->persistKey('my_tabs')                // localStorage key prefix (default: 'filament_workspace_tabs')
    ->excludeUrls(['/admin/login'])        // URL prefixes to never track as tabs
    ->contextMenu(false)                   // Disable right-click context menu
    ->dragReorder(false)                   // Disable drag-to-reorder

#Usage

Once installed, the tab bar appears below the topbar automatically.

Action Behavior
Click sidebar link Opens a new tab
Click an existing tab Switches to that tab (navigates to its URL)
Middle-click / Ctrl+click a link Opens in a new tab without navigating
Close button (x) Closes the tab
Double-click a tab Pins / unpins the tab
Right-click a tab Opens context menu
Ctrl+W / Cmd+W Closes the active tab
Drag a tab Reorders it

#Pinned tabs

Pinned tabs display a pin icon alongside the label, have an indigo left border, and cannot be closed until unpinned. They always stay to the left of unpinned tabs.

#Context menu options

  • Close — Close this tab (not available for pinned tabs)
  • Close Others — Close all tabs except this one (respects pinned tabs)
  • Close to the Right — Close all tabs to the right of this one
  • Duplicate — Open the same URL in a new tab
  • Pin / Unpin — Toggle the pinned state
  • Close All — Close all unpinned tabs

#Recently closed

When tabs are closed, they're stored in a history list. Click the dropdown arrow on the right side of the tab bar to reopen any of the last 10 recently closed tabs.

#How it works

  • Tab state (URLs, labels, order, pinned status) is stored client-side in localStorage using Alpine.js $persist().
  • Switching tabs triggers Livewire.navigate() for SPA-style page transitions.
  • Page titles are automatically extracted from document.title on each navigation.
  • The tab bar is injected via Filament's TOPBAR_AFTER render hook — no template modifications needed.
  • The persist key is automatically scoped to the panel ID to avoid cross-panel tab bleed.

#Publishing config

php artisan vendor:publish --tag="filament-workspace-tabs-config"

#License

MIT

The author

Mustafa Khaled avatar Author: Mustafa Khaled

15 Year Laravel Developer

Plugins
10
Stars
5

From the same author

Search Spotlight plugin thumbnail

Search Spotlight

A full-screen Spotlight / command-palette search overlay for Filament panels. Opens on ⌘K (configurable), aggregates results from multiple categories (records, resources, pages, actions, plus recent/pinned from localStorage), and composes Filament's built-in `GlobalSearchProvider` — every resource that already implements `getGloballySearchableAttributes()` shows up automatically.

Mustafa Khaled avatar Author: Mustafa Khaled
1 star
Tag: Panels
Dark mode ready Multilingual support
Free
Get it now
Export Pro plugin thumbnail

Export Pro

A comprehensive, model-agnostic export engine for Filament. Handles large datasets with background processing and real-time progress tracking, maintains full export history with audit trails, supports scheduled/recurring exports with delivery, and gives admins visibility into who exported what and when.

Mustafa Khaled avatar Author: Mustafa Khaled
0 stars
Tag: Action Tag: Developer Tool More tags: +3
Dark mode ready Multilingual support
$99.00
Buy now
Record Freezer plugin thumbnail

Record Freezer

Freeze individual Eloquent records against modification — finalised contracts, audited financial periods, legal holds

Mustafa Khaled avatar Author: Mustafa Khaled
2 stars
Tag: Panels Tag: Developer Tool More tags: +1
No dark mode support No multilingual support
Free
Get it now
Record Watcher plugin thumbnail

Record Watcher

Subscribe to individual Eloquent records and receive in-panel Filament notifications whenever they change — with the actor (who) and a field-level diff (what). Watches can carry conditions ("only if status changes", "only if amount > 10K"), can be paused, and live on a personal **My Watches** page scoped to the authenticated user. Every fan-out is also persisted to a permanent event log, so users can review the full change history even after dismissing notifications.

Mustafa Khaled avatar Author: Mustafa Khaled
1 star
Tag: Action Tag: Developer Tool More tags: +2
Dark mode ready Multilingual support
Free
Get it now