Skip to content

Commit

Permalink
Multiplier::validate(): Filter out non-validatable components
Browse files Browse the repository at this point in the history
45ed76a started filtering components
to `Control`s, to appease PHPStan, since `Container::validate()` only
accepts `Control[]`. But `Multiplier` does not actually have `Control`s
as direct children (other than the ‘Add’ `Submitter`s), so it would stop
validating and filtering multiplied controls.

a5a7348 reverted that part but kept
the incorrect phpdoc type cast.

Now, it works without the filter because `Container::validate()` already
ignores non-validatable components but we should still respect its contract.

Let’s filter the components before passing them down. This will also
allow us to drop the lying phpdoc type cast.
  • Loading branch information
jtojnar committed Mar 21, 2024
1 parent 2afcd08 commit 45fc736
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions src/Multiplier.php
Original file line number Diff line number Diff line change
Expand Up @@ -169,8 +169,8 @@ public function addCreateButton(?string $caption = null, int $copyCount = 1): Cr
*/
public function validate(?array $controls = null): void
{
/** @var Control[] $components */
$components = $controls ?? $this->getComponents();
/** @var (Control|Container)[] $components */
$components = $controls ?? array_filter($this->getComponents(), fn ($component) => $component instanceof Control || $component instanceof Container);

Check failure on line 173 in src/Multiplier.php

View workflow job for this annotation

GitHub Actions / Phpstan / Phpstan (8.1)

Parameter #1 $array of function array_filter expects array, Iterator<int|string, Nette\ComponentModel\IComponent> given.

Check failure on line 173 in src/Multiplier.php

View workflow job for this annotation

GitHub Actions / Phpstan / Phpstan (8.1)

Parameter #1 $array of function array_filter expects array, Iterator<int|string, Nette\ComponentModel\IComponent> given.

foreach ($components as $index => $control) {
foreach ($this->noValidate as $item) {
Expand Down

0 comments on commit 45fc736

Please sign in to comment.