2016-10-07 2 views
0

У меня возникла проблема с получением строки из перечисления по id.Yajra Datatable get string by Id

вот мой DataTable код:

<script type="text/javascript"> 
$(document).ready(function(){ 
    var datatable = $('#datatable').DataTable(
    { 
     dom: "lrtip", 
     responsive: true, 
     processing: true, 
     serverSide: true, 
     bSortCellsTop: true, 
     ajax: { 
      url: "{{ route('driver.list') }}", 
      data: { '_token' : '{{csrf_token() }}'}, 
      type: 'POST', 
     }, 
     columns: [ 
     { data: 'first_name', name: 'first_name', className: 'text-center', }, 
     { data: 'last_name', name: 'last_name', className: 'text-center', 'visible': false, 
      'searchable': false, }, 
     { data: 'gender', name: 'gender', className: 'text-center', }, 
     { data: 'race', name: 'race', className: 'text-center', 'visible': false, 
      'searchable': false, }, 
     { data: 'email', name: 'email', className: 'text-center', }, 
     { data: 'mobile', name: 'mobile', className: 'text-center', }, 
     { data: 'nric', name: 'nric', className: 'text-center', }, 
     { data: 'date_of_birth', name: 'date_of_birth', className: 'text-center', 'visible': false, 
      'searchable': false, }, 
     { data: 'license', name: 'license', className: 'text-center', }, 
     { data: 'type', name: 'type', className: 'text-center', 'visible': false, 
      'searchable': false, }, 
     { data: 'action', name: 'action', className: 'text-center', orderable: false, searchable: false }, 
     ], 
     initComplete: function() { 
      this.api().columns().every(function() { 
       $('#datatable thead tr#filterRow th:not(:last-child)').each(function() { 
        var title = $('#datatable thead th').eq($(this).index()).text(); 
        $(this).html('<input type="text" class="col-md-12" placeholder="Search by '+title+'" />'); 
        if (title == "Gender") { 
         var select = $('<select>'); 
         var genderList = {!! json_encode($genderList) !!}; 
         for (var i = 0;i < genderList.length; i++) { 
          option = $('<option>',{ 
           value: i, 
           text: genderList[i], 
          }); 
          select.append(option); 
         } 
         $(this).html(select); 
        } 
       }); 
       $('select').select2({ 
        allowClear: true, 
       }); 
       $("#datatable thead input,#datatable thead select").on('keyup change', function() { 
        console.log($(this).val()); 
        datatable.column($(this).parent().index()).search(this.value).draw(); 
       }); 
      }); 
     } 
    }); 
}); 
</script> 

вот мой код перечисление:

<?php 

namespace App\Helpers\Enums; 

final class Gender { 
const MALE = 0; 
const FEMALE = 1; 
public static function getList() { 
    return [ 
     Gender::MALE, 
     Gender::FEMALE, 
    ]; 
} 

public static function getArray() { 
    $result = []; 
    foreach (self::getList() as $arr) { 
     $result[$arr] = self::getString($arr); 
    } 
    return $result; 
} 

public static function getString($val) { 
    switch ($val) { 
     case 0: 
      return "Male"; 
     case 1: 
      return "Female"; 
    } 
} 

} 

?> 

Я хочу взять строку из перечисления по идентификатору.

Почему, когда я выбираю мужчина/женщина, он не обрабатывал данные? Есть идеи ?

ответ

0

Если вы используете DataTable пакет Yajra почему бы вам не использовать трансформатор вместо этого, он хорошо работает с фрактал, смотрите здесь: https://datatables.yajrabox.com/eloquent/transformer

Затем вы можете сделать что-то подобное в вашем трансформаторе:

public function transform(Driver $driver) 
{ 
    return [ 
     'gender' => $driver->gender == 0 ? 'Male' : 'Female' 
    ]; 
} 
+0

Я должен добавить новую модель DriverTransformer? –

+0

Да. Дайте мне знать, если вы застряли, и я могу вызвать примерный код. – haakym

+1

решена. спасибо, кстати. –

Смежные вопросы