bakeoff / panel-nav
Views and helpers to simplify building navigation in custom panel UIs
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 1
Type:cakephp-plugin
Requires
- cakephp/cakephp: ^5.0
This package is auto-updated.
Last update: 2025-03-04 16:18:04 UTC
README
This plugin contains views and helpers that can simplify building UI in custom admin panels, control panels, consoles.
When you're building an admin panel in CakePHP 5, you would have a route prefix such as /admin
and a bunch of controllers inside APP/Controller/Admin
: say, ArticlesController
, CommentsController
, TagsController
etc. In your view templates, you would have navigation menus linking to them and their actions.
This plugin lets you automate the process by automatically picking up all present controllers and their actions within that prefix, so you don't have to manually hardcode links to them.
Usage
Linking to actions
ArticlesController
manages Article
entities and has actions such as edit($id)
, reviewComments($id)
etc.
You can extend your view templates for those actions with Bakeoff/PanelNav./entity_profile
. This will render navigation to other actions available to this entity, as well as other controllers in the current prefix.
For example, templates/Articles/edit.php
:
<?php $this->extend('Bakeoff/PanelNav./entity_profile'); echo $this->Form->create($entity).PHP_EOL; echo $this->Form->control('title').PHP_EOL; echo $this->Form->control('body').PHP_EOL; echo $this->Form->control('is_published').PHP_EOL; echo $this->Form->button('Save').PHP_EOL; echo $this->Form->end().PHP_EOL;
Note: the current entity has to be available as $entity
.
Linking to controllers
<?php $this->loadHelper('Bakeoff/PanelNav.ControllerSurroundings'); // Loop though other controllers in the same folder a.k.a. same prefix foreach ($this->ControllerSurroundings->getOtherControllers() as $name): // We get the controller name, without the 'Controller' suffix echo $name; // outputs e.g. Articles // Render a link to the controller index echo $this->Html->link($name, ['controller' => $name, 'action' => 'index']); // Here's how we can tell if we're in this controller right now if ($name === $this->getRequest()->getParam('controller')) { // ... } endforeach;