If you have developed web based application by using laravel
framework, then you have to need to give one feature like delete or remove
multiple records by using checkbox with ajax in your laravel based web based
application. By using this feature user can easily remove multiple or bulk un
usable data in a single click and this type of feature will save user time for
delete data one by one. This all operation will be done without refresh of web
page because we have use ajax for this things.
So, in this blog we have discuss how to remove or delete multiple mysql table data with checkbox by using Ajax in Laravel application. If you want to remove single records then you can also use this feature by selecting only single records. In our previous post we have already covered how to delete single records by using Ajax in Laravel. So, many reader has requested us to make this type of tutorial like how to remove or delete multiple data by using Ajax with Checkbox in Laravel.
In our previously post we have already loaded mysql table data in Yajra Datatables package. So we have use same code here with Add new data with edit and delete button for this we have to go to resources/views/student/ajaxdata.blade.php file. Under this First we want to add one button for delete multiple checked checkbox row. After this we have we have register new column into jquery Datatables code. Dyanmically checkbox each row code will be generated at AjaxdataController.php file. And lastly in this file we have to write jquery code on bulk delete button which we have created lastly. Whole view file code you can find below.
So, in this blog we have discuss how to remove or delete multiple mysql table data with checkbox by using Ajax in Laravel application. If you want to remove single records then you can also use this feature by selecting only single records. In our previous post we have already covered how to delete single records by using Ajax in Laravel. So, many reader has requested us to make this type of tutorial like how to remove or delete multiple data by using Ajax with Checkbox in Laravel.
In our previously post we have already loaded mysql table data in Yajra Datatables package. So we have use same code here with Add new data with edit and delete button for this we have to go to resources/views/student/ajaxdata.blade.php file. Under this First we want to add one button for delete multiple checked checkbox row. After this we have we have register new column into jquery Datatables code. Dyanmically checkbox each row code will be generated at AjaxdataController.php file. And lastly in this file we have to write jquery code on bulk delete button which we have created lastly. Whole view file code you can find below.
<!DOCTYPE
html>
<html>
<head>
<title>Datatables Server Side
Processing in Laravel</title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.0/jquery.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" />
<script src="https://cdn.datatables.net/1.10.12/js/jquery.dataTables.min.js"></script>
<script src="https://cdn.datatables.net/1.10.12/js/dataTables.bootstrap.min.js"></script>
<link rel="stylesheet" href="https://cdn.datatables.net/1.10.12/css/dataTables.bootstrap.min.css" />
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
</head>
<body>
<div class="container">
<br />
<h3 align="center">Datatables Server Side
Processing in Laravel</h3>
<br />
<div align="right">
<button type="button" name="add" id="add_data" class="btn btn-success btn-sm">Add</button>
</div>
<br />
<table id="student_table" class="table table-bordered" style="width:100%">
<thead>
<tr>
<th>First Name</th>
<th>Last Name</th>
<th>Action</th>
<th><button type="button" name="bulk_delete" id="bulk_delete" class="btn btn-danger btn-xs"><i class="glyphicon glyphicon-remove"></i></button></th>
</tr>
</thead>
</table>
</div>
<div id="studentModal" class="modal fade" role="dialog">
<div class="modal-dialog">
<div class="modal-content">
<form method="post" id="student_form">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<h4 class="modal-title">Add Data</h4>
</div>
<div class="modal-body">
{{csrf_field()}}
<span id="form_output"></span>
<div class="form-group">
<label>Enter First Name</label>
<input type="text" name="first_name" id="first_name" class="form-control" />
</div>
<div class="form-group">
<label>Enter Last Name</label>
<input type="text" name="last_name" id="last_name" class="form-control" />
</div>
</div>
<div class="modal-footer">
<input type="hidden" name="student_id" id="student_id" value="" />
<input type="hidden" name="button_action" id="button_action" value="insert" />
<input type="submit" name="submit" id="action" value="Add" class="btn btn-info" />
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
</div>
</form>
</div>
</div>
</div>
<script type="text/javascript">
$(document).ready(function() {
$('#student_table').DataTable({
"processing": true,
"serverSide": true,
"ajax": "{{
route('ajaxdata.getdata') }}",
"columns":[
{ "data": "first_name" },
{ "data": "last_name" },
{ "data": "action", orderable:false, searchable: false},
{ "data":"checkbox", orderable:false, searchable:false}
]
});
$('#add_data').click(function(){
$('#studentModal').modal('show');
$('#student_form')[0].reset();
$('#form_output').html('');
$('#button_action').val('insert');
$('#action').val('Add');
$('.modal-title').text('Add Data');
});
$('#student_form').on('submit', function(event){
event.preventDefault();
var form_data = $(this).serialize();
$.ajax({
url:"{{
route('ajaxdata.postdata') }}",
method:"POST",
data:form_data,
dataType:"json",
success:function(data)
{
if(data.error.length > 0)
{
var error_html = '';
for(var count = 0; count < data.error.length; count++)
{
error_html += '<div class="alert
alert-danger">'+data.error[count]+'</div>';
}
$('#form_output').html(error_html);
}
else
{
$('#form_output').html(data.success);
$('#student_form')[0].reset();
$('#action').val('Add');
$('.modal-title').text('Add Data');
$('#button_action').val('insert');
$('#student_table').DataTable().ajax.reload();
}
}
})
});
$(document).on('click', '.edit', function(){
var id = $(this).attr("id");
$('#form_output').html('');
$.ajax({
url:"{{route('ajaxdata.fetchdata')}}",
method:'get',
data:{id:id},
dataType:'json',
success:function(data)
{
$('#first_name').val(data.first_name);
$('#last_name').val(data.last_name);
$('#student_id').val(id);
$('#studentModal').modal('show');
$('#action').val('Edit');
$('.modal-title').text('Edit Data');
$('#button_action').val('update');
}
})
});
$(document).on('click', '.delete', function(){
var id = $(this).attr('id');
if(confirm("Are you sure you want to
Delete this data?"))
{
$.ajax({
url:"{{route('ajaxdata.removedata')}}",
mehtod:"get",
data:{id:id},
success:function(data)
{
alert(data);
$('#student_table').DataTable().ajax.reload();
}
})
}
else
{
return false;
}
});
$(document).on('click', '#bulk_delete', function(){
var id = [];
if(confirm("Are you sure you want to
Delete this data?"))
{
$('.student_checkbox:checked').each(function(){
id.push($(this).val());
});
if(id.length > 0)
{
$.ajax({
url:"{{
route('ajaxdata.massremove')}}",
method:"get",
data:{id:id},
success:function(data)
{
alert(data);
$('#student_table').DataTable().ajax.reload();
}
});
}
else
{
alert("Please select atleast one
checkbox");
}
}
});
});
</script>
</body>
</html>
Now we want to go to app/Http/Controllers/AjaxdataController.php file
and in this file we have write code for generate dynamic checkbox for each
student row in getdata() method. After this we have create massremove() method
for delete or remove multiple data in single click. This method will receive
ajax request for delete multiple data based on selection of checkbox. You can
find whole controller code below.
<?php
namespace App\Http\Controllers;
use Validator;
use Illuminate\Http\Request;
use App\Student;
use Datatables;
class AjaxdataController
extends Controller
{
function index()
{
return view('student.ajaxdata');
//http://127.0.0:8000/ajaxdata
}
function getdata()
{
$students = Student::select('id',
'first_name', 'last_name');
return Datatables::of($students)
->addColumn('action',
function($student){
return '<a
href="#" class="btn btn-xs btn-primary edit"
id="'.$student->id.'"><i class="glyphicon
glyphicon-edit"></i> Edit</a><a href="#"
class="btn btn-xs btn-danger delete"
id="'.$student->id.'"><i class="glyphicon
glyphicon-remove"></i> Delete</a>';
})
->addColumn('checkbox',
'<input type="checkbox" name="student_checkbox[]"
class="student_checkbox" value="{{$id}}" />')
->rawColumns(['checkbox','action'])
->make(true);
}
function postdata(Request $request)
{
$validation =
Validator::make($request->all(), [
'first_name' => 'required',
'last_name' => 'required',
]);
$error_array = array();
$success_output = '';
if ($validation->fails())
{
foreach($validation->messages()->getMessages() as $field_name
=> $messages)
{
$error_array[] = $messages;
}
}
else
{
if($request->get('button_action') == "insert")
{
$student = new Student([
'first_name' =>
$request->get('first_name'),
'last_name' =>
$request->get('last_name')
]);
$student->save();
$success_output = '<div
class="alert alert-success">Data Inserted</div>';
}
if($request->get('button_action') == 'update')
{
$student =
Student::find($request->get('student_id'));
$student->first_name =
$request->get('first_name');
$student->last_name =
$request->get('last_name');
$student->save();
$success_output = '<div
class="alert alert-success">Data Updated</div>';
}
}
$output = array(
'error' =>
$error_array,
'success' =>
$success_output
);
echo json_encode($output);
}
function fetchdata(Request $request)
{
$id = $request->input('id');
$student = Student::find($id);
$output = array(
'first_name' =>
$student->first_name,
'last_name' =>
$student->last_name
);
echo json_encode($output);
}
function removedata(Request $request)
{
$student =
Student::find($request->input('id'));
if($student->delete())
{
echo 'Data Deleted';
}
}
function massremove(Request $request)
{
$student_id_array =
$request->input('id');
$student = Student::whereIn('id',
$student_id_array);
if($student->delete())
{
echo 'Data Deleted';
}
}
}
Lastly we want to set route for newly created massremove()
method in AjaxdataController.php file. So, for this we have to go to routes/web.php file.
And in this file we have set route for massremove() method.
<?php
Route::get('/', function () {
return view('welcome');
});
Route::get('ajaxdata',
'AjaxdataController@index')->name('ajaxdata');
Route::get('ajaxdata/getdata',
'AjaxdataController@getdata')->name('ajaxdata.getdata');
Route::post('ajaxdata/postdata',
'AjaxdataController@postdata')->name('ajaxdata.postdata');
Route::get('ajaxdata/fetchdata',
'AjaxdataController@fetchdata')->name('ajaxdata.fetchdata');
Route::get('ajaxdata/massremove',
'AjaxdataController@massremove')->name('ajaxdata.massremove');
So, this is complete source code for how to delete or remove
multiple or bulk records or mysql table data by using checkbox with Ajax in
Laravel. This feature is very usefull in enterprise level application.
0 Comments:
Post a Comment