Proyectos de Subversion LeadersLinked - Backend

Rev

Ir a la última revisión | | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
17008 efrain 1
<?php
2
$acl            = $this->viewModel()->getRoot()->getVariable('acl');
3
$currentUser    = $this->currentUserHelper();
4
 
5
$roleName = $currentUser->getUserTypeId();
6
 
7
 
8
$routeAdd   = $this->url('habits/users/add');
9
$routeDatatable = $this->url('habits/users');
10
 
11
$allowAdd               = $acl->isAllowed($roleName, 'habits/users/add') ? 1 : 0;
12
$allowDelete            = $acl->isAllowed($roleName, 'habits/users/delete') ? 1 : 0;
13
 
14
 
15
 
16
$allowUpload = false;
17
 
18
 
19
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/nprogress/nprogress.css'));
20
$this->inlineScript()->appendFile($this->basePath('assets/vendors/nprogress/nprogress.js'));
21
 
22
 
23
 
24
 
25
 
26
 
27
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/datatables.net-bs5/dataTables.bootstrap5.css'));
28
 
29
$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net/jquery.dataTables.js'));
30
$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net-bs5/dataTables.bootstrap5.js'));
31
 
32
 
33
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/bootstrap4-toggle/css/bootstrap4-toggle.min.css'));
34
$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap4-toggle/js/bootstrap4-toggle.min.js'));
35
 
36
 
37
 
38
 
39
$this->inlineScript()->appendFile($this->basePath('assets/vendors/select2/js/select2.js'));
40
$this->inlineScript()->appendFile($this->basePath('assets/vendors/select2/js/i18n/es.js'));
41
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/select2/css/select2.css'));
42
 
43
$this->headLink()->appendStylesheet($this->basePath('assets/vendors/select2-bootstrap5-theme/select2-bootstrap-5-theme.css'));
44
 
45
 
46
 
47
 
48
$this->inlineScript()->captureStart();
49
echo <<<JS
50
    jQuery( document ).ready(function( $ ) {
51
        var routeAdd    = '';
52
        var routeUpload = '';
53
        var allowDelete = $allowDelete;
54
 
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': 'first_name' },
123
                { 'mDataProp': 'last_name' },
124
                { 'mDataProp': 'email' },
125
                { 'mDataProp': 'actions' },
126
    	    ],
127
            'columnDefs': [
128
                {
129
                    'targets': 0,
130
                    'className' : 'text-vertical-middle',
131
                },
132
                {
133
                    'targets': 1,
134
                    'orderable': false,
135
                    'className' : 'text-vertical-middle',
136
 
137
                },
138
                {
139
                    'targets': 2,
140
                    'orderable': false,
141
                    'className' : 'text-vertical-middle',
142
 
143
                },
144
                {
145
                    'targets': -1,
146
                    'orderable': false,
147
                    'render' : function ( data, type, row ) {
148
                        s = '';
149
 
150
                        if(allowDelete) {
151
                            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;';
152
                        }
153
                        return s;
154
                    }
155
                }
156
              ],
157
        });
158
 
159
        var validator = $('#form').validate({
160
            debug: true,
161
            onclick: false,
162
            onkeyup: false,
163
            ignore: [],
164
            rules: {
165
                'user_id': {
166
                    required: true,
167
                },
168
            },
169
            submitHandler: function(form)
170
            {
171
                NProgress.start();
172
                $('#submitBtn').prop('disabled', true);
173
                $.ajax({
174
                    'dataType'  : 'json',
175
                    'accept'    : 'application/json',
176
                    'method'    : 'post',
177
                    'url'       :  $('#form').attr('action'),
178
                    'data'      :  {
179
                        'user_id' : $('#form #user_id').val(),
180
                    }
181
                }).done(function(response) {
182
                    if(response['success']) {
183
                        $.fn.showSuccess(response['data']);
184
 
185
                        $('#modal').modal('hide');
186
 
187
 
188
                         gridTable.api().ajax.reload(null, false);
189
                    } else {
190
                        validator.resetForm();
191
                        if(jQuery.type(response['data']) == 'string') {
192
                            $.fn.showError(response['data']);
193
                        } else  {
194
                            $.each(response['data'], function( fieldname, errors ) {
195
                                $.fn.showFormErrorValidator('#form #' + fieldname, errors);
196
                            });
197
                        }
198
                    }
199
                    $('#submitBtn').prop('disabled', false);
200
                }).fail(function( jqXHR, textStatus, errorThrown) {
201
                   $.fn.showError(textStatus);
202
                }).always(function() {
203
                    $('#submitBtn').prop('disabled', false);
204
                    NProgress.done();
205
                });
206
                return false;
207
            },
208
            invalidHandler: function(form, validator) {
209
 
210
            }
211
        });
212
 
213
 
214
 
215
        $('body').on('click', 'button.btn-add', function(e) {
216
            e.preventDefault();
217
            var action = $(this).data('href');
218
 
219
 
220
            $('#form').attr('action', '$routeAdd');
221
            $('#form #user_id').val('');
222
            $('#form #user_id').trigger('change');
223
 
224
 
225
            validator.resetForm();
226
            $('#modal').modal('show');
227
 
228
            return false;
229
        });
230
 
231
 
232
 
233
        $('body').on('click', 'button.btn-refresh', function(e) {
234
            e.preventDefault();
235
            gridTable.api().ajax.reload(null, false);
236
 
237
            return false;
238
        });
239
 
240
 
241
 
242
 
243
        $('body').on('click', 'button.btn-cancel', function(e) {
244
            e.preventDefault();
245
            $('#modal').modal('hide');
246
        });
247
 
248
    $('body').on('click', 'button.btn-delete', function(e) {
249
        e.preventDefault();
250
        var action = $(this).data('href');
251
 
252
 
253
          swal.fire({
254
            title: 'LABEL_ARE_YOU_SURE',
255
            icon: 'question',
256
            cancelButtonText: 'LABEL_NO',
257
            showCancelButton: true,
258
            confirmButtonText: 'LABEL_YES'
259
          }).then((result) => {
260
            if (result.isConfirmed) {
261
 
262
                    NProgress.start();
263
                    $.ajax({
264
                        'dataType'  : 'json',
265
                        'accept'    : 'application/json',
266
                        'method'    : 'post',
267
                        'url'       :  action,
268
                    }).done(function(response) {
269
                        if(response['success']) {
270
                            $.fn.showSuccess(response['data']);
271
                            gridTable.api().ajax.reload(null, false);
272
                        } else {
273
                            $.fn.showError(response['data']);
274
                        }
275
                    }).fail(function( jqXHR, textStatus, errorThrown) {
276
                        $.fn.showError(textStatus);
277
                    }).always(function() {
278
                        NProgress.done();
279
                    });
280
                }
281
           });
282
        });
283
 
284
 
285
 
286
 
287
        $('#form #user_id').select2({
288
            theme: 'bootstrap-5',
289
            width: '100%',
290
            dropdownParent: $('#modal'),
291
        });
292
 
293
 
294
 
295
    });
296
JS;
297
$this->inlineScript()->captureEnd();
298
?>
299
 
300
 
301
<div class="container">
302
    <div class="card" id="">
303
        <div class="card-header">
304
            <h6 class="card-title">LABEL_USERS</h6>
305
        </div>
306
        <div class="card-body">
307
            <div class="row">
308
                <div class="col-12 mt-3">
309
 
310
                    <table id="gridTable" class="table table-bordered">
311
                   		<thead>
312
                       		<tr>
313
                           		<th>LABEL_FIRST_NAME</th>
314
                               	<th>LABEL_LAST_NAME</th>
315
                         		<th>LABEL_EMAIL</th>
316
  								<th>LABEL_ACTIONS</th>
317
                       		</tr>
318
                   		</thead>
319
                     	<tbody>
320
                      	</tbody>
321
                  	</table>
322
               	</div>
323
        	</div>
324
       	</div>
325
      	 <div class="card-footer text-right">
326
         	 <?php if ($allowAdd) : ?>
327
       		<button type="button" class="btn btn-primary btn-add"><i class="fa fa-plus"></i> LABEL_ADD </button>
328
          	<?php endif; ?>
329
           	<button type="button" class="btn btn-info btn-refresh"><i class="fa fa-sync"></i> LABEL_REFRESH </button>
330
     	</div>
331
	</div>
332
</div>
333
 
334
 
335
 
336
<!-- The Modal -->
337
<div class="modal" id="modal">
338
    <div class="modal-dialog  modal-sm">
339
        <div class="modal-content">
340
 
341
            <!-- Modal Header -->
342
            <div class="modal-header">
343
                <h6 class="modal-title">LABEL_KNOWLEDGE_AREA_CATEGORY_USERS</h6>
344
                <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="btn-close"></button>
345
            </div>
346
 
347
            <!-- Modal body -->
348
            <div class="modal-body">
349
 
350
                <?php
351
                $form = $this->form;
352
                $form->setAttributes([
353
                    'method'    => 'post',
354
                    'name'      => 'form',
355
                    'id'        => 'form'
356
                ]);
357
 
358
                $form->prepare();
359
                echo $this->form()->openTag($form);
360
 
361
                ?>
362
                <div class="card-body">
363
 
364
                    <div class="row">
365
                        <div class="col-12 mt-3">
366
                            <?php
367
                            $element = $form->get('user_id');
368
                            $element->setOptions(['label' => 'LABEL_USER']);
369
                            $element->setAttributes(['class' => 'form-control']);
370
 
371
                            echo $this->formLabel($element);
372
                            echo $this->formSelect($element);
373
                            ?>
374
                        </div>
375
                    </div>
376
 
377
 
378
                </div>
379
            </div>
380
 
381
 
382
            <!-- Modal footer -->
383
            <div class="modal-footer text-right">
384
                <button type="submit" id="submitBtn" form="form" class="btn btn-primary">LABEL_SAVE</button>
385
                <button type="button" class="btn btn-light" data-bs-dismiss="modal">LABEL_CLOSE</button>
386
            </div>
387
            <?php echo $this->form()->closeTag($form); ?>
388
        </div>
389
 
390
 
391
    </div>
392
</div>