Completed
Push — master ( 51be17...87e6f6 )
by Jan
03:52
created

BaseEntityAdminForm::buildForm()   B

Complexity

Conditions 9
Paths 1

Size

Total Lines 31
Code Lines 21

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 9
eloc 21
nc 1
nop 2
dl 0
loc 31
rs 8.0555
c 0
b 0
f 0
1
<?php
2
/**
3
 *
4
 * part-db version 0.1
5
 * Copyright (C) 2005 Christoph Lechner
6
 * http://www.cl-projects.de/
7
 *
8
 * part-db version 0.2+
9
 * Copyright (C) 2009 K. Jacobs and others (see authors.php)
10
 * http://code.google.com/p/part-db/
11
 *
12
 * Part-DB Version 0.4+
13
 * Copyright (C) 2016 - 2019 Jan Böhmer
14
 * https://github.com/jbtronics
15
 *
16
 * This program is free software; you can redistribute it and/or
17
 * modify it under the terms of the GNU General Public License
18
 * as published by the Free Software Foundation; either version 2
19
 * of the License, or (at your option) any later version.
20
 *
21
 * This program is distributed in the hope that it will be useful,
22
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24
 * GNU General Public License for more details.
25
 *
26
 * You should have received a copy of the GNU General Public License
27
 * along with this program; if not, write to the Free Software
28
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
29
 *
30
 */
31
32
namespace App\Form\AdminPages;
33
34
35
use App\Entity\Base\NamedDBElement;
36
use App\Entity\Base\StructuralDBElement;
37
use FOS\CKEditorBundle\Form\Type\CKEditorType;
38
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
39
use Symfony\Component\Form\AbstractType;
40
use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
41
use Symfony\Component\Form\Extension\Core\Type\ResetType;
42
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
43
use Symfony\Component\Form\Extension\Core\Type\TextType;
44
use Symfony\Component\Form\FormBuilderInterface;
45
use Symfony\Component\Security\Core\Security;
46
47
class BaseEntityAdminForm extends AbstractType
48
{
49
50
    protected $security;
51
52
    public function __construct(Security $security)
53
    {
54
        $this->security = $security;
55
    }
56
57
58
    public function buildForm(FormBuilderInterface $builder, array $options)
59
    {
60
        /** @var StructuralDBElement $entity */
61
        $entity = $options['data'];
62
        $is_new = $entity->getID() === null;
63
64
        $builder
65
            ->add('name', TextType::class, ['empty_data' => '', 'label' => 'name.label',
66
                'attr' => ['placeholder' => 'part.name.placeholder'],
67
                'disabled' => !$this->security->isGranted($is_new ? 'create' : 'edit', $entity), ])
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
68
69
            ->add('parent', EntityType::class, ['class' => get_class($entity), 'choice_label' => 'full_path',
70
                'attr' => ['class' => 'selectpicker', 'data-live-search' => true], 'required' => false, 'label' => 'parent.label',
71
                'disabled' => !$this->security->isGranted($is_new ? 'create' : 'move', $entity), ])
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
72
73
            ->add('not_selectable', CheckboxType::class, ['required' => false,
74
                'label' => 'not_selectable.label', 'help' => 'not_selectable.help', 'label_attr'=> ['class' => 'checkbox-custom'],
75
                'disabled' => !$this->security->isGranted($is_new ? 'create' : 'edit', $entity) ])
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
76
77
            ->add('comment', CKEditorType::class, ['required' => false,
78
                'label' => 'comment.label', 'attr' => ['rows' => 4], 'help' => 'bbcode.hint',
79
                'disabled' => !$this->security->isGranted($is_new ? 'create' : 'edit', $entity)]);
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
80
81
            $this->additionalFormElements($builder, $options, $entity);
82
83
            //Buttons
84
            $builder->add('save', SubmitType::class, ['label' =>  $is_new ? 'entity.create' : 'entity.edit.save',
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
85
                'attr' => ['class' => $is_new ? 'btn-success' : ''],
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
86
                'disabled' => !$this->security->isGranted($is_new ? 'create' : 'edit', $entity)])
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
87
            ->add('reset', ResetType::class, ['label' => 'entity.edit.reset',
88
                'disabled' => !$this->security->isGranted($is_new ? 'create' : 'edit', $entity)]);
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
89
    }
90
91
    protected function additionalFormElements(FormBuilderInterface $builder, array $options, NamedDBElement $entity)
0 ignored issues
show
Unused Code introduced by
The parameter $entity 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

91
    protected function additionalFormElements(FormBuilderInterface $builder, array $options, /** @scrutinizer ignore-unused */ NamedDBElement $entity)

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...
92
    {
93
        //Empty for Base
94
    }
95
}