Proyectos de Subversion LeadersLinked - Backend

Rev

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

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