hitro dodajanje vozila

This commit is contained in:
David Štaleker
2023-07-24 09:11:14 +02:00
parent facfb3a726
commit dcc0fde1ba
8 changed files with 523 additions and 85 deletions

View File

@@ -17,7 +17,7 @@
<form method="get">
<div class="btn-group">
<input class="form-control" type="text" name="searchString" value="@ViewData["SearchString"]" placeholder="Iskanje..." autocomplete="off">
<button type="submit" class="btn btn-secondary" aria-label="Osveži" title="Osveži" asp-route-type="@ViewData["Type"]">
<button id="btnSubmit" type="submit" class="btn btn-secondary" aria-label="Osveži" title="Osveži" asp-route-type="@ViewData["Type"]">
<i class="opacity-75 ion ion-md-refresh"></i>
</button>
<div class="btn-group" title="Columns">
@@ -41,98 +41,76 @@
<table class="table card-table">
<thead>
<tr>
@*<th style="width: 200px;">#</th>*@
<th style="width: auto;">
@Html.DisplayNameFor(modelItem => modelItem.Vehicles[0].Title)
</th>
<th style="width: auto;">
@Html.DisplayNameFor(modelItem => modelItem.Vehicles[0].RegistrationNumber)
</th>
<th style="width: 100px">
@Html.DisplayNameFor(modelItem => modelItem.Vehicles[0].Active)
</th>
<th style="width: 120px;"></th>
</tr>
<tr>
@*<th style="width: 200px;">#</th>*@
<th style="width: auto;">
@Html.DisplayNameFor(modelItem => modelItem.Vehicles[0].Title)
</th>
<th style="width: auto;">
@Html.DisplayNameFor(modelItem => modelItem.Vehicles[0].RegistrationNumber)
</th>
<th style="width: 100px">
@Html.DisplayNameFor(modelItem => modelItem.Vehicles[0].Active)
</th>
<th style="width: 120px;"></th>
</tr>
</thead>
<tbody>
@foreach (var item in Model.Vehicles)
{
<tr data-idvehicle="@item.IdVehicle">
<td>
@Html.DisplayFor(modelItem => item.Title)
</td>
<td>
@Html.DisplayFor(modelItem => item.RegistrationNumber)
</td>
<td>
@Html.DisplayFor(modelItem => item.Active)
</td>
<td>
<a class="btn btn-xs icon-btn btn-outline-secondary borderless" asp-page="CreateEdit" asp-route-edit="true" asp-route-id="@item.IdVehicle" data-toggle="tooltip" data-placement="top" title="Urejanje" data-state="secondary"><i class="fas fa-pencil-alt"></i></a>
<a class="btn btn-xs icon-btn btn-outline-danger borderless" data-state="danger" href='javascript:;' onclick="deleteVehicle(this)"><i class="fas fa-times"></i></a>
</td>
</tr>
}
@foreach (var item in Model.Vehicles)
{
<tr data-idvehicle="@item.IdVehicle">
<td>
@Html.DisplayFor(modelItem => item.Title)
</td>
<td>
@Html.DisplayFor(modelItem => item.RegistrationNumber)
</td>
<td>
@Html.DisplayFor(modelItem => item.Active)
</td>
<td>
<a class="btn btn-xs icon-btn btn-outline-secondary borderless" href="Javascript:;" onclick="editCodeTableVehicle(this)" data-toggle="tooltip" data-placement="top" title="Urejanje" data-state="secondary"><i class="fas fa-pencil-alt"></i></a>
<a class="btn btn-xs icon-btn btn-outline-danger borderless" data-state="danger" href='javascript:;' onclick="deleteCodeTableVehicle(this)"><i class="fas fa-times"></i></a>
</td>
</tr>
}
</tbody>
</table>
<div class="card-footer py-3 text-right">
<a asp-page="CreateEdit" asp-route-edit="false" class="btn btn-primary">Vnos novega</a>
<a href="Javascript:;" onclick="addNewCodeTableVehicle();" class="btn btn-primary">Vnos novega</a>
</div>
</div>
<div id="divModalCodetableVehicleAddEditPlaceholder"></div>
@Html.AntiForgeryToken()
@section Scripts {
<script src="~/vendor/libs/select2/select2.js" asp-append-version="true"></script>
<script src="~/js/codeTableVehicleHelper.js?v=1" asp-append-version="true"></script>
<script>
$('[data-toggle="tooltip"]').tooltip({ container: 'table' });
function deleteVehicle(element) {
function addNewCodeTableVehicle() {
codeTableVehicleAddEdit('#divModalCodetableVehicleAddEditPlaceholder', false, null, (idCodeTableItem) => {
document.getElementById('btnSubmit').click();
});
}
function editCodeTableVehicle(element) {
let idVehicle = parseInt($(element).parent().parent().attr('data-idvehicle'));
codeTableVehicleAddEdit('#divModalCodetableVehicleAddEditPlaceholder', true, idVehicle, (idVehicle) => {
document.getElementById('btnSubmit').click();
});
}
function deleteCodeTableVehicle(element) {
let row = $(element).parent().parent();
let idInvoice = $(row).attr('data-idinvoice');
let invoiceNumber = $(row).attr('data-number');
let idVehicle = parseInt(row.attr('data-idvehicle'));
Swal.fire({
title: `Izbrišem dokument ${invoiceNumber}?`,
text: "Tega dejanja ni možno razveljaviti!",
icon: 'warning',
showCancelButton: true,
confirmButtonColor: '#3085d6',
cancelButtonColor: '#d33',
confirmButtonText: 'Da, izbriši!',
cancelButtonText: 'Prekliči!'
}).then((result) => {
if (result.isConfirmed) {
$.blockUI();
$.ajax({
type: "DELETE",
beforeSend: function (xhr) {
xhr.setRequestHeader("XSRF-TOKEN",
$('input:hidden[name="__RequestVerificationToken"]').val());
},
url: "/Invoices/Index/?handler=Invoice",
data: {
idInvoice
},
success: function (data) {
$.unblockUI();
if (data.successful) {
$(row).remove();
} else {
console.log(data);
Swal.fire('Napaka pri brisanju dokumenta',
data.error,
'error');
}
},
error: function (xhr, ajaxOptions, thrownError) {
console.log(xhr);
alert(xhr.responseText);
$.unblockUI();
}
});
}
codeTableVehicleDelete(idVehicle, (idVehicle) => {
row.remove();
});
}
</script>