Proyectos de Subversion LeadersLinked - Backend

Rev

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

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