PHPackages                             pratikkuikel/panini - 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. pratikkuikel/panini

ActiveLibrary[Admin Panels](/categories/admin)

pratikkuikel/panini
===================

Panini cms based on filamentphp and wasabi json

6111[4 PRs](https://github.com/pratikkuikel/panini/pulls)PHPCI passing

Since Oct 13Pushed 1mo ago1 watchersCompare

[ Source](https://github.com/pratikkuikel/panini)[ Packagist](https://packagist.org/packages/pratikkuikel/panini)[ RSS](/packages/pratikkuikel-panini/feed)WikiDiscussions main Synced 1mo ago

READMEChangelogDependenciesVersions (5)Used By (0)

Panini for FilamentPHP: Craft Your Own CMS idk If It can be called a CMS.
=========================================================================

[](#panini-for-filamentphp-craft-your-own-cms-idk-if-it-can-be-called-a-cms)

[![Latest Version on Packagist](https://camo.githubusercontent.com/6789b9e2f415aa8a767fc3141cfc6777004bb2a40749c31327d36a90192c2292/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f70726174696b6b75696b656c2f70616e696e692e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/pratikkuikel/panini)[![GitHub Tests Action Status](https://camo.githubusercontent.com/29b9996babbaede7ae53c98405433ab0a3686b430bb0c74f0c8241b7a3fa0bbf/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f616374696f6e732f776f726b666c6f772f7374617475732f70726174696b6b75696b656c2f70616e696e692f72756e2d74657374732e796d6c3f6272616e63683d6d61696e266c6162656c3d7465737473267374796c653d666c61742d737175617265)](https://github.com/pratikkuikel/panini/actions?query=workflow%3Arun-tests+branch%3Amain)[![GitHub Code Style Action Status](https://camo.githubusercontent.com/51014a0e02e6b0c60e210a1ff0c0ee098e87d4991df79e49f8d62911e1a86b03/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f616374696f6e732f776f726b666c6f772f7374617475732f70726174696b6b75696b656c2f70616e696e692f6669782d7068702d636f64652d7374796c652d6973737565732e796d6c3f6272616e63683d6d61696e266c6162656c3d636f64652532307374796c65267374796c653d666c61742d737175617265)](https://github.com/pratikkuikel/panini/actions?query=workflow%3A%22Fix+PHP+code+style+issues%22+branch%3Amain)[![Total Downloads](https://camo.githubusercontent.com/299ba00ca926a4a61936200cc4380c6f3f2e2517994ca48acff2e878ba72b641/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f70726174696b6b75696b656c2f70616e696e692e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/pratikkuikel/panini)

[![panini.png](https://camo.githubusercontent.com/d9a358dbc0e607092b2b2dc0f52b0d35dcc5ced1c5fecb6c8716e002be9a4421/68747470733a2f2f692e706f7374696d672e63632f4e4c7837714c47772f70616e696e692e706e67)](https://camo.githubusercontent.com/d9a358dbc0e607092b2b2dc0f52b0d35dcc5ced1c5fecb6c8716e002be9a4421/68747470733a2f2f692e706f7374696d672e63632f4e4c7837714c47772f70616e696e692e706e67)

 Not an AI generated Logo which has been upscaled and compressed again using AI.

Panini is a FilamentPHP package designed for developers who crave the freedom to build their own CMS without the constraints of pre-defined structures. It's not a CMS; it's a toolkit that generates Filament resources—Controllers, Factories, Migrations, Seeders, and Models. The star of the show is the Page Manager, allowing you to dynamically generate pages with customizable form fields. Embrace frontend independence and create your unique content management experience, all crafted by you for your project's specific needs. Because sometimes, the best CMS is the one you build yourself.

[![wtf](https://camo.githubusercontent.com/7c26ff53b8145c9bc84c70f4ba42a7d6272b2062dd9b5b7799396c07b95754be/68747470733a2f2f6d656469612e67697068792e636f6d2f6d656469612f726855734f6f59625275537731596d4e55492f67697068792e676966)](https://camo.githubusercontent.com/7c26ff53b8145c9bc84c70f4ba42a7d6272b2062dd9b5b7799396c07b95754be/68747470733a2f2f6d656469612e67697068792e636f6d2f6d656469612f726855734f6f59625275537731596d4e55492f67697068792e676966)

> I honestly don't know what I have built but It does solve my problem and I will be damned if it solves yours too ! 😈

#### why is this called panini ?

[](#why-is-this-called-panini-)

Maybe because it's a sandwich and you can build it any way you like.

Enough with this monologue ! Let's get it up and running
--------------------------------------------------------

[](#enough-with-this-monologue--lets-get-it-up-and-running)

### Before you begin, Make sure you have Filamentphp installed with default AdminPanelProvider.

[](#before-you-begin-make-sure-you-have-filamentphp-installed-with-default-adminpanelprovider)

👉 [Filamentphp Installation](https://filamentphp.com/docs/3.x/panels/installation)

This package assumes that AdminPanelProvider is the default one.

Now you can install the package via composer:

Make sure you have minimum stability set as dev in composer.json

```
    "minimum-stability": "dev"
```

```
composer require pratikkuikel/panini
```

Publish and run the migrations with:

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

Add Panini Plugin to AdminPanelProvider.

```
use Pratikkuikel\Panini\PaniniPlugin;

        return $panel
            ...
            ->plugin(new PaniniPlugin())
            ...
```

To enable page auto-discovery change :

```
            ->discoverPages(in: app_path('Filament/Pages'), for: 'App\\Filament\\Pages')
```

TO

```
            ->discoverPages(in: app_path('Filament/Admin/Pages'), for: 'App\\Filament\\Admin\\Pages')
```

Login to your Admin Panel.

There you have it, your raw panini.

Bake it, chef 👨‍🍳

Usage
-----

[](#usage)

⭐Generate Resources with Resource Generator

[![resource_generator.png](https://camo.githubusercontent.com/0207303ff9b6edce68312c45a35b4af96df57d847e35b637e9a8e3c2a31d3ab9/68747470733a2f2f692e706f7374696d672e63632f58717748574a6d372f7265736f757263652d67656e657261746f722e706e67)](https://camo.githubusercontent.com/0207303ff9b6edce68312c45a35b4af96df57d847e35b637e9a8e3c2a31d3ab9/68747470733a2f2f692e706f7374696d672e63632f58717748574a6d372f7265736f757263652d67656e657261746f722e706e67)

⭐Page Manager

[![page_manager.png](https://camo.githubusercontent.com/523ddfb897ea4c577d1abc31430ebacca924493c039cffc03d04c6b8c1a1f98f/68747470733a2f2f692e706f7374696d672e63632f4c585a766b5474622f706167652d6d616e616765722e706e67)](https://camo.githubusercontent.com/523ddfb897ea4c577d1abc31430ebacca924493c039cffc03d04c6b8c1a1f98f/68747470733a2f2f692e706f7374696d672e63632f4c585a766b5474622f706167652d6d616e616765722e706e67)

Using Page Manager
------------------

[](#using-page-manager)

Page Manager currently supports two Fields right now, Select and TextInput. Feel Free to add More.

Attributes are the methods you chain to the Selected InputField. Multiple attributes is supported.

Multiple fields can be added to the page, All it needs is a click to `Add field to the page` button.

After you have created the page manager, click on `Generate` button to generate the page.

You can customize the generated page, Find the page in `app\Filament\Admin\Pages` directory and the view file in `resources\views\filament\admin\pages` directory.

The generated fields can be downloaded, reused or shared.
Here is the sample Json Field

```
[
    {
        "type": "Pratikkuikel\\Panini\\Filament\\Fields\\PaniniTextInput",
        "name": "name",
        "label": "name",
        "attributes": { "required": "true" }
    },
    {
        "type": "Pratikkuikel\\Panini\\Filament\\Fields\\PaniniSelect",
        "name": "option",
        "label": "Option",
        "attributes": { "required": "true" }
    }
]
```

Fetching the page data
----------------------

[](#fetching-the-page-data)

You can fetch the data using

```
$data = PageManager::where('name','leslie-winkle')->first();
```

Here, [wasabi](https://github.com/pratikkuikel/wasabi) converts your page's data fields into attributes. And those can be accessed using ✅

```
$data->name
```

Instead of ❌

```
$data->data['name'];
```

If there's a need to query page's data use [Json Where Clauses](https://laravel.com/docs/10.x/queries#json-where-clauses)

```
$data = PageManager::where('data->name','robot')->get();
```

Testing
-------

[](#testing)

I beg my pardon, TDD Army ! There are no tests, at least not at the moment. Will get it done, will I ?

Changelog
---------

[](#changelog)

Please see [CHANGELOG](CHANGELOG.md) for more information on what has changed recently.

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

[](#contributing)

Please see [CONTRIBUTING](.github/CONTRIBUTING.md) for details.

Security Vulnerabilities
------------------------

[](#security-vulnerabilities)

Please review [our security policy](../../security/policy) on how to report security vulnerabilities.

Credits
-------

[](#credits)

- [Laravel](https://laravel.com)
- [FilamentPhp](https://filamentphp.com)
- [Spatie](https://spatie.be)
- [Touhidurabir](https://github.com/touhidurabir/laravel-stub-generator)
- [pratikkuikel](https://github.com/pratikkuikel)
- [All Contributors](../../contributors)

License
-------

[](#license)

The MIT License (MIT). Please see [License File](LICENSE.md) for more information.

###  Health Score

26

—

LowBetter than 43% of packages

Maintenance61

Regular maintenance activity

Popularity11

Limited adoption so far

Community11

Small or concentrated contributor base

Maturity18

Early-stage or recently created project

 Bus Factor1

Top contributor holds 64.1% 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.

### Community

Maintainers

![](https://www.gravatar.com/avatar/d02f96f9bd6794f06e2d07fb9cbbbd763de80a81a85995a88129903396d4fb86?d=identicon)[pratikkuikel](/maintainers/pratikkuikel)

---

Top Contributors

[![pratikkuikel](https://avatars.githubusercontent.com/u/35728183?v=4)](https://github.com/pratikkuikel "pratikkuikel (25 commits)")[![dependabot[bot]](https://avatars.githubusercontent.com/in/29110?v=4)](https://github.com/dependabot[bot] "dependabot[bot] (8 commits)")[![github-actions[bot]](https://avatars.githubusercontent.com/in/15368?v=4)](https://github.com/github-actions[bot] "github-actions[bot] (6 commits)")

---

Tags

filamentphplaravelpaniniwasabi

### Embed Badge

![Health badge](/badges/pratikkuikel-panini/health.svg)

```
[![Health](https://phpackages.com/badges/pratikkuikel-panini/health.svg)](https://phpackages.com/packages/pratikkuikel-panini)
```

###  Alternatives

[jeroennoten/laravel-adminlte

Easy AdminLTE integration with Laravel

4.0k4.8M43](/packages/jeroennoten-laravel-adminlte)[dmstr/yii2-adminlte-asset

AdminLTE backend theme asset bundle for Yii 2.0 Framework

1.1k1.8M67](/packages/dmstr-yii2-adminlte-asset)[dwij/laraadmin

LaraAdmin is a Open source Laravel Admin Panel / CMS which can be used as Admin Backend, Data Management Tool or CRM boilerplate for Laravel with features like CRUD Generation, Module Manager, Media, Menus, Backups and much more

1.6k68.7k](/packages/dwij-laraadmin)[filament/spatie-laravel-media-library-plugin

Filament support for `spatie/laravel-medialibrary`.

1764.8M125](/packages/filament-spatie-laravel-media-library-plugin)[bezhansalleh/filament-exceptions

A Simple &amp; Beautiful Pluggable Exception Viewer for FilamentPHP's Admin Panel

193195.9k13](/packages/bezhansalleh-filament-exceptions)[filament/infolists

Easily add beautiful read-only infolists to any Livewire component.

1220.8M36](/packages/filament-infolists)

PHPackages © 2026

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