Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16971 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
15392 efrain 1
<?php
2
$acl            = $this->viewModel()->getRoot()->getVariable('acl');
3
$currentUser    = $this->currentUserHelper();
4
 
5
$roleName = $currentUser->getUserTypeId();
6
 
16822 efrain 7
 
15392 efrain 8
$routeAdd       = $this->url('settings/aptitudes/add');
9
$routeDatatable = $this->url('settings/aptitudes');
10
$routeDashboard = $this->url('dashboard');
11
 
12
$allowAdd               = $acl->isAllowed($roleName, 'settings/aptitudes/add') ? 1 : 0;
13
$allowEdit              = $acl->isAllowed($roleName, 'settings/aptitudes/edit') ? 1 : 0;
14
$allowDelete            = $acl->isAllowed($roleName, 'settings/aptitudes/delete') ? 1 : 0;
15
 
16
 
16822 efrain 17
$this->inlineScript()->appendFile($this->basePath('assets/vendors/ckeditor/ckeditor.js'));
15392 efrain 18
 
19
 
16822 efrain 20
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/nprogress/nprogress.css'));
21
$this->inlineScript()->appendFile($this->basePath('assets/vendors/nprogress/nprogress.js'));
22
 
23
 
16929 efrain 24
 
25
 
26
 
16822 efrain 27
$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net/jquery.dataTables.js'));
28
 
29
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/datatables.net-bs5/dataTables.bootstrap5.css'));
30
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/datatables.net-bs5-responsive/responsive.bootstrap5.css'));
31
 
32
$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net/jquery.dataTables.js'));
33
$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net-bs5/dataTables.bootstrap5.js'));
34
$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net-bs5-responsive/dataTables.responsive.min.js'));
35
$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net-bs5-responsive/responsive.bootstrap5.min.js'));
36
 
37
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/bootstrap4-toggle/css/bootstrap4-toggle.min.css'));
38
$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap4-toggle/js/bootstrap4-toggle.min.js'));
39
 
40
 
41
 
42
 
43
 
44
$status_active = \LeadersLinked\Model\Aptitude::STATUS_ACTIVE;
45
 
46
$this->inlineScript()->captureStart();
47
echo <<<JS
48
    jQuery( document ).ready(function( $ ) {
16929 efrain 49
 
16822 efrain 50
 
51
 
52
 
53
        var allowEdit   = $allowEdit;
54
        var allowDelete = $allowDelete;
55
 
56
        var gridTable = $('#gridTable').dataTable( {
57
            'processing': true,
58
            'serverSide': true,
59
            'searching': true,
60
            'order': [[ 0, 'asc' ]],
61
            'ordering':  true,
62
            'ordenable' : true,
63
            'responsive': true,
64
            'select' : false,
65
        	'paging': true,
66
            'pagingType': 'simple_numbers',
67
    		'ajax': {
68
    			'url' : '$routeDatatable',
69
    			'type' : 'get',
70
                'beforeSend': function (request) {
71
                  NProgress.start();
72
                },
73
                'dataFilter': function(response) {
74
                    var response = jQuery.parseJSON( response );
75
 
76
                    var json                = {};
77
                    json.recordsTotal       = 0;
78
                    json.recordsFiltered    = 0;
79
                    json.data               = [];
80
 
81
 
82
                    if(response.success) {
83
                        json.recordsTotal       = response.data.total;
84
                        json.recordsFiltered    = response.data.total;
85
                        json.data               = response.data.items;
86
                    } else {
87
                        $.fn.showError(response.data)
88
                    }
89
 
90
                    return JSON.stringify( json );
91
                }
92
    		},
93
            'language' : {
94
                'sProcessing':     'LABEL_DATATABLE_SPROCESSING',
95
                'sLengthMenu':     'LABEL_DATATABLE_SLENGTHMENU',
96
                'sZeroRecords':    'LABEL_DATATABLE_SZERORECORDS',
97
                'sEmptyTable':     'LABEL_DATATABLE_SEMPTYTABLE',
98
                'sInfo':           'LABEL_DATATABLE_SINFO',
99
                'sInfoEmpty':      'LABEL_DATATABLE_SINFOEMPTY',
100
                'sInfoFiltered':   'LABEL_DATATABLE_SINFOFILTERED',
101
                'sInfoPostFix':    '',
102
                'sSearch':         'LABEL_DATATABLE_SSEARCH',
103
                'sUrl':            '',
104
                'sInfoThousands':  ',',
105
                'sLoadingRecords': 'LABEL_DATATABLE_SLOADINGRECORDS',
106
                'oPaginate': {
107
                    'sFirst':    'LABEL_DATATABLE_SFIRST',
108
                    'sLast':     'LABEL_DATATABLE_SLAST',
109
                    'sNext':     'LABEL_DATATABLE_SNEXT',
110
                    'sPrevious': 'LABEL_DATATABLE_SPREVIOUS'
111
                },
112
                'oAria': {
113
                    'sSortAscending':  ': LABEL_DATATABLE_SSORTASCENDING',
114
                    'sSortDescending': ':LABEL_DATATABLE_SSORTDESCENDING'
115
                },
116
            },
117
            'drawCallback': function( settings ) {
118
                NProgress.done();
119
 
120
            },
121
            'aoColumns': [
122
                { 'mDataProp': 'name' },
123
                { 'mDataProp': 'status' },
124
                { 'mDataProp': 'actions' },
125
    	    ],
126
            'columnDefs': [
127
                {
128
                    'targets': 0,
129
                    'className' : 'text-vertical-middle',
130
                },
131
                {
132
                    'targets': -2,
133
                    'orderable': false,
134
                    'className' : 'text-center',
135
                      'render' : function ( data, type, row ) {
136
 
137
                        checked = data == 'a'  ? 'checked' : '';
138
                        return '<div class="form-check">' +
16971 efrain 139
                            '<input type="checkbox" class="form-check-input" disabled="" ' + checked + '>' +
16822 efrain 140
                            '<label class="form-check-label" for="checkCheckedDisabled"></label></div>' ;
141
                    }
142
                },
143
                {
144
                    'targets': -1,
145
                    'orderable': false,
146
                    'render' : function ( data, type, row ) {
147
                        s = '';
148
 
149
                        if(allowEdit) {
16906 efrain 150
                            s = s + '<button class="btn btn-primary btn-edit" data-href="' + data['link_edit']+ '" data-toggle="tooltip" title="LABEL_EDIT"><i class="fa fa-pen"></i> LABEL_EDIT </button>&nbsp;';
16822 efrain 151
                        }
152
                        if(allowDelete) {
153
                            s = s + '<button class="btn btn-danger btn-delete" data-href="' + data['link_delete']+ '" data-toggle="tooltip" title="LABEL_DELETE"><i class="fa fa-trash"></i> LABEL_DELETE </button>&nbsp;';
154
                        }
155
                        return s;
156
                    }
157
                }
158
              ],
159
        });
160
 
161
 
162
        var validator = $('#form').validate({
163
            debug: true,
164
            onclick: false,
165
            onkeyup: false,
166
            ignore: [],
167
            rules: {
168
                'name': {
169
                    required: true,
170
                    maxlength: 64,
171
                },
172
                'description': {
173
                    updateCkeditor:function() {
174
                        CKEDITOR.instances.description.updateElement();
175
                    },
176
                    required: true,
177
                },
178
                'status': {
179
                    required: false,
180
 
181
                },
182
            },
183
            submitHandler: function(form)
184
            {
185
                $.ajax({
186
                    'dataType'  : 'json',
187
                    'accept'    : 'application/json',
188
                    'method'    : 'post',
189
                    'url'       :  $('#form').attr('action'),
190
                    'data'      :  $('#form').serialize()
191
                }).done(function(response) {
192
                    NProgress.start();
193
                    if(response['success']) {
194
                        $.fn.showSuccess(response['data']);
195
 
196
                        $('#modal').modal('hide');
197
 
198
 
199
                         gridTable.api().ajax.reload(null, false);
200
                    } else {
201
                        validator.resetForm();
202
                        if(jQuery.type(response['data']) == 'string') {
203
                            $.fn.showError(response['data']);
204
                        } else  {
205
                            $.each(response['data'], function( fieldname, errors ) {
206
                                $.fn.showFormErrorValidator('#form #' + fieldname, errors);
207
                            });
208
                        }
209
                    }
210
                }).fail(function( jqXHR, textStatus, errorThrown) {
211
                   $.fn.showError(textStatus);
212
                }).always(function() {
213
                    NProgress.done();
214
                });
215
                return false;
216
            },
217
            invalidHandler: function(form, validator) {
218
 
219
            }
220
        });
221
 
222
        $('body').on('click', 'button.btn-add', function(e) {
223
            e.preventDefault();
224
 
16840 efrain 225
 
16822 efrain 226
            $('#form').attr('action', '$routeAdd');
227
            $('#form #name').val('');
228
            $('#form #status').bootstrapToggle('on');
229
            CKEDITOR.instances.description.setData('');
230
 
231
            validator.resetForm();
232
            $('#modal').modal('show');
233
        });
234
 
235
        $('body').on('click', 'button.btn-edit', function(e) {
236
            e.preventDefault();
237
            NProgress.start();
238
            var action = $(this).data('href');
239
 
240
            $.ajax({
241
                'dataType'  : 'json',
242
                'accept'    : 'application/json',
243
                'method'    : 'get',
244
                'url'       :  action,
245
            }).done(function(response) {
246
                if(response['success']) {
247
 
16840 efrain 248
 
16822 efrain 249
                    $('#form').attr('action', action);
250
                    $('#form #name').val(response['data']['name']);
251
                    $('#form #status').bootstrapToggle(response['data']['status'] == '$status_active' ? 'on' : 'off')
252
                    CKEDITOR.instances.description.setData(response['data']['description']);
253
 
254
                    validator.resetForm();
255
 
256
                    $('#modal').modal('show');
257
                } else {
258
                    $.fn.showError(response['data']);
259
                }
260
            }).fail(function( jqXHR, textStatus, errorThrown) {
261
                $.fn.showError(textStatus);
262
            }).always(function() {
263
                NProgress.done();
264
            });
265
        });
266
 
267
    $('body').on('click', 'button.btn-delete', function(e) {
268
        e.preventDefault();
269
        var action = $(this).data('href');
270
 
271
 
272
          swal.fire({
273
            title: 'LABEL_ARE_YOU_SURE',
274
            icon: 'question',
275
            cancelButtonText: 'LABEL_NO',
276
            showCancelButton: true,
277
            confirmButtonText: 'LABEL_YES'
278
          }).then((result) => {
279
            if (result.isConfirmed) {
280
 
281
                    NProgress.start();
282
                    $.ajax({
283
                        'dataType'  : 'json',
284
                        'accept'    : 'application/json',
285
                        'method'    : 'post',
286
                        'url'       :  action,
287
                    }).done(function(response) {
288
                        if(response['success']) {
289
                            $.fn.showSuccess(response['data']);
290
                            gridTable.api().ajax.reload(null, false);
291
                        } else {
292
                            $.fn.showError(response['data']);
293
                        }
294
                    }).fail(function( jqXHR, textStatus, errorThrown) {
295
                        $.fn.showError(textStatus);
296
                    }).always(function() {
297
                        NProgress.done();
298
                    });
299
                }
300
           });
301
 
302
        });
303
 
304
        $('body').on('click', 'button.btn-refresh', function(e) {
305
            e.preventDefault();
306
            gridTable.api().ajax.reload(null, false);
307
        });
308
 
309
 
310
        $('body').on('click', 'button.btn-cancel', function(e) {
311
            e.preventDefault();
312
            $('#modal').modal('hide');
313
        });
314
 
315
 
316
        $('#form #status').bootstrapToggle({'on' : 'LABEL_ACTIVE',  'off' : 'LABEL_INACTIVE', 'width' : '160px', 'height' : '40px'});
317
        CKEDITOR.replace( 'description')
318
    });
15392 efrain 319
JS;
16822 efrain 320
$this->inlineScript()->captureEnd();
15392 efrain 321
?>
16822 efrain 322
 
15392 efrain 323
 
16822 efrain 324
 
325
<div class="container">
326
    	<div class="row">
16891 efrain 327
        	<div class="col-12 mt-3">
16822 efrain 328
				<div class="card">
329
 
330
					<div class="card-body">
331
					<h6 class="card-title">LABEL_APTITUDES</h6>
332
						<div class="row">
16841 efrain 333
							<div class="col-12  mt-3">
16845 efrain 334
    							<table id="gridTable" class="table   table-bordered">
16822 efrain 335
                              		<thead>
336
                						<tr>
337
                                        	<th>LABEL_NAME</th>
338
                                          	<th>LABEL_ACTIVE</th>
339
                                          	<th>LABEL_ACTIONS</th>
340
                                        </tr>
341
                               		</thead>
342
                                 	<tbody>
343
                                 	</tbody>
344
                            	</table>
345
							</div>
346
						</div>
347
 
348
                   	</div>
349
                   	<div class="card-footer text-right">
350
 
16992 efrain 351
							<button type="button" class="btn btn-info btn-refresh"><i class="fa fa-sync"></i> LABEL_REFRESH  </button>
16822 efrain 352
							<?php if($allowAdd) : ?>
353
							<button type="button" class="btn btn-primary btn-add"><i class="fa fa-plus"></i> LABEL_ADD </button>
354
							<?php endif; ?>
355
 
356
                 	</div>
357
          		</div>
358
           	</div>
359
        </div>
360
</div>
361
 
362
<!-- The Modal -->
363
<div class="modal" id="modal">
364
	<div class="modal-dialog  modal-xl">
365
    	<div class="modal-content">
366
 
367
            <!-- Modal Header -->
368
      		<div class="modal-header">
16845 efrain 369
        		<h6 class="modal-title">LABEL_DEGREES</h6>
16822 efrain 370
        		<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="btn-close"></button>
371
      		</div>
372
 
373
      		 			 <?php
374
                    $form = $this->form;
375
            		$form->setAttributes([
376
                        'method'    => 'post',
377
                        'name'      => 'form',
378
                        'id'        => 'form'
379
                    ]);
380
 
381
                    $form->prepare();
382
                    echo $this->form()->openTag($form);
383
                    ?>
384
 
385
            <!-- Modal body -->
386
      		<div class="modal-body">
387
 
388
    					<div class="row">
16841 efrain 389
    						<div class="col  mt-3">
16822 efrain 390
    						<?php
391
                            $element = $form->get('name');
392
                            $element->setOptions(['label' => 'LABEL_NAME']);
393
                            $element->setAttributes(['class' => 'form-control']);
394
 
395
                            echo $this->formLabel($element);
396
                            echo $this->formText($element);
397
                            ?>
398
                            </div>
399
						</div>
400
    					<div class="row">
16841 efrain 401
    						<div class="col  mt-3">
16822 efrain 402
                    	<?php
403
                            $element = $form->get('description');
404
                            $element->setOptions(['label' => 'LABEL_DESCRIPTION']);
405
                            $element->setAttributes(['class' => 'form-control']);
406
 
407
                            echo $this->formLabel($element);
408
                            echo $this->formTextArea($element);
409
                        ?>
410
                            </div>
411
						</div>
412
    					<div class="row">
16841 efrain 413
    						<div class="col  mt-3">
16822 efrain 414
                      	<?php
415
                            $element = $form->get('status');
416
                            echo $this->formCheckbox($element);
417
                        ?>
418
                            </div>
419
						</div>
420
 
421
      		</div>
422
 
423
            <!-- Modal footer -->
16891 efrain 424
      		<div class="modal-footer text-right">
16822 efrain 425
        		 <button type="submit" class="btn btn-primary">LABEL_SAVE</button>
426
       			<button type="button" class="btn btn-light btn-cancel">LABEL_CANCEL</button>
427
      		</div>
428
      		<?php echo $this->form()->closeTag($form); ?>
429
 
430
    	</div>
431
	</div>
432
</div>
433
 
434
 
435
 
436
 
437