PHPackages                             flexpik/filament-studio - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Admin Panels](/categories/admin)
4. /
5. flexpik/filament-studio

ActiveLibrary[Admin Panels](/categories/admin)

flexpik/filament-studio
=======================

Dynamic data model manager for Filament — build unlimited collections with custom fields, EAV storage, versioning, and multi-tenancy

v1.3.0(1mo ago)423349[4 PRs](https://github.com/flexpik/filament-studio/pulls)MITPHPPHP ^8.3CI passing

Since Mar 27Pushed 2w ago3 watchersCompare

[ Source](https://github.com/flexpik/filament-studio)[ Packagist](https://packagist.org/packages/flexpik/filament-studio)[ Docs](https://github.com/flexpik/filament-studio)[ RSS](/packages/flexpik-filament-studio/feed)WikiDiscussions main Synced 3w ago

READMEChangelog (5)Dependencies (15)Versions (12)Used By (0)

 [![Filament Studio — Plugin Preview](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/preview.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/preview.png)

 [![Latest Version on Packagist](https://camo.githubusercontent.com/71e2d745a2dcd6c8bbe3bfa9ffbd7eaede31023a554228d364dcbfd9db92998a/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f666c657870696b2f66696c616d656e742d73747564696f2e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/flexpik/filament-studio) [![Total Downloads](https://camo.githubusercontent.com/df39dc18be8636d14c4ae7236a8f0a90d55d8be581bf1ccbbd3253616bfeaf8a/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f666c657870696b2f66696c616d656e742d73747564696f2e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/flexpik/filament-studio) [![Tests](https://camo.githubusercontent.com/7072d80a2fd8ca3d2f648c15ffef7899feb12d66453e1923337f32714fd36f9c/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f616374696f6e732f776f726b666c6f772f7374617475732f666c657870696b2f66696c616d656e742d73747564696f2f74657374732e796d6c3f6272616e63683d6d61696e266c6162656c3d7465737473267374796c653d666c61742d737175617265)](https://github.com/flexpik/filament-studio/actions) [![License](https://camo.githubusercontent.com/763df9ce96c004ba8a58ce3c3775bed1b01ef9495ef65a018dd48acdc206aa86/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f6c2f666c657870696b2f66696c616d656e742d73747564696f2e7376673f7374796c653d666c61742d737175617265)](https://github.com/flexpik/filament-studio/blob/main/LICENSE.md)

Filament Studio
===============

[](#filament-studio)

**A dynamic data model manager for Filament v5 — create collections, define fields, manage records, and build dashboards, all at runtime. No migrations required.**

Filament Studio turns your Filament admin panel into a flexible data platform. Define custom data structures through a visual interface, and the plugin handles the rest: forms, tables, filters, API endpoints, dashboards, and access control — all powered by an EAV (Entity-Attribute-Value) storage engine.

Screenshots
-----------

[](#screenshots)

Collections list[![Collections List](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/collections-list.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/collections-list.png)Create collection — Basic Info[![Create Collection — Basic Info](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/create-collection-basic-info.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/create-collection-basic-info.png)Create collection — System Fields[![Create Collection — System Fields](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/create-collection-system-fields.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/create-collection-system-fields.png)Create collection — Settings[![Create Collection — Settings](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/create-collection-settings.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/create-collection-settings.png)Fields list[![Fields List](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/fields-list.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/fields-list.png)Field editor[![Field Editor](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/field-editor.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/field-editor.png)Advanced filter builder[![Advanced Filter Builder](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/advanced-filter.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/advanced-filter.png)Version history[![Version History](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/version-history.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/version-history.png)Dashboard editor[![Dashboard Editor](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/dashboard-editor.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/dashboard-editor.png)API Keys[![API Keys List](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/api-keys-list.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/api-keys-list.png)API Key editor[![API Key Editor](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/api-key-editor.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/api-key-editor.png)API Documentation[![API Documentation](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/api-documentation.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/api-documentation.png)Collection permissions[![Collection Permissions](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/collection-permissions.png)](https://raw.githubusercontent.com/flexpik/filament-studio/main/art/collection-permissions.png)Why Filament Studio?
--------------------

[](#why-filament-studio)

- **No migrations per collection** — Add new data types at runtime without touching your codebase
- **Full Filament integration** — Native forms, tables, filters, and actions that look and feel like hand-crafted resources
- **Production-ready** — Multi-tenancy, multilingual content, authorization, versioning, soft deletes, and audit logging out of the box
- **AI-native** — Built-in MCP server lets Claude, Cursor, and other AI tools manage your data model through natural language
- **Extensible** — Register custom field types, panel types, condition resolvers, and lifecycle hooks

Features
--------

[](#features)

### Dynamic Collections

[](#dynamic-collections)

Create and manage data collections with custom fields through the admin UI. Each collection gets a fully functional CRUD interface with forms, tables, and filters — generated dynamically from the field definitions.

**33 built-in field types** across 9 categories:

CategoryTypesTextText, Textarea, Rich Editor, Markdown, Password, Slug, Color, HiddenNumericInteger, Decimal, RangeBooleanCheckbox, ToggleSelectionSelect, Multi-Select, Radio, Checkbox List, TagsDate &amp; TimeDate, Time, DatetimeFileFile, Image, AvatarRelationalBelongs To, Has Many, Belongs To ManyStructuredRepeater, Builder, Key-ValuePresentationSection Header, Divider, Callout### Dashboard Builder

[](#dashboard-builder)

Build data dashboards with **9 panel types**: Metric, List, Time Series, Bar Chart, Line Chart, Pie Chart, Meter, Label, and Variable. Place panels on dashboards (12-column grid), collection pages, or record pages.

Panels support dynamic variables (`$CURRENT_USER`, `$NOW`, `{{custom}}`), aggregate functions (count, sum, avg, min, max), and interactive controls.

### Advanced Filtering

[](#advanced-filtering)

A visual filter builder with **23 operators**, nested AND/OR logic, dynamic variables, and saved filter presets. Operators adapt to data type — text fields get "contains" and "starts with", dates get "before" and "after", JSON fields get "contains any/all/none".

### REST API

[](#rest-api)

Auto-generated RESTful API with API key authentication, per-collection permissions, rate limiting, and OpenAPI documentation via Scramble.

### MCP Server

[](#mcp-server)

A built-in [Model Context Protocol](https://modelcontextprotocol.io/) server lets AI assistants (Claude, Cursor, Windsurf) manage your data model through natural language. Connect via stdio or HTTP and gain access to **34 tools** covering every aspect of Filament Studio:

- **Schema design** — create and update collections, fields, and field options
- **Data access** — query, create, update, and delete records with full filter-tree support
- **Dashboards** — build and configure dashboards and panels
- **Administration** — manage saved filters and API keys

```
{
  "mcpServers": {
    "filament-studio": {
      "type": "stdio",
      "command": "php",
      "args": ["artisan", "mcp:start", "studio"],
      "env": { "STUDIO_API_KEY": "your-key", "STUDIO_MCP_ENABLED": "true" }
    }
  }
}
```

### Conditional Logic

[](#conditional-logic)

Fields can be conditionally visible, required, or disabled based on form values, user permissions, page context, or custom resolvers — with cycle detection for safety.

### Multilingual Content

[](#multilingual-content)

Opt-in per-locale support for translatable fields. Enable multilingual globally, then configure each collection with its own supported locales and default locale. Mark individual fields as translatable — non-translatable fields (booleans, dates, numbers) store a single value regardless of locale.

- **Locale resolution** — `?locale=` query param &gt; `X-Locale` header &gt; session &gt; collection default &gt; global default
- **Automatic fallback** — When a translation is missing, falls back to the default locale with metadata indicating which fields fell back
- **Admin locale switcher** — Toggle between locales in the record editor; version history includes a per-locale viewer
- **API support** — All REST endpoints accept locale selection; `?all_locales=true` returns all translations as nested objects
- **OpenAPI documentation** — Locale parameters and `_meta` response schemas appear automatically in API docs when multilingual is enabled

```
// config/filament-studio.php
'locales' => [
    'enabled' => true,
    'available' => ['en', 'fr', 'de'],
    'default' => 'en',
],
```

### Multi-Tenancy

[](#multi-tenancy)

Full tenant isolation across all models. Every collection, record, dashboard, and API key is scoped to its tenant.

### Record Versioning &amp; Soft Deletes

[](#record-versioning--soft-deletes)

Optional snapshot-based version history with restore capability, including per-locale snapshots for translatable fields. Optional soft deletes to recover deleted records.

### Authorization &amp; Spatie Permissions

[](#authorization--spatie-permissions)

Policy-based access control with granular per-collection permissions. When `spatie/laravel-permission` is installed, Filament Studio automatically syncs permissions for each collection:

- **Per-collection CRUD permissions** — `studio.collection.{slug}.viewRecords`, `createRecord`, `updateRecord`, `deleteRecord`
- **Global permissions** — `studio.manageFields`, `studio.manageApiKeys`
- **Auto-sync** — Permissions are created/removed automatically when collections are created, renamed, or deleted
- **Navigation &amp; action enforcement** — UI elements (navigation items, create/edit/delete buttons) are hidden when the user lacks the corresponding permission
- **Graceful fallback** — If Spatie Permission is not installed, all actions are allowed by default

Quick Start
-----------

[](#quick-start)

### Install

[](#install)

```
composer require flexpik/filament-studio
```

### Publish &amp; Migrate

[](#publish--migrate)

```
php artisan vendor:publish --tag="filament-studio-migrations"
php artisan migrate
```

### Register the Plugin

[](#register-the-plugin)

```
use Flexpik\FilamentStudio\FilamentStudioPlugin;

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

Visit your admin panel — you'll find a new **Studio** section in the sidebar.

### Configure (Optional)

[](#configure-optional)

```
FilamentStudioPlugin::make()
    ->navigationGroup('Content')
    ->enableVersioning()
    ->enableSoftDeletes()
    ->enableApi()
    ->fieldTypes([
        'currency' => CurrencyFieldType::class,
    ])
    ->panelTypes([
        CustomMapPanel::class,
    ]);
```

Publish the config for environment-level settings:

```
php artisan vendor:publish --tag="filament-studio-config"
```

Extending
---------

[](#extending)

### Custom Field Types

[](#custom-field-types)

Create field types by extending `AbstractFieldType`:

```
use Flexpik\FilamentStudio\FieldTypes\AbstractFieldType;
use Flexpik\FilamentStudio\Enums\EavCast;

class RatingFieldType extends AbstractFieldType
{
    protected static string $key = 'rating';
    protected static string $label = 'Rating';
    protected static string $icon = 'heroicon-o-star';
    protected static EavCast $eavCast = EavCast::Integer;
    protected static string $category = 'numeric';

    public function settingsSchema(): array { /* ... */ }
    public function toFilamentComponent(): Component { /* ... */ }
    public function toTableColumn(): ?Column { /* ... */ }
    public function toFilter(): ?Filter { /* ... */ }
}
```

### Lifecycle Hooks

[](#lifecycle-hooks)

React to events and modify generated schemas:

```
FilamentStudioPlugin::afterCollectionCreated(fn ($collection) => /* ... */);
FilamentStudioPlugin::afterFieldAdded(fn ($field) => /* ... */);

FilamentStudioPlugin::modifyFormSchema(fn (array $schema, $collection) => $schema);
FilamentStudioPlugin::modifyTableColumns(fn (array $columns, $collection) => $columns);
FilamentStudioPlugin::modifyQuery(fn ($query) => $query);
```

Architecture
------------

[](#architecture)

Filament Studio uses **EAV (Entity-Attribute-Value) storage** — data is stored across four core tables instead of creating a table per collection:

TablePurpose`studio_collections`Schema definitions (name, slug, settings)`studio_fields`Field definitions per collection (type, settings, validation)`studio_records`Record entries (UUID, collection, tenant)`studio_values`Typed data storage (text, integer, decimal, boolean, datetime, JSON columns)This approach enables runtime schema changes without migrations while preserving native database sorting and type safety through typed storage columns.

Documentation
-------------

[](#documentation)

GuideDescription[Installation](docs/installation.md)Requirements, setup, and verification[Configuration](docs/configuration.md)Config file, plugin options, feature flags[Field Types](docs/field-types.md)All 33 built-in types, EAV storage, field settings[Dashboards &amp; Panels](docs/dashboards.md)Dashboard builder, 9 panel types, variables[Filtering](docs/filtering.md)23 operators, filter trees, saved filters[REST API](docs/api.md)Endpoints, authentication, permissions, rate limiting[MCP Server](docs/mcp.md)AI assistant integration — 34 tools, stdio &amp; HTTP transport, auth, rate limiting[Conditional Logic](docs/conditional-logic.md)Dynamic visibility, required, and disabled states[Authorization](docs/authorization.md)Policies, permissions, Spatie integration[Multi-Tenancy](docs/multi-tenancy.md)Tenant scoping, lifecycle hooks[Multilingual](docs/multilingual.md)Locale config, translatable fields, API locale support[Record Versioning](docs/versioning.md)Snapshots, restore, soft deletes[Hooks &amp; Events](docs/hooks.md)Lifecycle hooks, schema modification[Custom Field Types](docs/extending/custom-field-types.md)Building your own field types[Custom Panel Types](docs/extending/custom-panel-types.md)Building your own dashboard panelsRequirements
------------

[](#requirements)

- PHP 8.3+
- Laravel 11+
- Filament v5

Testing
-------

[](#testing)

```
vendor/bin/pest
```

Changelog
---------

[](#changelog)

See [CHANGELOG](CHANGELOG.md) for recent changes.

Contributing
------------

[](#contributing)

See [CONTRIBUTING](CONTRIBUTING.md) for details.

Security
--------

[](#security)

If you discover a security vulnerability, please send an email to the maintainers. All security vulnerabilities will be promptly addressed.

Credits
-------

[](#credits)

- [Flexpik](https://github.com/flexpik)
- [All Contributors](../../contributors)

License
-------

[](#license)

The MIT License (MIT). See [LICENSE](LICENSE.md) for details.

###  Health Score

51

—

FairBetter than 95% of packages

Maintenance94

Actively maintained with recent releases

Popularity29

Limited adoption so far

Community14

Small or concentrated contributor base

Maturity55

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 92.9% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~6 days

Total

8

Last Release

47d ago

PHP version history (2 changes)v1.0.0PHP ^8.2

v1.0.1PHP ^8.3

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/268365064?v=4)[flexpik](/maintainers/flexpik)[@flexpik](https://github.com/flexpik)

---

Top Contributors

[![serhii-f8](https://avatars.githubusercontent.com/u/22273976?v=4)](https://github.com/serhii-f8 "serhii-f8 (13 commits)")[![flexpik](https://avatars.githubusercontent.com/u/268365064?v=4)](https://github.com/flexpik "flexpik (1 commits)")

---

Tags

cruddynamic-modelsfilamentfilament-pluginfilamentphplaravellaravelcrudfilamenteavData Managerdynamic-models

###  Code Quality

TestsPest

### Embed Badge

![Health badge](/badges/flexpik-filament-studio/health.svg)

```
[![Health](https://phpackages.com/badges/flexpik-filament-studio/health.svg)](https://phpackages.com/packages/flexpik-filament-studio)
```

###  Alternatives

[awcodes/filament-quick-create

Plugin for Filament Admin that adds a dropdown menu to the header to quickly create new items.

250203.6k11](/packages/awcodes-filament-quick-create)[rawilk/profile-filament-plugin

Profile &amp; MFA starter kit for filament.

3913.7k](/packages/rawilk-profile-filament-plugin)[mradder/filament-logger

Audit logging, activity tracking, exports, alerts, and dashboards for Filament admin panels.

2310.5k](/packages/mradder-filament-logger)[stephenjude/filament-jetstream

A Laravel starter kit built with Filament inspired by Jetstream.

17758.9k2](/packages/stephenjude-filament-jetstream)[stephenjude/filament-two-factor-authentication

Filament Two Factor Authentication: Google 2FA + Passkey Authentication

84192.9k8](/packages/stephenjude-filament-two-factor-authentication)[guava/filament-knowledge-base

A filament plugin that adds a knowledge base and help to your filament panel(s).

210140.2k1](/packages/guava-filament-knowledge-base)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
