Rev 16929 | Rev 16992 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
<?php$acl = $this->viewModel()->getRoot()->getVariable('acl');$currentUser = $this->currentUserHelper();$roleName = $currentUser->getUserTypeId();$routeDatatable = $this->url('microlearning/access-for-students');$allowRevoke = $acl->isAllowed($roleName, 'microlearning/access-for-students/revoke') ? 1 : 0;$allowUnlimit = $acl->isAllowed($roleName, 'microlearning/access-for-students/unlimit') ? 1 : 0;$allowUpload = $acl->isAllowed($roleName, 'microlearning/access-for-students/upload') ? 1 : 0;$allowCancel = $acl->isAllowed($roleName, 'microlearning/access-for-students/cancel') ? 1 : 0;$allowReactive = $acl->isAllowed($roleName, 'microlearning/access-for-students/reactive') ? 1 : 0;$allowNotification = $acl->isAllowed($roleName, 'microlearning/access-for-students/notification') ? 1 : 0;$this->headLink()->appendStylesheet($this->basePath('assets/vendors/nprogress/nprogress.css'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/nprogress/nprogress.js'));$this->headLink()->appendStylesheet($this->basePath('assets/vendors/datatables.net-bs5/dataTables.bootstrap5.css'));$this->headLink()->appendStylesheet($this->basePath('assets/vendors/datatables.net-bs5-responsive/responsive.bootstrap5.css'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net/jquery.dataTables.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net-bs5/dataTables.bootstrap5.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net-bs5-responsive/dataTables.responsive.min.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/datatables.net-bs5-responsive/responsive.bootstrap5.min.js'));$this->headLink()->appendStylesheet($this->basePath('assets/vendors/bootstrap4-toggle/css/bootstrap4-toggle.min.css'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap4-toggle/js/bootstrap4-toggle.min.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/moment/moment-with-locales.min.js'));$this->headLink()->appendStylesheet($this->basePath('assets/vendors/bootstrap-datetimepicker/css/bootstrap-datetimepicker.css'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap-datetimepicker/js/bootstrap-datetimepicker.min.js'));$this->headLink()->appendStylesheet($this->basePath('assets/vendors/bootstrap-fileinput/css/fileinput.min.css'));$this->headLink()->appendStylesheet($this->basePath('assets/vendors/bootstrap-fileinput/themes/explorer-fas/theme.css'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap-fileinput/js/plugins/piexif.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap-fileinput/js/plugins/sortable.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap-fileinput/js/fileinput.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap-fileinput/js/locales/es.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap-fileinput/themes/fas/theme.js'));$this->inlineScript()->appendFile($this->basePath('assets/vendors/bootstrap-fileinput/themes/explorer-fas/theme.js'));$this->headStyle()->captureStart();echo <<<CSS#gridTableUploadOk {display: flex;flex-flow: column;width: 100%;}#gridTableUploadOk thead {flex: 0 0 auto;}#gridTableUploadOk tbody {flex: 1 1 auto;display: block;overflow-y: auto;overflow-x: hidden;}#gridTableUploadOk tr {width: 100%;display: table;table-layout: fixed;}#gridTableUploadError {display: flex;flex-flow: column;width: 100%;}#gridTableUploadError thead {flex: 0 0 auto;}#gridTableUploadError tbody {flex: 1 1 auto;display: block;overflow-y: auto;overflow-x: hidden;}#gridTableUploadError tr {width: 100%;display: table;table-layout: fixed;}CSS;$this->headStyle()->captureEnd();$this->inlineScript()->captureStart();echo <<<JSjQuery( document ).ready(function( $ ) {var routeUpload = '';var routeNotification = '';$.validator.setDefaults({debug: true,highlight: function(element) {$(element).addClass('is-invalid');},unhighlight: function(element) {$(element).removeClass('is-invalid');},errorElement: 'span',errorClass: 'error invalid-feedback',errorPlacement: function(error, element) {if(element.parent('.btn-file').length) {error.insertAfter(element.parent().parent());} else if(element.parent('.toggle').length) {error.insertAfter(element.parent().parent());} else {error.insertAfter(element.parent());}}});var allowRevoke = $allowRevoke;var allowUnlimit = $allowUnlimit;var allowCancel = $allowCancel;var allowReactive = $allowReactive;var allowUpload = $allowUpload;var allowNotification = $allowNotification;var gridTable = $('#gridTable').dataTable( {'processing': true,'serverSide': true,'searching': true,'order': [[ 1, 'asc' ]],'ordering': true,'ordenable' : true,'responsive': true,'select' : false,'paging': true,'pagingType': 'simple_numbers','lengthMenu': [ [10, 25, 50, -1], [10, 25, 50, 'All'] ],'ajax': {'url' : '$routeDatatable','type' : 'get','data': function ( d ) {d.topic_uuid = $('#form-filter #topic_uuid').val();d.capsule_uuid = $('#form-filter #capsule_uuid').val();},'beforeSend': function (request) {NProgress.start();},'dataFilter': function(response) {var response = jQuery.parseJSON( response );var json = {};json.recordsTotal = 0;json.recordsFiltered = 0;json.data = [];if(response.success) {$('#form-capsule-add').attr('action', response.data.link_add );if(response.data.capsules) {$('#form-filter #capsule_uuid').empty();$.each(response.data.capsules, function(index, value) {$('#form-filter #capsule_uuid').append('<option value="' + index + '">' + value + '</option>')});}routeUpload = response.data.link_upload;routeNotification = response.data.link_notification;if(response.data.link_upload) {$('button.btn-upload').removeAttr('disabled');} else {$('button.btn-upload').attr('disabled', 'disabled');}if(response.data.link_notification) {$('button.btn-notification').removeAttr('disabled');} else {$('button.btn-notification').attr('disabled', 'disabled');}json.recordsTotal = response.data.total;json.recordsFiltered = response.data.total;json.data = response.data.items;} else {$.fn.showError(response.data)}return JSON.stringify( json );}},'language' : {'sProcessing': 'LABEL_DATATABLE_SPROCESSING','sLengthMenu': 'LABEL_DATATABLE_SLENGTHMENU','sZeroRecords': 'LABEL_DATATABLE_SZERORECORDS','sEmptyTable': 'LABEL_DATATABLE_SEMPTYTABLE','sInfo': 'LABEL_DATATABLE_SINFO','sInfoEmpty': 'LABEL_DATATABLE_SINFOEMPTY','sInfoFiltered': 'LABEL_DATATABLE_SINFOFILTERED','sInfoPostFix': '','sSearch': 'LABEL_DATATABLE_SSEARCH','sUrl': '','sInfoThousands': ',','sLoadingRecords': 'LABEL_DATATABLE_SLOADINGRECORDS','oPaginate': {'sFirst': 'LABEL_DATATABLE_SFIRST','sLast': 'LABEL_DATATABLE_SLAST','sNext': 'LABEL_DATATABLE_SNEXT','sPrevious': 'LABEL_DATATABLE_SPREVIOUS'},'oAria': {'sSortAscending': ': LABEL_DATATABLE_SSORTASCENDING','sSortDescending': ':LABEL_DATATABLE_SSORTDESCENDING'},},'drawCallback': function( settings ) {NProgress.done();},'aoColumns': [{ 'mDataProp': 'uuid' },{ 'mDataProp': 'first_name' },{ 'mDataProp': 'last_name' },{ 'mDataProp': 'email' },{ 'mDataProp': 'details' },{ 'mDataProp': 'actions' },],'columnDefs': [{'targets': 0,'orderable': false,'render' : function ( data, type, row ) {s = '<input type="checkbox" class="chk-customer" value="' + data + '">';return s;}},{'targets': -2,'orderable': false,'render' : function ( data, type, row ) {s = '';if(data['access']) {s = s + 'LABEL_ACCESS : ' + data['access'] + '<br>';}if(data['paid_from']) {s = s + 'LABEL_PAID_FROM : ' + data['paid_from'] + '<br>';}if(data['paid_to']) {s = s + 'LABEL_PAID_TO : ' + data['paid_to'] + '<br>';}if(data['added_on']) {s = s + 'LABEL_ADDED_ON : ' + data['added_on'] + '<br>';}if(data['updated_on']) {s = s + 'LABEL_UPDATED_ON : ' + data['updated_on'] + '<br>';}return s;}},{'targets': -1,'orderable': false,'render' : function ( data, type, row ) {s = '';if(allowRevoke && data['link_revoke'] ) {s = s + '<button class="btn btn-danger btn-sm btn-revoke" data-href="' + data['link_revoke']+ '" data-toggle="tooltip" title="LABEL_REVOKE"><i class="fa fa-times"></i> LABEL_REVOKE </button> ';}if(allowCancel && data['link_cancel'] ) {s = s + '<button class="btn btn-danger btn-sm btn-cancel" data-href="' + data['link_cancel']+ '" data-toggle="tooltip" title="LABEL_CANCEL"><i class="fa fa-times"></i> LABEL_CANCEL </button> ';}if(allowUnlimit && data['link_unlimit'] ) {s = s + '<button class="btn btn-primary btn-sm btn-unlimit" data-href="' + data['link_unlimit']+ '" data-toggle="tooltip" title="LABEL_UNLIMIT"><i class="fa fa-check"></i> LABEL_UNLIMIT </button> ';}if(allowReactive && data['link_reactive'] ) {s = s + '<button class="btn btn-success btn-sm btn-reactive" data-href="' + data['link_reactive']+ '" data-toggle="tooltip" title="LABEL_REACTIVE"><i class="fa fa-check"></i> LABEL_REACTIVE </button> ';}return s;}}],});$('#form-filter #topic_uuid').change(function(e) {e.preventDefault();$('#form-filter #capsule_uuid').empty();gridTable.api().ajax.reload(null, false);})$('#form-filter #capsule_uuid').change(function(e) {e.preventDefault();gridTable.api().ajax.reload(null, false);})$('body').on('click', 'button.btn-notification', function(e) {e.preventDefault();var customer_uuids = [];$.each($('input[type="checkbox"].chk-customer:checked'), function(index, element) {customer_uuids.push($(this).val());});if(customer_uuids.length == 0) {$.fn.showError('ERROR_NOT_SELECTED_CUSTOMERS');return;}var href = $(this).data('href');$('#notificationPushModal').modal('show');$('#form-push-notification').attr('action', href);});$('#chk-customer-all').click(function(e) {// e.preventDefault();var checked = $(this).prop('checked');$.each($('input[type="checkbox"].chk-customer'), function(index, element) {$(this).prop('checked', checked);});});$('body').on('click', 'input[type="checkbox"].chk-customer', function(e) {var checked = $(this).prop('checked');if(!checked) {$('#chk-customer-all').prop('checked', false );}});var validatorPushNotification = $('#form-push-notification').validate({debug: true,onclick: false,onkeyup: false,onfocusout: false,ignore: [],rules: {'push_template_id' : {required: true,},},submitHandler: function(form){var customer_uuids = [];$.each($('input[type="checkbox"].chk-customer:checked'), function(index, element) {customer_uuids.push($(this).val());});if(customer_uuids.length == 0) {$.fn.showError('ERROR_NOT_SELECTED_CUSTOMERS');return;}var push_template_id = $('#form-push-notification #push_template_id').val();$('input[type="submit"]').prop('disabled', true);NProgress.start();$.ajax({'dataType' : 'json','accept' : 'application/json','method' : 'post','url' : routeNotification,'data' : {'push_template_id' : push_template_id,'customer_uuids' : customer_uuids},}).done(function(response) {if(response['success']) {if(response['data']['push_to_send'] == 1) {$.fn.showSuccess(response['data']['push_to_send'] + ' LABEL_PUSH_IN_QUEUE');} else {$.fn.showSuccess(response['data']['push_to_send'] + ' LABEL_PUSHES_IN_QUEUE');}$('#notificationPushModal').modal('hide');} else {validatorPushNotification.resetForm();if(jQuery.type(response['data']) == 'string') {$.fn.showError(response['data']);} else {$.each(response['data'], function( fieldname, errors ) {$.fn.showFormErrorValidator('#form-push-notification #' + fieldname, errors);});}}}).fail(function( jqXHR, textStatus, errorThrown) {$.fn.showError(textStatus);}).always(function() {NProgress.done();});return false;},invalidHandler: function(form, validator) {}});var validatorCapsuleCustomer = $('#form-capsule-customer').validate({debug: true,onclick: false,onkeyup: false,onfocusout: false,ignore: [],rules: {'file' : {required: true,extension: 'xls|xlsx',accept: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.ms-excel'},},submitHandler: function(form){NProgress.start();var formdata = false;if (window.FormData){formdata = new FormData(form);}formdata.append('step','validation');$.ajax({'dataType' : 'json','accept' : 'application/json','method' : 'post','url' : routeUpload,'data' : formdata,'processData': false,'contentType': false,}).done(function(response) {if(response['success']) {$('#table-upload-customers-key').val(response['data']['key']);$('#table-upload-customers-topic').val(response['data']['topic']);$('#table-upload-customers-capsule').val(response['data']['capsule']);$('#gridTableUploadOk tbody').empty();$.each(response['data']['items']['ok'], function(index, item) {var s = '<tr>';s = s + '<td>' + item['id'] + '</td>';s = s + '<td>' + item['first_name'] + '</td>';s = s + '<td>' + item['last_name'] + '</td>';s = s + '<td>' + item['email'] + '</td>';s = s + '<td class="text-right">' + item['assigned_capsules'] + '</td>';s = s + '</tr>';$('#gridTableUploadOk tbody').append(s);});$.each(response['data']['items']['error'], function(index, item) {var s = '<tr>';s = s + '<td>' + item['id'] + '</td>';s = s + '<td>' + item['first_name'] + '</td>';s = s + '<td>' + item['last_name'] + '</td>';s = s + '<td>' + item['email'] + '</td>';s = s + '<td>' + item['status'] + '</td>';s = s + '</tr>';$('#gridTableUploadError tbody').append(s);});$('#modalCapsuleCustomer').modal('hide');$('#modalUploadCustomers').modal('show');} else {validatorCapsuleCustomer.resetForm();if(jQuery.type(response['data']) == 'string') {$.fn.showError(response['data']);} else {$.each(response['data'], function( fieldname, errors ) {$.fn.showFormErrorValidator('#form-capsule-customer #' + fieldname, errors);});}}}).fail(function( jqXHR, textStatus, errorThrown) {$.fn.showError(textStatus);}).always(function() {NProgress.done();});return false;},invalidHandler: function(form, validator) {}});$('#form-capsule-customer #file').fileinput({theme: 'fas',language: 'es',showUpload: false,dropZoneEnabled: false,maxFileCount: 1,allowedFileExtensions: ['xls', 'xlsx'],});$('body').on('click', 'button.btn-upload', function(e) {e.preventDefault();$('#form-capsule-customer #file').fileinput('reset');$('#form-capsule-customer #file').val('');$('#modalCapsuleCustomer').modal('show');});$('body').on('click', 'button.btn-upload-customers-step2', function(e) {e.preventDefault();NProgress.start();$.ajax({'dataType' : 'json','accept' : 'application/json','method' : 'post','url' : routeUpload,'data' : {'step' : 'process','key' : $('#table-upload-customers-key').val(),}}).done(function(response) {if(response['success']) {var anchor = window.document.createElement("a");anchor.href = 'data:application/octet-stream;charset=utf-8;base64,' + response['data']['csv_base64_content'] ;anchor.download = response['data']['csv_filename'];document.body.appendChild(anchor);anchor.click(); // IE: "Access is denied"; see: https://connect.microsoft.com/IE/feedback/details/797361/ie-10-treats-blob-url-as-cross-origin-and-denies-accessdocument.body.removeChild(anchor);var s = response['data']['users_processed'] + ' LABEL_USTUDENTS_PROCESED <br>' +response['data']['users_assigned'] + ' LABEL_STUDENTS_ASSIGNED <br>' +response['data']['users_previous'] + ' LABEL_USTUDENTS_PREVIOUS <br>' +response['data']['users_in_the_capsule'] + ' LABEL_STUDENTS_TOTAL';$.fn.showSuccess(s);gridTable.api().ajax.reload(null, false);$('#modalUploadCustomers').modal('hide');} else {$.fn.showError(response['data']);}}).fail(function( jqXHR, textStatus, errorThrown) {$.fn.showError(textStatus);}).always(function() {NProgress.done();});return false;});$('body').on('click', 'button.btn-refresh', function(e) {e.preventDefault();gridTable.api().ajax.reload(null, false);});$('body').on('click', 'button.btn-delete', function(e) {e.preventDefault();var action = $(this).data('href');swal.fire({title: 'LABEL_ARE_YOU_SURE',icon: 'question',cancelButtonText: 'LABEL_NO',showCancelButton: true,confirmButtonText: 'LABEL_YES'}).then((result) => {if (result.isConfirmed) {NProgress.start();$.ajax({'dataType' : 'json','accept' : 'application/json','method' : 'post','url' : action,}).done(function(response) {if(response['success']) {$.fn.showSuccess(response['data']);gridTable.api().ajax.reload(null, false);} else {$.fn.showError(response['data']);}}).fail(function( jqXHR, textStatus, errorThrown) {$.fn.showError(textStatus);}).always(function() {NProgress.done();});}});});$('body').on('click', 'button.btn-unlimit', function(e) {e.preventDefault();var action = $(this).data('href');swal.fire({title: 'LABEL_ARE_YOU_SURE',icon: 'question',cancelButtonText: 'LABEL_NO',showCancelButton: true,confirmButtonText: 'LABEL_YES'}).then((result) => {if (result.isConfirmed) {NProgress.start();$.ajax({'dataType' : 'json','accept' : 'application/json','method' : 'post','url' : action,}).done(function(response) {if(response['success']) {$.fn.showSuccess(response['data']);gridTable.api().ajax.reload(null, false);} else {$.fn.showError(response['data']);}}).fail(function( jqXHR, textStatus, errorThrown) {$.fn.showError(textStatus);}).always(function() {NProgress.done();});}});});});JS;$this->inlineScript()->captureEnd();?><div class="container"><div class="card" id=""><div class="card-header"><h6 class="card-title">LABEL_ACCESS_FOR_STUDENTS</h6></div><?php$form = $this->form;$form->setAttributes(['name' => 'form-filter','id' => 'form-filter',]);$form->prepare();echo $this->form()->openTag($form);?><div class="card-body"><div class="row"><div class="col-6 mt-3 "><?php$element = $form->get('topic_uuid');$element->setOptions(['label' => 'LABEL_TOPIC']);$element->setAttributes(['class' => 'form-control']);echo $this->formLabel($element);echo $this->formSelect($element);?></div><div class="col-6 mt-3"><?php$element = $form->get('capsule_uuid');$element->setOptions(['label' => 'LABEL_CAPSULE']);$element->setAttributes(['class' => 'form-control']);echo $this->formLabel($element);echo $this->formSelect($element);?></div></div><div class="row"><div class="col-12 mt-3"><table id="gridTable" class="table table-bordered"><thead><tr><th><input type="checkbox" id="chk-customer-all"></th><th>LABEL_FIRST_NAME</th><th>LABEL_LAST_NAME</th><th>LABEL_EMAIL</th><th>LABEL_DETAILS</th><th>LABEL_ACTIONS</th></tr></thead><tbody></tbody></table></div></div></div><div class="card-footer text-right"><button type="button" class="btn btn-info btn-refresh"><i class="fa fa-refresh"></i> LABEL_REFRESH </button><?php if($allowUpload) : ?><button type="button" class="btn btn-primary btn-upload"><i class="fa fa-upload"></i> LABEL_UPLOAD </button><?php endif; ?><?php if($allowNotification) : ?><button type="button" class="btn btn-primary btn-notification"><i class="fa fa-tablet"></i> LABEL_NOTIFICATION </button><?php endif; ?></div><?php echo $this->form()->closeTag($form); ?></div></div><!-- The Modal --><div class="modal" id="notificationPushModal"><div class="modal-dialog modal-sm"><div class="modal-content"><!-- Modal Header --><div class="modal-header"><h6 class="modal-title">LABEL_PUSH_NOTIFICATION</h6><button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="btn-close"></button></div><?php$form = $this->formPushNotification;$form->setAttributes(['method' => 'post','name' => 'form-push-notification','id' => 'form-push-notification',]);$form->prepare();echo $this->form()->openTag($form);?><div class="modal-body"><div class="row"><div class="col-12 mt-3"><?php$element = $form->get('push_template_id');$element->setAttributes(['class' => 'form-control']);$element->setLabelAttributes(['class' => 'form-label']);$element->setOptions(['label' => 'LABEL_TYPE']);echo $this->formLabel($element);echo $this->formSelect($element);?></div></div></div><!-- Modal footer --><div class="modal-footer text-right"><button type="submit" class="btn btn-primary">LABEL_SEND</button><button type="button" class="btn btn-danger" data-dismiss="modal">LABEL_CLOSE</button></div><?phpecho $this->form()->closeTag($form);?></div></div></div><!-- The Modal --><div class="modal" id="modalCapsuleCustomer"><div class="modal-dialog modal-xl"><div class="modal-content"><!-- Modal Header --><div class="modal-header"><h6 class="modal-title">LABEL_UPLOAD</h6><button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="btn-close"></button></div><?php$form = $this->formCapsuleCustomer;$form->setAttributes(['method' => 'post','name' => 'form-capsule-customer','id' => 'form-capsule-customer']);$form->prepare();echo $this->form()->openTag($form);?><div class="modal-body"><div class="row"><div class="col-12 mt-3"><?php$element = $form->get('file');$element->setOptions(['label' => 'LABEL_EXCEL']);echo $this->formLabel($element);?><div class="file-loading"><?php$element->setAttributes(['class' => 'form-control', 'accept' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.ms-excel']);echo $this->formFile($element);?></div></div></div></div><!-- Modal footer --><div class="modal-footer text-right"><button type="submit" class="btn btn-primary">LABEL_UPLOAD</button><button type="button" class="btn btn-danger" data-dismiss="modal">LABEL_CLOSE</button></div><?php echo $this->form()->closeTag($form); ?></div></div></div><!-- The Modal --><div class="modal" id="modalUploadCustomers"><div class="modal-dialog modal-xl"><div class="modal-content"><!-- Modal Header --><div class="modal-header"><h6 class="modal-title">LABEL_CUSTOMERS</h6><button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="btn-close"></button></div><!-- Modal body --><div class="modal-body"><form><input type="hidden" name="table-upload-customers-key" id="table-upload-customers-key"><div class="row"><div class="col-12 mt-3"><label>LABEL_TOPIC</label><input type="text" readonly="readonly" id="table-upload-customers-topic" class="form-control" ></div></div><div class="row"><div class="col-12 mt-3"><label>LABEL_CAPSULE</label><input type="text" readonly="readonly" id="table-upload-customers-capsule" class="form-control" ></div></div></form><div class="row"><div class="col-12 mt-3"><ul class="nav nav-tabs" id="myTab" role="tablist"><li class="nav-item"><a class="nav-link active" id="items-ok-tab" data-bs-toggle="tab" href="#items-ok" role="tab" aria-controls="items-ok" aria-selected="true">LABEL_USERS</a></li><li class="nav-item"><a class="nav-link" id="items-error-tab" data-bs-toggle="tab" href="#items-error" role="tab" aria-controls="items-error" aria-selected="false">LABEL_ERRORS</a></li></ul><div class="tab-content border border-top-0 p-3" id="myTabContent"><div class="tab-pane fade show active" id="items-ok" role="tabpanel" aria-labelledby="items-ok-tab"><div style="height: 300px;overflow: scroll;"><table id="gridTableUploadOk" style="width: 100%" class="table table-bordered"><thead><tr><th>LABEL_ID</th><th>LABEL_FIRST_NAME</th><th>LABEL_LAST_NAME</th><th>LABEL_EMAIL</th><th>LABEL_CAPSULES</th></tr></thead><tbody></tbody></table></div></div><div class="tab-pane fade" id="items-error" role="tabpanel" aria-labelledby="items-error-tab"><div style="height: 300px;overflow: scroll;"><table id="gridTableUploadError" style="width: 100%" class="table table-bordered"><thead><tr><th>LABEL_ID</th><th>LABEL_FIRST_NAME</th><th>LABEL_LAST_NAME</th><th>LABEL_EMAIL</th><th>LABEL_STATUS</th></tr></thead><tbody></tbody></table></div></div></div></div></div></div><!-- Modal footer --><div class="modal-footer text-right"><button type="submit" class="btn btn-primary btn-upload-customers-step2">LABEL_SAVE</button><button type="button" class="btn btn-danger" data-dismiss="modal">LABEL_CLOSE</button></div></div></div></div>