Completed
Push — master ( 0826f5...8a4d66 )
by Jan
03:23
created

UserAdminForm::buildForm()   A

Complexity

Conditions 3
Paths 1

Size

Total Lines 43
Code Lines 25

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 3
eloc 25
nc 1
nop 2
dl 0
loc 43
rs 9.52
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;
33
34
35
use App\Entity\Group;
36
use App\Entity\NamedDBElement;
37
use App\Entity\StructuralDBElement;
38
use FOS\CKEditorBundle\Form\Type\CKEditorType;
39
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
40
use Symfony\Component\Form\AbstractType;
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 UserAdminForm 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' => 'user.username.label',
66
                'attr' => ['placeholder' => 'user.username.placeholder'],
67
                'disabled' => !$this->security->isGranted('edit_username', $entity), ])
68
69
            ->add('group', EntityType::class, ['class' => Group::class, 'choice_label' => 'name',
70
                'attr' => ['class' => 'selectpicker', 'data-live-search' => true], 'required' => false, 'label' => 'group.label',
71
                'disabled' => !$this->security->isGranted('change_group', $entity), ])
72
73
            ->add('first_name', TextType::class, ['empty_data' => '', 'label' => 'user.firstName.label',
74
                'attr' => ['placeholder' => 'user.firstName.placeholder'], 'required' => false,
75
                'disabled' => !$this->security->isGranted('edit_infos', $entity), ])
76
77
            ->add('last_name', TextType::class, ['empty_data' => '', 'label' => 'user.lastName.label',
78
                'attr' => ['placeholder' => 'user.lastName.placeholder'], 'required' => false,
79
                'disabled' => !$this->security->isGranted('edit_infos', $entity), ])
80
81
            ->add('email', TextType::class, ['empty_data' => '', 'label' => 'user.email.label',
82
                'attr' => ['placeholder' => 'user.email.placeholder'], 'required' => false,
83
                'disabled' => !$this->security->isGranted('edit_infos', $entity), ])
84
85
86
            ->add('department', TextType::class, ['empty_data' => '', 'label' => 'user.department.label',
87
                'attr' => ['placeholder' => 'user.department.placeholder'], 'required' => false,
88
                'disabled' => !$this->security->isGranted('edit_infos', $entity), ])
89
90
        ;
91
        /*->add('comment', CKEditorType::class, ['required' => false,
92
            'label' => 'comment.label', 'attr' => ['rows' => 4], 'help' => 'bbcode.hint',
93
            'disabled' => !$this->security->isGranted($is_new ? 'create' : 'edit', $entity)]); */
94
95
        $this->additionalFormElements($builder, $options, $entity);
96
97
        //Buttons
98
        $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...
99
            'attr' => ['class' => $is_new ? 'btn-success' : '']])
0 ignored issues
show
introduced by
The condition $is_new is always false.
Loading history...
100
            ->add('reset', ResetType::class, ['label' => 'entity.edit.reset']);
101
    }
102
103
    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

103
    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...
Unused Code introduced by
The parameter $builder 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

103
    protected function additionalFormElements(/** @scrutinizer ignore-unused */ FormBuilderInterface $builder, array $options, 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...
Unused Code introduced by
The parameter $options 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

103
    protected function additionalFormElements(FormBuilderInterface $builder, /** @scrutinizer ignore-unused */ array $options, 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...
104
    {
105
        //Empty for Base
106
    }
107
}