Compare commits
10 Commits
Author | SHA1 | Date |
---|---|---|
|
d2b733bd0e | |
|
4dcdf2b1cf | |
|
e868cfeaf4 | |
|
28d5856908 | |
|
30baf4a2a7 | |
|
0dba6fb137 | |
|
94ad49396a | |
|
5672e3dbf7 | |
|
f604754a98 | |
|
31ae4a394c |
|
@ -2,6 +2,7 @@
|
|||
/composer.phar
|
||||
/phpunit.xml
|
||||
/.phpunit.result.cache
|
||||
/.phpunit.cache
|
||||
/phpunit.phar
|
||||
/config/Migrations/schema-dump-default.lock
|
||||
/vendor/
|
||||
|
|
|
@ -0,0 +1,70 @@
|
|||
<?php
|
||||
|
||||
namespace CheeseCake\Controller\Traits;
|
||||
|
||||
use Cake\Core\Configure;
|
||||
use Cake\ORM\Table;
|
||||
use Cake\ORM\TableRegistry;
|
||||
|
||||
trait OverrideTableTrait
|
||||
{
|
||||
/**
|
||||
* @var Table|null
|
||||
*/
|
||||
protected ?Table $_table = null;
|
||||
|
||||
/**
|
||||
* This object's default table alias.
|
||||
*
|
||||
* @var string|null
|
||||
*/
|
||||
protected ?string $defaultTable = null;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
protected string $_tableConfigKey = '';
|
||||
|
||||
/**
|
||||
* Gets the table instance
|
||||
*
|
||||
* @return Table
|
||||
*/
|
||||
public function getTable(string $tableName = null)
|
||||
{
|
||||
if ($this->_table instanceof Table) {
|
||||
return $this->_table;
|
||||
}
|
||||
$this->getTableConfigKey();
|
||||
$table = $tableName;
|
||||
if (!isset($table)) {
|
||||
$table = $this->defaultTable;
|
||||
if (Configure::read($this->_tableConfigKey)) {
|
||||
$table = Configure::read($this->_tableConfigKey);
|
||||
}
|
||||
}
|
||||
$this->_table = TableRegistry::getTableLocator()->get($table);
|
||||
|
||||
return $this->_table;
|
||||
}
|
||||
|
||||
protected function getTableConfigKey()
|
||||
{
|
||||
if (!$this->_tableConfigKey) {
|
||||
$this->_tableConfigKey = $this->getPlugin() . '.' . $this->defaultTable . '.table';
|
||||
}
|
||||
|
||||
return $this->_tableConfigKey;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the users table
|
||||
*
|
||||
* @param Table $table table
|
||||
* @return void
|
||||
*/
|
||||
public function setTable(Table $table)
|
||||
{
|
||||
$this->_table = $table;
|
||||
}
|
||||
}
|
|
@ -47,30 +47,35 @@ class ActiveLinkHelper extends Helper
|
|||
$target = $options['target'];
|
||||
unset($options['target']);
|
||||
if (is_string($target)) {
|
||||
if (Router::normalize($currentUrl) == Router::normalize($target)) {
|
||||
$options['class'] = $this->_addClass($options);
|
||||
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
return $this->_linkFromStringTarget($currentUrl, $target, $title, $url, $options);
|
||||
}
|
||||
if (is_array($target)) {
|
||||
if (!array_key_exists('plugin', $currentUrl)) {
|
||||
$currentUrl['plugin'] = false;
|
||||
}
|
||||
if (!array_key_exists('prefix', $currentUrl)) {
|
||||
$currentUrl['prefix'] = false;
|
||||
}
|
||||
foreach ($target as $targetKey => $targetValue) {
|
||||
if (is_array($targetValue)) {
|
||||
return 'test';
|
||||
}
|
||||
if (!array_key_exists($targetKey, $currentUrl) || $targetValue != $currentUrl[$targetKey]) {
|
||||
if (!is_array($target)) {
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
|
||||
if (!array_key_exists('plugin', $currentUrl)) {
|
||||
$currentUrl['plugin'] = false;
|
||||
}
|
||||
if (!array_key_exists('prefix', $currentUrl)) {
|
||||
$currentUrl['prefix'] = false;
|
||||
}
|
||||
if (isset($target['or']) && $target['or']) {
|
||||
foreach ($target['or'] as $singleTargetToMatch) {
|
||||
if ($this->_matchesUrlFromArrayTarget($currentUrl, $singleTargetToMatch)) {
|
||||
$options['class'] = $this->_addClass($options);
|
||||
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
}
|
||||
$options['class'] = $this->_addClass($options);
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
|
||||
if (!$this->_matchesUrlFromArrayTarget($currentUrl, $target)) {
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
|
||||
$options['class'] = $this->_addClass($options);
|
||||
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
|
||||
|
@ -85,4 +90,33 @@ class ActiveLinkHelper extends Helper
|
|||
|
||||
return array_key_exists('class', $providedOptions) ? $providedOptions['class'] . ' ' . $activeClass : $activeClass;
|
||||
}
|
||||
|
||||
protected function _linkFromStringTarget(array $current, string $targetString, string $title, array|string|null $url, array $options)
|
||||
{
|
||||
if (Router::normalize($current) == Router::normalize($targetString)) {
|
||||
$options['class'] = $this->_addClass($options);
|
||||
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
|
||||
return $this->Html->link($title, $url, $options);
|
||||
}
|
||||
|
||||
protected function _matchesUrlFromArrayTarget(array $current, array $targetUrl)
|
||||
{
|
||||
foreach ($targetUrl as $targetKey => $targetValue) {
|
||||
if (is_array($targetValue)) {
|
||||
if (!in_array($current[$targetKey], $targetValue)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
continue;
|
||||
}
|
||||
if (!array_key_exists($targetKey, $current) || $targetValue != $current[$targetKey]) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -24,7 +24,7 @@
|
|||
<?= $this->Html->link(__('New {{ singularHumanName }}'), ['action' => 'add'], ['class' => 'button float-right']) ?>
|
||||
{% set done = [] %}
|
||||
<h3><?= __('{{ pluralHumanName }}') ?></h3>
|
||||
<div class="table-responsive">
|
||||
<div class="table-responsive" id="table-container">
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
|
|
|
@ -0,0 +1,34 @@
|
|||
<?php declare(strict_types=1);
|
||||
|
||||
namespace TestApp;
|
||||
|
||||
use Cake\Http\BaseApplication;
|
||||
use Cake\Http\MiddlewareQueue;
|
||||
use Cake\Routing\Middleware\RoutingMiddleware;
|
||||
use Cake\Routing\Route\DashedRoute;
|
||||
use Cake\Routing\RouteBuilder;
|
||||
|
||||
class Application extends BaseApplication {
|
||||
|
||||
/**
|
||||
* @param \Cake\Routing\RouteBuilder $routes
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function routes(RouteBuilder $routes): void {
|
||||
$routes->scope('/', function(RouteBuilder $routes) {
|
||||
$routes->fallbacks(DashedRoute::class);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @param \Cake\Http\MiddlewareQueue $middlewareQueue The middleware queue to set in your App Class
|
||||
* @return \Cake\Http\MiddlewareQueue
|
||||
*/
|
||||
public function middleware(MiddlewareQueue $middlewareQueue): MiddlewareQueue {
|
||||
$middlewareQueue->add(new RoutingMiddleware($this));
|
||||
|
||||
return $middlewareQueue;
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue