Passed
Push — master ( 00a718...8afe66 )
by Bruno
06:41
created

Renderable_pagination::fix()   C

Complexity

Conditions 11
Paths 192

Size

Total Lines 35
Code Lines 23

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 11
eloc 23
c 1
b 0
f 1
nc 192
nop 3
dl 0
loc 35
rs 6.55

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php declare(strict_types=1);
2
3
namespace Formularium\Frontend\Bootstrap\Renderable;
4
5
use Formularium\Field;
6
use Formularium\Renderable;
7
use Formularium\HTMLElement;
8
9
class Renderable_pagination extends Renderable_constant
10
{
11
    public function viewable($value, Field $field, HTMLElement $previous): HTMLElement
12
    {
13
        return $this->fix($value, $field, $previous);
14
    }
15
    
16
    public function editable($value, Field $field, HTMLElement $previous): HTMLElement
17
    {
18
        return $this->fix($value, $field, $previous);
19
    }
20
21
    /**
22
     * @param mixed $value
23
     * @param Field $field
24
     * @param HTMLElement $previous
25
     * @return HTMLElement
26
     */
27
    protected function fix($value, Field $field, HTMLElement $previous): HTMLElement
0 ignored issues
show
Unused Code introduced by
The parameter $value is not used and could be removed. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-unused  annotation

27
    protected function fix(/** @scrutinizer ignore-unused */ $value, Field $field, HTMLElement $previous): HTMLElement

This check looks for parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
28
    {
29
        foreach ($previous->get('.formularium-disabled') as $e) {
30
            $e->addAttribute('class', 'disabled');
31
        }
32
        foreach ($previous->get('.formularium-pagination-item') as $e) {
33
            $e->addAttribute('class', 'page-item');
34
        }
35
        foreach ($previous->get('.formularium-pagination-ellipsis') as $e) {
36
            $e->addAttribute('class', 'disabled');
37
        }
38
        foreach ($previous->get('.formularium-pagination-link') as $e) {
39
            $e->addAttribute('class', 'page-link');
40
        }
41
        foreach ($previous->get('.formularium-pagination-current') as $e) {
42
            $e->addAttribute('class', 'disabled');
43
        }
44
        foreach ($previous->get('.formularium-pagination') as $e) {
45
            $e->addAttribute('class', 'pagination');
46
        }
47
48
        $size = $field->getExtension(Renderable::SIZE, '');
49
        switch ($size) {
50
            case Renderable::SIZE_LARGE:
51
                foreach ($previous->get('.formularium-pagination') as $e) {
52
                    $e->addAttribute('class', 'pagination-lg');
53
                }
54
                break;
55
            case Renderable::SIZE_SMALL:
56
                foreach ($previous->get('.formularium-pagination') as $e) {
57
                    $e->addAttribute('class', 'pagination-sm');
58
                }
59
                break;
60
        }
61
        return $previous;
62
    }
63
}
64