Commit 09c2dca20de62bef24c062a72c61c06f6a769509
1 parent
68bcc844f5
Exists in
master
permitir editar los jurados
Showing
5 changed files
with
260 additions
and
6 deletions
Show diff stats
app/Resources/views/base_app.html.twig
... | ... | @@ -98,7 +98,7 @@ |
98 | 98 | <li> |
99 | 99 | <a href="javascript:void(0);" class="waves-effect waves-button waves-classic show-search"><i class="fa fa-search"></i></a> |
100 | 100 | </li> |
101 | - <li class="dropdown"> | |
101 | + {#<li class="dropdown"> | |
102 | 102 | <a href="#" class="dropdown-toggle waves-effect waves-button waves-classic" data-toggle="dropdown"><i class="fa fa-envelope"></i><span class="badge badge-success pull-right">4</span></a> |
103 | 103 | <ul class="dropdown-menu title-caret dropdown-lg" role="menu"> |
104 | 104 | <li><p class="drop-title">You have 4 new messages !</p></li> |
... | ... | @@ -133,7 +133,7 @@ |
133 | 133 | </li> |
134 | 134 | <li class="drop-all"><a href="#" class="text-center">All Messages</a></li> |
135 | 135 | </ul> |
136 | - </li> | |
136 | + </li>#} | |
137 | 137 | {% if is_granted('ROLE_COORDINADOR_REGIONAL') %} |
138 | 138 | |
139 | 139 | <li class="dropdown"> |
... | ... | @@ -214,6 +214,14 @@ |
214 | 214 | </a> |
215 | 215 | </li> |
216 | 216 | |
217 | + <li> | |
218 | + <a href="{{path('admin_jurados_index')}}"> | |
219 | + <div class="task-icon badge badge-success"><i class="icon-users"></i></div> | |
220 | + <span class="badge badge-roundless badge-default pull-right">1min ago</span> | |
221 | + <p class="task-details">Actualizar Jurados</p> | |
222 | + </a> | |
223 | + </li> | |
224 | + | |
217 | 225 | </ul> |
218 | 226 | </li> |
219 | 227 | <li class="drop-all"><a href="#" class="text-center">All Tasks</a></li> |
... | ... | @@ -227,12 +235,12 @@ |
227 | 235 | <img class="img-circle avatar" width="40" height="40" alt=""> |
228 | 236 | </a> |
229 | 237 | <ul class="dropdown-menu dropdown-list" role="menu"> |
230 | - <li role="presentation"><a href="profile.html"><i class="fa fa-user"></i>Profile</a></li> | |
231 | - <li role="presentation"><a href="calendar.html"><i class="fa fa-calendar"></i>Calendar</a></li> | |
238 | + <li role="presentation"><a href="profile.html"><i class="fa fa-user"></i>Actualizar Datos</a></li> | |
239 | + {#<li role="presentation"><a href="calendar.html"><i class="fa fa-calendar"></i>Calendar</a></li> | |
232 | 240 | <li role="presentation"><a href="inbox.html"><i class="fa fa-envelope"></i>Inbox<span class="badge badge-success pull-right">4</span></a></li> |
233 | 241 | <li role="presentation" class="divider"></li> |
234 | - <li role="presentation"><a href="lock-screen.html"><i class="fa fa-lock"></i>Lock screen</a></li> | |
235 | - <li role="presentation"><a href={{ path('logout') }}><i class="fa fa-sign-out m-r-xs"></i>Log out</a></li> | |
242 | + <li role="presentation"><a href="lock-screen.html"><i class="fa fa-lock"></i>Lock screen</a></li>#} | |
243 | + <li role="presentation"><a href={{ path('logout') }}><i class="fa fa-sign-out m-r-xs"></i>Cerrar Sesión</a></li> | |
236 | 244 | </ul> |
237 | 245 | </li> |
238 | 246 | {#<li> | ... | ... |
app/Resources/views/usuarios/jurados_edit.html.twig
... | ... | @@ -0,0 +1,20 @@ |
1 | +{% extends 'base_app.html.twig' %} | |
2 | + | |
3 | +{% block body %} | |
4 | + <div class="container"> | |
5 | + {% form_theme edit_form 'bootstrap_3_horizontal_layout.html.twig' %} | |
6 | + <h1>Edición de Jurados</h1> | |
7 | + | |
8 | + {{ form_start(edit_form) }} | |
9 | + {{ form_widget(edit_form) }} | |
10 | + <input type="submit" value="Edit" /> | |
11 | + {{ form_end(edit_form) }} | |
12 | + | |
13 | + <ul> | |
14 | + <li> | |
15 | + <a href="{{ path('admin_jurados_index') }}">Regresar al listado</a> | |
16 | + </li> | |
17 | + | |
18 | + </ul> | |
19 | + </div> | |
20 | +{% endblock %} | ... | ... |
app/Resources/views/usuarios/jurados_index.html.twig
... | ... | @@ -0,0 +1,72 @@ |
1 | +{% extends 'base_app.html.twig' %} | |
2 | + | |
3 | +{% block body %} | |
4 | + <div class="container"> | |
5 | + <div class="widget widget-table action-table"> | |
6 | + <div class="widget-header"> | |
7 | + <div class="row"> | |
8 | + <div class="col-sm-9"><i class="fa fa-list"></i> | |
9 | + <h3>Listado de Jurados Registrados</h3></div> | |
10 | + <div class="col-sm-2"><input type="text" class="form-control" name="marca"></div> | |
11 | + </div> | |
12 | + </div> | |
13 | + <div class="widget-content context"> | |
14 | + <table class="table table-striped table-bordered table-condensed"> | |
15 | + <thead> | |
16 | + <tr> | |
17 | + <th>Id</th> | |
18 | + <th>Cédula</th> | |
19 | + <th>Nombres y Apellidos</th> | |
20 | + <th>Estado</th> | |
21 | + <th>Escalafón Actual</th> | |
22 | + <th>Correo</th> | |
23 | + <th>Acciones</th> | |
24 | + </tr> | |
25 | + </thead> | |
26 | + <tbody> | |
27 | + {% for usuario in usuarios %} | |
28 | + <tr> | |
29 | + <td>{{ usuario.id }}</td> | |
30 | + <td>{{ usuario.cedulaPasaporte }}</td> | |
31 | + <td>{{ usuario.nombres }}, {{ usuario.apellidos }}</td> | |
32 | + <td>{{ usuario.idEstado.nombre }}</td> | |
33 | + <td>{{ usuario.idEscala.nombre }}</td> | |
34 | + <td>{{ usuario.correoElectronico }}</td> | |
35 | + <td> | |
36 | + <a href="{{ path('admin_usuarios_show', { 'id': usuario.id }) }}" class="btn btn-xs btn-info"><i class="fa fa-eye" ></i></a> | |
37 | + <a href="{{ path('admin_jurados_edit', { 'id': usuario.id }) }}" class="btn btn-xs btn-primary"><i class="fa fa-edit"></i></a> | |
38 | + </td> | |
39 | + </tr> | |
40 | + {% endfor %} | |
41 | + </tbody> | |
42 | + </table> | |
43 | + | |
44 | + </div> | |
45 | +{% endblock %} | |
46 | + | |
47 | + {% block javascripts %} | |
48 | + {{ parent() }} | |
49 | + <script src="https://cdn.jsdelivr.net/mark.js/8.6.0/jquery.mark.min.js"></script> | |
50 | + | |
51 | + <script> | |
52 | + $(function() { | |
53 | + | |
54 | + var $input = $("input[name='marca']"), | |
55 | + $context = $("table tbody tr"); | |
56 | + $input.on("input", function() { | |
57 | + var term = $(this).val(); | |
58 | + $context.show().unmark(); | |
59 | + if (term) { | |
60 | + $context.mark(term, { | |
61 | + done: function() { | |
62 | + $context.not(":has(mark)").hide(); | |
63 | + } | |
64 | + }); | |
65 | + } | |
66 | + }); | |
67 | + | |
68 | + }); | |
69 | + | |
70 | + </script> | |
71 | + | |
72 | + {% endblock %} | ... | ... |
src/AppBundle/Controller/UsuariosController.php
... | ... | @@ -2,6 +2,7 @@ |
2 | 2 | |
3 | 3 | namespace AppBundle\Controller; |
4 | 4 | |
5 | +use AppBundle\Entity\TutoresAscenso; | |
5 | 6 | use Symfony\Component\HttpFoundation\Request; |
6 | 7 | use Symfony\Bundle\FrameworkBundle\Controller\Controller; |
7 | 8 | use Sensio\Bundle\FrameworkExtraBundle\Configuration\Method; |
... | ... | @@ -141,4 +142,54 @@ class UsuariosController extends Controller |
141 | 142 | ->getForm() |
142 | 143 | ; |
143 | 144 | } |
145 | + | |
146 | + | |
147 | + | |
148 | + | |
149 | + /** | |
150 | + * Lists all Usuarios entities. | |
151 | + * | |
152 | + * @Route("/jurados/", name="admin_jurados_index") | |
153 | + * @Method("GET") | |
154 | + */ | |
155 | + public function indexJuradosAction() | |
156 | + { | |
157 | + $em = $this->getDoctrine()->getManager(); | |
158 | + | |
159 | + $usuarios = $em->getRepository('AppBundle:TutoresAscenso')->findAll(); | |
160 | + | |
161 | + return $this->render('usuarios/jurados_index.html.twig', array( | |
162 | + 'usuarios' => $usuarios, | |
163 | + )); | |
164 | + } | |
165 | + | |
166 | + | |
167 | + /** | |
168 | + * Displays a form to edit an existing Usuarios entity. | |
169 | + * | |
170 | + * @Route("/jurados/{id}/edit", name="admin_jurados_edit") | |
171 | + * @Method({"GET", "POST"}) | |
172 | + */ | |
173 | + public function editJuradosAction(Request $request, TutoresAscenso $jurado) | |
174 | + { | |
175 | + //$deleteForm = $this->createDeleteForm($jurado); | |
176 | + $editForm = $this->createForm('AppBundle\Form\TutoresAscensoEditType', $jurado); | |
177 | + $editForm->handleRequest($request); | |
178 | + | |
179 | + if ($editForm->isSubmitted() && $editForm->isValid()) { | |
180 | + $em = $this->getDoctrine()->getManager(); | |
181 | + $em->persist($jurado); | |
182 | + $em->flush(); | |
183 | + | |
184 | + return $this->redirectToRoute('admin_jurados_edit', array('id' => $jurado->getId())); | |
185 | + } | |
186 | + | |
187 | + return $this->render('usuarios/jurados_edit.html.twig', array( | |
188 | + 'usuario' => $jurado, | |
189 | + 'edit_form' => $editForm->createView(), | |
190 | + //'delete_form' => $deleteForm->createView(), | |
191 | + )); | |
192 | + } | |
193 | + | |
194 | + | |
144 | 195 | } | ... | ... |
src/AppBundle/Form/TutoresAscensoEditType.php
... | ... | @@ -0,0 +1,103 @@ |
1 | +<?php | |
2 | + | |
3 | +namespace AppBundle\Form; | |
4 | + | |
5 | +use Symfony\Component\Form\AbstractType; | |
6 | +use Symfony\Component\Form\FormBuilderInterface; | |
7 | +use Symfony\Component\OptionsResolver\OptionsResolver; | |
8 | +use Symfony\Component\Form\Extension\Core\Type\EmailType; | |
9 | +use Symfony\Component\Form\Extension\Core\Type\TextType; | |
10 | +use Symfony\Bridge\Doctrine\Form\Type\EntityType; | |
11 | +use Symfony\Component\Form\Extension\Core\Type\ButtonType; | |
12 | +use Symfony\Component\Form\Extension\Core\Type\SubmitType; | |
13 | + | |
14 | + | |
15 | +class TutoresAscensoEditType extends AbstractType | |
16 | +{ | |
17 | + /** | |
18 | + * @param FormBuilderInterface $builder | |
19 | + * @param array $options | |
20 | + */ | |
21 | + public function buildForm(FormBuilderInterface $builder, array $options) | |
22 | + { | |
23 | + $builder | |
24 | + ->add('idDocumentoIdentidad', EntityType::class, array( | |
25 | + 'label' => 'Tipo Documento', | |
26 | + 'placeholder' => 'Seleccione...', | |
27 | + 'class' => 'AppBundle:DocumentoIdentidad', | |
28 | + )) | |
29 | + ->add('cedulaPasaporte', TextType::class, array( | |
30 | + 'label' => 'Cédula/Pasaporte', | |
31 | + 'attr' => array( | |
32 | + 'placeholder' => 'Cédula Pasaporte ...', | |
33 | + 'class' => 'col-lg-4 form-control', | |
34 | + ) | |
35 | + )) | |
36 | + | |
37 | + | |
38 | + ->add('nombres', TextType::class, array( | |
39 | + 'label' => 'Nombres Tutor', | |
40 | + 'attr' => array( | |
41 | + 'placeholder' => 'Nombres del Tutor...', | |
42 | + 'class' => 'col-lg-6 form-control ', | |
43 | + ) | |
44 | + )) | |
45 | + | |
46 | + ->add('apellidos', TextType::class, array( | |
47 | + 'label' => 'Apellidos Tutor', | |
48 | + 'attr' => array( | |
49 | + 'placeholder' => 'apellidos del tutor...', | |
50 | + 'class' => 'col-lg-3 form-control', | |
51 | + ) | |
52 | + )) | |
53 | + | |
54 | + ->add('institucion', TextType::class, array( | |
55 | + 'label' => 'Institución', | |
56 | + 'attr' => array( | |
57 | + 'placeholder' => 'UBV, LUZ, UNEFM,', | |
58 | + 'class' => 'col-lg-3 form-control', | |
59 | + ) | |
60 | + )) | |
61 | + | |
62 | + ->add('idEstado', EntityType::class, array( | |
63 | + 'label' => 'Estado', | |
64 | + 'placeholder' => 'Estado donde Labora...', | |
65 | + 'class' => 'AppBundle:Estado', | |
66 | + 'attr' => array( | |
67 | + 'class' => 'col-lg-3 form-control', | |
68 | + ) | |
69 | + )) | |
70 | + | |
71 | + ->add('idEscala', EntityType::class, array( | |
72 | + 'label' => 'Escalafón', | |
73 | + 'placeholder' => 'Escalafón actual...', | |
74 | + 'class' => 'AppBundle:Escalafones', | |
75 | + 'attr' => array( | |
76 | + 'class' => 'col-lg-3 form-control', | |
77 | + ) | |
78 | + )) | |
79 | + ->add('correoElectronico', EmailType::class, array( | |
80 | + 'label' => 'Correo E.', | |
81 | + 'attr' => array( | |
82 | + 'placeholder' => 'Dirección de Correo Tutor ...', | |
83 | + 'class' => 'col-lg-3 form-control', | |
84 | + ) | |
85 | + )) | |
86 | + /*->add('nombres') | |
87 | + ->add('apellidos') | |
88 | + ->add('institucion') | |
89 | + ->add('idEscala')*/ | |
90 | + //->add('ascenso') | |
91 | + ; | |
92 | + } | |
93 | + | |
94 | + /** | |
95 | + * @param OptionsResolver $resolver | |
96 | + */ | |
97 | + public function configureOptions(OptionsResolver $resolver) | |
98 | + { | |
99 | + $resolver->setDefaults(array( | |
100 | + 'data_class' => 'AppBundle\Entity\TutoresAscenso' | |
101 | + )); | |
102 | + } | |
103 | +} | ... | ... |