You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
1.8 KiB
61 lines
1.8 KiB
<?php |
|
|
|
/** |
|
* This file is part of CodeIgniter 4 framework. |
|
* |
|
* (c) CodeIgniter Foundation <admin@codeigniter.com> |
|
* |
|
* For the full copyright and license information, please view |
|
* the LICENSE file that was distributed with this source code. |
|
*/ |
|
|
|
namespace CodeIgniter\Traits; |
|
|
|
trait ConditionalTrait |
|
{ |
|
/** |
|
* Only runs the query when $condition evaluates to true |
|
* |
|
* @template TWhen of mixed |
|
* |
|
* @phpstan-param TWhen $condition |
|
* @phpstan-param callable(self, TWhen): mixed $callback |
|
* @phpstan-param (callable(self): mixed)|null $defaultCallback |
|
* @param array|bool|float|int|object|resource|string|null $condition |
|
* |
|
* @return $this |
|
*/ |
|
public function when($condition, callable $callback, ?callable $defaultCallback = null): self |
|
{ |
|
if ($condition) { |
|
$callback($this, $condition); |
|
} elseif ($defaultCallback) { |
|
$defaultCallback($this); |
|
} |
|
|
|
return $this; |
|
} |
|
|
|
/** |
|
* Only runs the query when $condition evaluates to false |
|
* |
|
* @template TWhenNot of mixed |
|
* |
|
* @phpstan-param TWhenNot $condition |
|
* @phpstan-param callable(self, TWhenNot): mixed $callback |
|
* @phpstan-param (callable(self): mixed)|null $defaultCallback |
|
* @param array|bool|float|int|object|resource|string|null $condition |
|
* |
|
* @return $this |
|
*/ |
|
public function whenNot($condition, callable $callback, ?callable $defaultCallback = null): self |
|
{ |
|
if (! $condition) { |
|
$callback($this, $condition); |
|
} elseif ($defaultCallback) { |
|
$defaultCallback($this); |
|
} |
|
|
|
return $this; |
|
} |
|
}
|
|
|