bytic /
form
| 1 | <?php |
||||||
| 2 | |||||||
| 3 | namespace Nip\Form\Traits; |
||||||
| 4 | |||||||
| 5 | /** |
||||||
| 6 | * Trait HasClassTrait |
||||||
| 7 | * @package Nip\Form\Traits |
||||||
| 8 | */ |
||||||
| 9 | trait HasClassTrait |
||||||
| 10 | { |
||||||
| 11 | /** |
||||||
| 12 | * @return $this |
||||||
| 13 | */ |
||||||
| 14 | 7 | public function addClass() |
|||||
| 15 | { |
||||||
| 16 | 7 | $classes = func_get_args(); |
|||||
| 17 | 7 | $classes = array_map('trim', $classes); |
|||||
| 18 | 7 | if (is_array($classes)) { |
|||||
|
0 ignored issues
–
show
introduced
by
Loading history...
|
|||||||
| 19 | 7 | $classes = implode(' ', $classes) . ' ' . $this->getAttrib('class'); |
|||||
|
0 ignored issues
–
show
It seems like
getAttrib() must be provided by classes using this trait. How about adding it as abstract method to this trait?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
Loading history...
|
|||||||
| 20 | 7 | $newClasses = explode(' ', $classes); |
|||||
| 21 | 7 | $newClasses = array_filter($newClasses); |
|||||
| 22 | 7 | $newClasses = array_unique($newClasses); |
|||||
| 23 | 7 | $this->setAttrib('class', trim(implode(' ', $newClasses))); |
|||||
|
0 ignored issues
–
show
It seems like
setAttrib() must be provided by classes using this trait. How about adding it as abstract method to this trait?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
Loading history...
|
|||||||
| 24 | } |
||||||
| 25 | |||||||
| 26 | 7 | return $this; |
|||||
| 27 | } |
||||||
| 28 | |||||||
| 29 | /** |
||||||
| 30 | * @return $this |
||||||
| 31 | */ |
||||||
| 32 | 1 | public function removeClass() |
|||||
| 33 | { |
||||||
| 34 | 1 | $removeClasses = func_get_args(); |
|||||
| 35 | 1 | $removeClasses = array_map('trim', $removeClasses); |
|||||
| 36 | 1 | if (is_array($removeClasses)) { |
|||||
|
0 ignored issues
–
show
|
|||||||
| 37 | 1 | $classes = explode(' ', $this->getAttrib('class')); |
|||||
| 38 | 1 | foreach ($removeClasses as $class) { |
|||||
| 39 | 1 | $key = array_search($class, $classes); |
|||||
| 40 | 1 | if ($key !== false) { |
|||||
| 41 | 1 | unset($classes[$key]); |
|||||
| 42 | } |
||||||
| 43 | } |
||||||
| 44 | 1 | $this->setAttrib('class', implode(' ', $classes)); |
|||||
| 45 | } |
||||||
| 46 | |||||||
| 47 | 1 | return $this; |
|||||
| 48 | } |
||||||
| 49 | |||||||
| 50 | /** |
||||||
| 51 | * @param string $class |
||||||
| 52 | * @return bool |
||||||
| 53 | */ |
||||||
| 54 | 1 | public function hasClass($class) |
|||||
| 55 | { |
||||||
| 56 | 1 | return in_array($class, explode(' ', $this->getAttrib('class'))); |
|||||
| 57 | } |
||||||
| 58 | } |
||||||
| 59 |