Я работаю над старым laravel проектом, и мне нужно изменить существующий. Поэтому я сейчас пытаюсь понять код. Проект на laravel и yajra datatable. Я не могу понять, как работает функция уничтожения? В представлении нет вызова функции уничтожения, но когда я нажимаю кнопку удаления, она все еще работает.
Контроллер
public function loadSizes()
{
$sizes = Size::select(['id', 'name', 'code'])->get();
return DataTables::of($sizes)
->addColumn('action', function ($size) {
return '<a href="' . url('/sizes/' . $size->id . '/edit') . '" class="btn btn-default edit_btn_styles" data-toggle="tooltip" data-placement="top" title="Update"><i class="fa fa-wrench" aria-hidden="true"></i></a>
<button type="button" data-id="' . $size->id . '" class="btn btn-default remove-size remove-btn" data-toggle="tooltip" data-placement="top" title="Delete"><i class="fas fa-trash-alt" aria-hidden="true"></i></button>';
})
->rawColumns(['action'])
->make(true);
}
public function destory(Request $request)
{
$result = Size::where('id', $request->input('size_id'))->delete();
if ($result) {
return "SUCCESS";
} else {
return "FAIL";
}
}
view
@extends('layouts.sidebar')
@section('content')
<div class="row">
<div class="col-sm-12 pad-main">
<div class="row">
<div class="col-md-6">
<h4 class="cat-name"> Size List</h4>
</div>
</div>
<div class="row">
<div class="col-md-12 table-responsive pad-tbl">
<table class="table table-striped" id="size_table">
<thead>
<tr>
<th scope="col"> Name</th>
<th scope="col"> Code</th>
<th scope="col"> Action</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
</div>
@if (Session::has('action'))
@if (Session::get('action') == "create")
@if (Session::has('status_success'))
<script > showAlert("SUCCESS", "Size creation successful");</script >
@elseif(Session::has('status_error')))
<script > showAlert("FAIL", "Size creation fail");</script >
@endif
@elseif(Session::get('action') == "update")
@if (Session::has('status_success'))
<script > showAlert("SUCCESS", "Size update successful");</script >
@elseif(Session::has('status_error')))
<script > showAlert("FAIL", "Size update fail");</script >
@endif
@endif
@endif
<script>
$(document).ready(function () {
$('#size_table').DataTable({
language: {
searchPlaceholder: "Search records"
},
"columnDefs": [
{"className": "dt-center", "targets": "_all"}
],
processing: true,
serverSide: true,
ajax: '{!! url(' / load - sizes') !!}',
columns: [
{data: 'name', name: 'name'},
{data: 'code', name: 'code'},
{data: 'action', name: 'action'},
]
});
});
$(document.body).on("click", ".remove-size", function () {
var size_id = $(this).data('id');
showConfirm("DELETE", "Do you want to delete this Size ?", "deleteSize(" + size_id + ")");
});
function deleteSize(id) {
$.ajax({
type: 'get',
url: '{!! url('delete-size') !!}',
data: {size_id: id},
success: function (data) {
if (data == "SUCCESS") {
$('[data-id="' + id + '"]').closest('tr').remove();
showAlert("SUCCESS", "Delete Size successful");
}
}, error: function (data) {
showAlert("FAIL", "Delete Size fail");
}
});
}
</script>
@endsection