recurring item sort logic

This commit is contained in:
o-psi
2023-10-15 22:14:24 -05:00
parent b04dd98370
commit 47db00e90c
+23 -43
View File
@@ -247,6 +247,7 @@ if (isset($_POST['add_recurring_item'])) {
$qty = floatval($_POST['qty']); $qty = floatval($_POST['qty']);
$price = floatval($_POST['price']); $price = floatval($_POST['price']);
$tax_id = intval($_POST['tax_id']); $tax_id = intval($_POST['tax_id']);
$item_order = intval($_POST['item_order']);
$subtotal = $price * $qty; $subtotal = $price * $qty;
@@ -261,7 +262,7 @@ if (isset($_POST['add_recurring_item'])) {
$total = $subtotal + $tax_amount; $total = $subtotal + $tax_amount;
mysqli_query($mysqli,"INSERT INTO invoice_items SET item_name = '$name', item_description = '$description', item_quantity = $qty, item_price = $price, item_subtotal = $subtotal, item_tax = $tax_amount, item_total = $total, item_tax_id = $tax_id, item_recurring_id = $recurring_id"); mysqli_query($mysqli,"INSERT INTO invoice_items SET item_name = '$name', item_description = '$description', item_quantity = $qty, item_price = $price, item_subtotal = $subtotal, item_tax = $tax_amount, item_total = $total, item_tax_id = $tax_id, item_order = $item_order, item_recurring_id = $recurring_id");
//Update Recurring Balances //Update Recurring Balances
@@ -1085,59 +1086,38 @@ if (isset($_POST['export_client_payments_csv'])) {
} }
if (isset($_POST['update_invoice_item_order'])) { if (isset($_POST['update_recurring_item_order'])) {
if ($_POST['update_invoice_item_order'] == 'up') {
$item_id = intval($_POST['item_id']); $item_id = intval($_POST['item_id']);
$item_invoice_id = intval($_POST['item_invoice_id']); $item_recurring_id = intval($_POST['item_recurring_id']);
$sql = mysqli_query($mysqli,"SELECT * FROM invoice_items WHERE item_id = $item_id"); $sql = mysqli_query($mysqli,"SELECT * FROM invoice_items WHERE item_id = $item_id");
$row = mysqli_fetch_array($sql); $row = mysqli_fetch_array($sql);
$item_order = intval($row['item_order']); $current_order = intval($row['item_order']);
$update_direction = sanitizeInput($_POST['update_recurring_item_order']);
$new_item_order = $item_order - 1; switch ($update_direction)
{
//Check if new item order is used case 'up':
$sql = mysqli_query($mysqli,"SELECT * FROM invoice_items WHERE item_invoice_id = $item_invoice_id AND item_order = $new_item_order"); $new_order = $current_order - 1;
break;
//Redo the entire order of list case 'down':
while ($row = mysqli_fetch_array($sql)) { $new_order = $current_order + 1;
$item_id = intval($row['item_id']); break;
$item_order = intval($row['item_order']);
$new_item_order = $item_order + 1;
mysqli_query($mysqli,"UPDATE invoice_items SET item_order = $new_item_order WHERE item_id = $item_id");
} }
//Find item_id of current item in $new_order
$other_sql = mysqli_query($mysqli,"SELECT * FROM invoice_items WHERE item_recurring_id = $item_recurring_id AND item_order = $new_order");
$other_row = mysqli_fetch_array($other_sql);
$other_item_id = intval($other_row['item_id']);
$other_row_str = strval($other_row['item_name']);
mysqli_query($mysqli,"UPDATE invoice_items SET item_order = $new_order WHERE item_id = $item_id");
mysqli_query($mysqli,"UPDATE invoice_items SET item_order = $item_order WHERE item_invoice_id = $item_invoice_id AND item_order = $new_item_order"); mysqli_query($mysqli,"UPDATE invoice_items SET item_order = $current_order WHERE item_id = $other_item_id");
mysqli_query($mysqli,"UPDATE invoice_items SET item_order = $new_item_order WHERE item_id = $item_id");
$_SESSION['alert_message'] = "Item moved up"; $_SESSION['alert_message'] = "recurring Item Order Updated";
header("Location: " . $_SERVER["HTTP_REFERER"]); header("Location: " . $_SERVER["HTTP_REFERER"]);
}
if ($_POST['update_invoice_item_order'] == 'down') {
$item_id = intval($_POST['item_id']);
$item_invoice_id = intval($_POST['item_invoice_id']);
$sql = mysqli_query($mysqli,"SELECT * FROM invoice_items WHERE item_id = $item_id");
$row = mysqli_fetch_array($sql);
$item_order = intval($row['item_order']);
$new_item_order = $item_order + 1;
mysqli_query($mysqli,"UPDATE invoice_items SET item_order = $item_order WHERE item_invoice_id = $item_invoice_id AND item_order = $new_item_order");
mysqli_query($mysqli,"UPDATE invoice_items SET item_order = $new_item_order WHERE item_id = $item_id");
$_SESSION['alert_message'] = "Item moved down";
header("Location: " . $_SERVER["HTTP_REFERER"]);
}
} }