From 2ce36cb14fc99d3a4b78d4841727eecb96ab78f3 Mon Sep 17 00:00:00 2001 From: johnnyq Date: Mon, 10 Jun 2024 17:26:43 -0400 Subject: [PATCH] Added Bulk Edit Category, Archive, Unarchive and Delete to Products --- post/product.php | 169 +++++++++++++++++++ product_bulk_edit_category_modal.php | 42 +++++ products.php | 235 +++++++++++++++------------ 3 files changed, 344 insertions(+), 102 deletions(-) create mode 100644 product_bulk_edit_category_modal.php diff --git a/post/product.php b/post/product.php index ae7ee71b..5fbde323 100644 --- a/post/product.php +++ b/post/product.php @@ -65,6 +65,28 @@ if (isset($_GET['archive_product'])) { } +if (isset($_GET['unarchive_product'])) { + + validateTechRole(); + + $product_id = intval($_GET['unarchive_product']); + + // Get Contact Name and Client ID for logging and alert message + $sql = mysqli_query($mysqli,"SELECT product_name FROM products WHERE product_id = $product_id"); + $row = mysqli_fetch_array($sql); + $product_name = sanitizeInput($row['product_name']); + + mysqli_query($mysqli,"UPDATE products SET product_archived_at = NULL WHERE product_id = $product_id"); + + //logging + mysqli_query($mysqli,"INSERT INTO logs SET log_type = 'Product', log_action = 'Unarchive', log_description = '$session_name restored product $product_name', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id, log_entity_id = $product_id"); + + $_SESSION['alert_message'] = "Product $product_name restored"; + + header("Location: " . $_SERVER["HTTP_REFERER"]); + +} + if (isset($_GET['delete_product'])) { $product_id = intval($_GET['delete_product']); @@ -85,6 +107,153 @@ if (isset($_GET['delete_product'])) { } +if (isset($_POST['bulk_edit_product_category'])) { + + $category_id = intval($_POST['bulk_category_id']); + + // Get Category name for logging and Notification + $sql = mysqli_query($mysqli,"SELECT category_name FROM categories WHERE category_id = $category_id"); + $row = mysqli_fetch_array($sql); + $category_name = sanitizeInput($row['category_name']); + + // Get Count + $count = count($_POST['product_ids']); + + // Assign category to Selected Products + if (!empty($_POST['product_ids'])) { + foreach($_POST['product_ids'] as $product_id) { + $product_id = intval($product_id); + + // Get Product Details for Logging + $sql = mysqli_query($mysqli,"SELECT product_name FROM products WHERE product_id = $product_id"); + $row = mysqli_fetch_array($sql); + $product_name = sanitizeInput($row['product_name']); + + mysqli_query($mysqli,"UPDATE products SET product_category_id = $category_id WHERE product_id = $product_id"); + + //Logging + mysqli_query($mysqli,"INSERT INTO logs SET log_type = 'Product', log_action = 'Edit', log_description = '$session_name assigned $product_name to income category $category_name', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id, log_entity_id = $product_id"); + + } // End Assign Product Loop + + $_SESSION['alert_message'] = "You assigned product category $category_name to $count products"; + } + + header("Location: " . $_SERVER["HTTP_REFERER"]); +} + +if (isset($_POST['bulk_archive_products'])) { + validateAdminRole(); + validateCSRFToken($_POST['csrf_token']); + + $count = 0; // Default 0 + $product_ids = $_POST['product_ids']; // Get array of IDs to be deleted + + if (!empty($product_ids)) { + + // Cycle through array and archive each record + foreach ($product_ids as $product_id) { + + $product_id = intval($product_id); + + // Get Name and Client ID for logging and alert message + $sql = mysqli_query($mysqli,"SELECT product_name FROM products WHERE product_id = $product_id"); + $row = mysqli_fetch_array($sql); + $product_name = sanitizeInput($row['product_name']); + + mysqli_query($mysqli,"UPDATE products SET product_archived_at = NOW() WHERE product_id = $product_id"); + + // Individual Contact logging + mysqli_query($mysqli,"INSERT INTO logs SET log_type = 'Product', log_action = 'Archive', log_description = '$session_name archived product $product_name', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id, log_entity_id = $product_id"); + $count++; + } + + // Bulk Logging + mysqli_query($mysqli, "INSERT INTO logs SET log_type = 'Product', log_action = 'Bulk Archive', log_description = '$session_name archived $count products', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id"); + + $_SESSION['alert_type'] = "error"; + $_SESSION['alert_message'] = "Archived $count product(s)"; + + } + + header("Location: " . $_SERVER["HTTP_REFERER"]); +} + +if (isset($_POST['bulk_unarchive_products'])) { + validateAdminRole(); + validateCSRFToken($_POST['csrf_token']); + + $count = 0; // Default 0 + $product_ids = $_POST['product_ids']; // Get array of IDs + + if (!empty($product_ids)) { + + // Cycle through array and unarchive + foreach ($product_ids as $product_id) { + + $product_id = intval($product_id); + + // Get Name and Client ID for logging and alert message + $sql = mysqli_query($mysqli,"SELECT product_name FROM products WHERE product_id = $product_id"); + $row = mysqli_fetch_array($sql); + $product_name = sanitizeInput($row['product_name']); + + mysqli_query($mysqli,"UPDATE products SET product_archived_at = NULL WHERE product_id = $product_id"); + + // Individual logging + mysqli_query($mysqli,"INSERT INTO logs SET log_type = 'Product', log_action = 'Unarchive', log_description = '$session_name Unarchived product $product_name', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id, log_entity_id = $product_id"); + + + $count++; + } + + // Bulk Logging + mysqli_query($mysqli, "INSERT INTO logs SET log_type = 'Product', log_action = 'Unarchive', log_description = '$session_name Unarchived $count products', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id"); + + $_SESSION['alert_message'] = "Unarchived $count product(s)"; + + } + + header("Location: " . $_SERVER["HTTP_REFERER"]); +} + +if (isset($_POST['bulk_delete_products'])) { + validateAdminRole(); + validateCSRFToken($_POST['csrf_token']); + + $count = 0; // Default 0 + $product_ids = $_POST['product_ids']; // Get array of IDs to be deleted + + if (!empty($product_ids)) { + + // Cycle through array and delete each record + foreach ($product_ids as $product_id) { + + $product_id = intval($product_id); + + // Get Name and Client ID for logging and alert message + $sql = mysqli_query($mysqli,"SELECT product_name FROM products WHERE product_id = $product_id"); + $row = mysqli_fetch_array($sql); + $product_name = sanitizeInput($row['product_name']); + + mysqli_query($mysqli, "DELETE FROM products WHERE product_id = $product_id"); + + mysqli_query($mysqli, "INSERT INTO logs SET log_type = 'Product', log_action = 'Delete', log_description = '$session_name deleted product $product_name', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id, log_entity_id = $product_id"); + + $count++; + } + + // Logging + mysqli_query($mysqli, "INSERT INTO logs SET log_type = 'Product', log_action = 'Bulk Delete', log_description = '$session_name bulk deleted $count products', log_ip = '$session_ip', log_user_agent = '$session_user_agent', log_user_id = $session_user_id"); + + $_SESSION['alert_message'] = "Deleted $count product(s)"; + + } + + header("Location: " . $_SERVER["HTTP_REFERER"]); + exit(); +} + if (isset($_POST['export_products_csv'])) { //get records from database diff --git a/product_bulk_edit_category_modal.php b/product_bulk_edit_category_modal.php new file mode 100644 index 00000000..4222ee69 --- /dev/null +++ b/product_bulk_edit_category_modal.php @@ -0,0 +1,42 @@ + diff --git a/products.php b/products.php index f0e8557d..1f5e966b 100644 --- a/products.php +++ b/products.php @@ -84,130 +84,161 @@ $num_rows = mysqli_fetch_row(mysqli_query($mysqli, "SELECT FOUND_ROWS()"));
-
- "> - Archived - -
-
-
- - "> - - - - - - - - - - - - - $product_description"; - } - $product_price = floatval($row['product_price']); - $product_currency_code = nullable_htmlentities($row['product_currency_code']); - $product_created_at = nullable_htmlentities($row['product_created_at']); - $category_id = intval($row['category_id']); - $category_name = nullable_htmlentities($row['category_name']); - $product_tax_id = intval($row['product_tax_id']); - $tax_name = nullable_htmlentities($row['tax_name']); - if (empty($tax_name)) { - $tax_name_display = "-"; - } else { - $tax_name_display = $tax_name; - } - $tax_percent = floatval($row['tax_percent']); - - - ?> + + +
+
NameCategoryDescriptionTax NameTax RatePriceAction
+ "> - - - - - - - - + + + + + + + + - + + $product_description"; + } + $product_price = floatval($row['product_price']); + $product_currency_code = nullable_htmlentities($row['product_currency_code']); + $product_created_at = nullable_htmlentities($row['product_created_at']); + $product_archived_at = nullable_htmlentities($row['product_archived_at']); + $category_id = intval($row['category_id']); + $category_name = nullable_htmlentities($row['category_name']); + $product_tax_id = intval($row['product_tax_id']); + $tax_name = nullable_htmlentities($row['tax_name']); + if (empty($tax_name)) { + $tax_name_display = "-"; + } else { + $tax_name_display = $tax_name; + } + $tax_percent = floatval($row['tax_percent']); - } + ?> + + + + + + + + + + + - ?> + -
% - +
+
NameCategoryDescriptionTax NameTax RatePriceAction
+
+ +
+
% + +
-
+ require "product_edit_modal.php"; + + + } + + ?> + + + + + + + +