Im adding multiple rows using AJAX to the datatable which contains a checkbox as a element. I have written a code for the checkboxes that after selecting/deselecting 'select-all', all child checkboxes in tbody should get checked or unchecked accordingly.. And after selecting/deselecting any child checkboxes manually, 'select-all' checkbox should change. But this part is not working.
HTML CODE:
<table id="user" class="w3-table-all w3-hoverable w3-card-4 display">
<thead>
<tr class="w3-light-grey">
<th><input type="checkbox" class="w3-check" id="select-all"></th>
<th>User Id</th>
<th>Username</th>
<th>Full Name</th>
<th>Activated Date</th>
<th>Last Login Date</th>
</tr>
</thead>
<tbody id="body">
</tbody>
</table>
JQuery for checkboxes:
$("#select-all").change(function(){
$(".checkbox").prop('checked', $(this).prop("checked"));
});
$('.checkbox').change(function(){
if(false == $(this).prop("checked")){
$("#select-all").prop('checked', false);
}
if ($('.checkbox:checked').length == $('.checkbox').length ){
$("#select-all").prop('checked', true);
}
});
DATATABLE and AJAX FUNCTION CODE:
var table = $('#user').DataTable({
"columns": [
{ "orderable": false },
null,
null,
null,
null,
null,
],
"order": [[ 1, "asc" ]]
});
$.ajax({
url: 'data.json',
dataType: 'json',
success: function(data) {
for (var i=0; i<data.length; i++) {
if(data[i].enabled==1)
var row1 = $('<tr><td><input type="checkbox" class="w3-check checkbox" value=""></td><td>' + data[i].id+ '</td><td>' + data[i].username + '</td><td>' + data[i].first_name + ' ' + data[i].middle_name + ' ' + data[i].last_name + '</td><td>' + data[i].activated_date + '</td><td>' + data[i].last_login + '</td></tr>');
table.rows.add(row1);
table.draw();
$("#body").append(row1);
}
},
error: function(jqXHR, textStatus, errorThrown){
alert('Error: ' + textStatus + ' - ' + errorThrown);
}
});