Initial commit

This commit is contained in:
“VeLiTi”
2025-01-30 11:43:37 +01:00
commit 6f1cc27ec4
823 changed files with 233091 additions and 0 deletions

365
product.php Normal file
View File

@@ -0,0 +1,365 @@
<?php
// Prevent direct access to file
defined(security_key) or exit;
// Check to make sure the id parameter is specified in the URL
if (isset($_GET['id'])) {
// Prepare statement and execute, prevents SQL injection
$stmt = $pdo->prepare('SELECT * FROM products WHERE status = 1 AND (id = ? OR url_slug = ?)');
$stmt->execute([ $_GET['id'], $_GET['id'] ]);
// Fetch the product from the database and return the result as an Array
$product = $stmt->fetch(PDO::FETCH_ASSOC);
// Check if the product exists (array is not empty)
if (!$product) {
// Output simple error if the id for the product doesn't exists (array is empty)
http_response_code(404);
exit('Product does not exist!');
}
// Select the product images (if any) from the products_images table
$stmt = $pdo->prepare('SELECT m.*, pm.position FROM products_media pm JOIN media m ON m.id = pm.media_id WHERE pm.product_id = ? ORDER BY pm.position ASC');
$stmt->execute([ $product['id'] ]);
// Fetch the product images from the database and return the result as an Array
$product_media = $stmt->fetchAll(PDO::FETCH_ASSOC);
// Select the product options (if any) from the products_options table
$stmt = $pdo->prepare('SELECT CONCAT(title, "::", type, "::", required) AS k, name, quantity, price, price_modifier, weight, weight_modifier, type, id, required FROM products_options WHERE product_id = ? ORDER BY position ASC');
$stmt->execute([ $product['id'] ]);
// Fetch the product options from the database and return the result as an Array
$product_options = $stmt->fetchAll(PDO::FETCH_GROUP);
// Add the HTML meta data (for SEO purposes)
$meta = '
<meta property="og:url" content="' . url('index.php?page=product&id=' . ($product['url_slug'] ? $product['url_slug'] : $product['id'])) . '">
<meta property="og:title" content="' . $product['name'] . '">
';
if (isset($product_media[0]) && file_exists($product_media[0]['full_path'])) {
$meta .= '<meta property="og:image" content="' . base_url . $product_media[0]['full_path'] . '">';
}
// If the user clicked the add to cart button
if (isset($_POST['quantity']) && is_numeric($_POST['quantity'])) {
// abs() function will prevent minus quantity and (int) will ensure the value is an integer (number)
$quantity = abs((int)$_POST['quantity']);
// Get product options
$options = '';
$options_price = (float)$product['price'];
$options_weight = (float)$product['weight'];
// Iterate post data
foreach ($_POST as $k => $v) {
if (strpos($k, 'option-') !== false) {
if (is_array($v)) {
// Option is checkbox or radio element
foreach ($v as $vv) {
if (empty($vv)) continue;
$options .= str_replace(['_', 'option-'], [' ', ''], $k) . '-' . $vv . ',';
$stmt = $pdo->prepare('SELECT * FROM products_options WHERE title = ? AND name = ? AND product_id = ?');
$stmt->execute([ str_replace(['_', 'option-'], [' ', ''], $k), $vv, $product['id'] ]);
$option = $stmt->fetch(PDO::FETCH_ASSOC);
$options_price = $option['price_modifier'] == 'add' ? $options_price + $option['price'] : $options_price - $option['price'];
$options_weight = $option['weight_modifier'] == 'add' ? $options_weight + $option['weight'] : $options_weight - $option['weight'];
}
} else {
if (empty($v)) continue;
$options .= str_replace(['_', 'option-'], [' ', ''], $k) . '-' . $v . ',';
//------------------
//Update name otherwise option is not found
//------------------
$name_update = '%|^|'.$v;
$stmt = $pdo->prepare('SELECT * FROM products_options WHERE title = ? AND name like ? AND product_id = ?');
$stmt->execute([ str_replace(['_', 'option-'], [' ', ''], $k), $name_update, $product['id'] ]);
//------------------
// OLD CODE
//------------------
//$stmt = $pdo->prepare('SELECT * FROM products_options WHERE title = ? AND name = ? AND product_id = ?');
//$stmt->execute([ str_replace(['_', 'option-'], [' ', ''], $k), $v, $product['id'] ]);
//------------------
$option = $stmt->fetch(PDO::FETCH_ASSOC);
if (!$option) {
// Option is text or datetime element
$stmt = $pdo->prepare('SELECT * FROM products_options WHERE title = ? AND product_id = ?');
$stmt->execute([ str_replace(['_', 'option-'], [' ', ''], $k), $product['id'] ]);
$option = $stmt->fetch(PDO::FETCH_ASSOC);
}
$options_price = $option['price_modifier'] == 'add' ? $options_price + $option['price'] : $options_price - $option['price'];
$options_weight = $option['weight_modifier'] == 'add' ? $options_weight + $option['weight'] : $options_weight - $option['weight'];
}
}
}
$options_price = $options_price < 0 ? 0 : $options_price;
$options = rtrim($options, ',');
// Check if the product exists (array is not empty)
if ($quantity > 0) {
// Product exists in database, now we can create/update the session variable for the cart
if (!isset($_SESSION['cart'])) {
// Shopping cart session variable doesnt exist, create it
$_SESSION['cart'] = [];
}
$cart_product = &get_cart_product($product['id'], $options);
if ($cart_product) {
// Product exists in cart, update the quanity
$cart_product['quantity'] += $quantity;
} else {
// Product is not in cart, add it
$_SESSION['cart'][] = [
'id' => $product['id'],
'quantity' => $quantity,
'options' => $options,
'options_price' => $options_price,
'options_weight' => $options_weight,
'shipping_price' => 0.00
];
}
}
// Prevent form resubmission...
header('Location: ' . url('index.php?page=cart'));
exit;
}
} else {
// Output simple error if the id wasn't specified
http_response_code(404);
exit('Product does not exist!');
}
//get all media
$stmt = $pdo->query('SELECT id, full_path, caption FROM media');
$stmt->execute();
$media2 = $stmt->fetchAll(PDO::FETCH_ASSOC);
//LINK to products page:
$products_link = url(link_to_collection);
$product_link = url('index.php?page=product&id='.($product['url_slug'] ? $product['url_slug'] : $product['id']));
//Notifier - when 1 user ask for product notification
$notifier = 0;
if (isset($_POST["notifier"])){
$stmt = $pdo->prepare('SELECT * FROM accounts WHERE id = ?');
$stmt->execute([ $_SESSION['account_id'] ]);
$account = $stmt->fetch(PDO::FETCH_ASSOC);
$email = $account['email'];
send_product_notification_email($email, $_POST["product_details"]);
$notifier = 1;
}
//CREATE OPTION_PICTURE ARRAY FOR USE IN OPTION OVERVIEW
$option_profile = json_decode($product['product_config']) ?? '';
if (!empty($option_profile) && $option_profile !=''){
//CREATE OPTION PICTURE ARRAY
$option_picture[] = '';
foreach ($option_profile as $option){
//CHECK FOR RELATED MEDIA
foreach ($media2 as $media_item2){
if ($media_item2['id'] == $option->IMG_large_id){
$option_picture[$option->option_id] = $media_item2['full_path'];
}
}
}
}
?>
<?=template_header($product['name'], $meta)?>
<?php if ($error): ?>
<p class="content-wrapper error"><?=$error?></p>
<?php else: ?>
<div class="product content-wrapper">
<div class="product-imgs">
<?php if (isset($_GET['option_id']) && !empty($_GET['option_id']) && $_GET['option_id'] !='') : ?>
<?php
$option_profile = json_decode($product['product_config']);
foreach ($option_profile as $option){
//GET RIGHT PICTURE BASED ON SELECTED OPTION IN OVERVIEW PAGE
if ($option->option_id == $_GET['option_id']){
$IMG_large_id = $option->IMG_large_id;
foreach ($media2 as $media_item2){
if ($media_item2['id'] == $IMG_large_id){
$IMG_large_path = $media_item2['full_path'];
echo '
<div class="product-img-large">
<img src="'.$base_url.$media_item2['full_path'].'" id="'.$product['id'].'" alt="'.$media_item2['caption'].'">
</div>';
}
}
}
}
?>
<?php elseif (isset($product_media[0]) && file_exists($product_media[0]['full_path'])): ?>
<div class="product-img-large">
<img src="<?=base_url . $product_media[0]['full_path']?>" alt="<?=$product_media[0]['caption']?>">
</div>
<?php endif; ?>
<div class="product-small-imgs">
<?php
//Show small images
foreach ($product_media as $media){
if (isset($_GET['option_id']) && !empty($_GET['option_id']) && $_GET['option_id'] !='' && show_option_images != true){
$option_profile = json_decode($product['product_config']);
//create array with all option imagesIDs
$option_images = [];
foreach($option_profile as $option){
$option_images[] = $option->IMG_large_id;
}
if (in_array($media['id'], $option_images)){
//Do nothing
} else {
echo ' <div class="product-img-small '.($media['position']==1?' selected':'').'">
<img src="'.base_url.$media['full_path'].'" width="150" height="150" alt="'.$media['caption'].'">
</div>';
}
}
else {
//No Option profile - show all images
echo ' <div class="product-img-small '.($media['position']==1?' selected':'').'">
<img src="'.base_url.$media['full_path'].'" width="150" height="150" alt="'.$media['caption'].'">
</div>';
}
}
?>
</div>
</div>
<div class="product-wrapper">
<div class="breadcrum">
<a href="<?=$products_link?>"><?=$breadcrum_products?></a> <p>/ <?=$product['name']?></p>
</div>
<h1 class="name"><?=$product['name']?></h1>
<div class="prices">
<span class="price" data-price="<?=$product['price']?>"><?=currency_code?><?=number_format($product['price'],2)?></span>
<?php if ($product['rrp'] > 0): ?>
<span class="rrp"><?=currency_code?><?=number_format($product['rrp'],2)?></span>
<?php endif; ?>
</div>
<!-- On Stock indicator -->
<div class="stock">
<?php //Stock status
$stock_status = ($product['quantity'] != 0) ? $product_on_stock : $out_of_stock;
$style = ($stock_status == $product_on_stock) ? 'style="color:green;font-weight: bold;"' : 'style="color:gray;font-weight: lighter;"';
echo ' <span class="stock_product">
<p '.$style.'> '.$stock_status.' </p>
</span>';
?>
</div>
<!-- Free shipment indicator -->
<?php
if (free_shipment_indicator){
freeShipment($product['price'],'div');
}
?>
<form id="product-form" action="" method="post">
<?php foreach ($product_options as $id => $option): ?>
<?php $id = explode('::', $id); ?>
<?php if ($id[1] == 'select'): ?>
<label for="<?=$id[0]?>"><?=$id[0]?></label>
<select id="<?=$id[0]?>" class="option select" name="option-<?=$id[0]?>"<?=$id[2] ? ' required' : ''?>>
<option value="" selected disabled style="display:none"><?=$id[0]?></option>
<?php foreach ($option as $option_value): ?>
<option id="<?=$option_value['id']?>" value="<?=$option_value['name']?>" data-price="<?=$option_value['price']?>" data-modifier="<?=$option_value['price_modifier']?>"<?=$option_value['quantity']==0?' disabled':''?>><?=$option_value['name']?></option>
<?php endforeach; ?>
</select>
<?php elseif ($id[1] == 'radio'): ?>
<label for="<?=$id[0]?>"><?=$id[0]?></label>
<div class="radio-checkbox">
<?php foreach ($option as $n => $option_value): ?>
<?php //check if option has picture ID
if (str_contains($option_value['name'], '|^|')): ?>
<?php $check=explode('|^|', $option_value['name']);?>
<?php foreach ($media2 as $media_item):?>
<?php if ($media_item['id'] == $check[0]):?>
<label class="picture_select_label">
<input id="<?=$option_value['id']?>" class="option radio" value="<?=$check[1]?>" name="option-<?=$id[0]?>" type="radio" data-price="<?=$option_value['price']?>" data-modifier="<?=$option_value['price_modifier']?>">
<span class="picture_select"><img onclick="updateOption('<?=$product['id']?>','<?=url($option_picture[$option_value['id']])?>')" src="<?=url($media_item['full_path'])?>"></span>
</label>
<?php endif; ?>
<?php endforeach; ?>
<?php else: ?>
<label>
<input id="<?=$option_value['id']?>" class="option radio" value="<?=$option_value['name']?>" name="option-<?=$id[0]?>" type="radio" data-price="<?=$option_value['price']?>" data-modifier="<?=$option_value['price_modifier']?>"<?=$id[2] && $n == 0 ? ' required' : ''?><?=$option_value['quantity']==0?' disabled':''?>><?=$option_value['name']?>
</label>
<?php endif; ?>
<?php endforeach; ?>
</div>
<?php elseif ($id[1] == 'checkbox'): ?>
<label for="<?=$id[0]?>"><?=$id[0]?></label>
<div class="radio-checkbox">
<?php foreach ($option as $n => $option_value): ?>
<?php //check if option has picture ID
if (str_contains($option_value['name'], '|^|')): ?>
<?php $check=explode('|^|', $option_value['name']);?>
<?php foreach ($media2 as $media_item):?>
<?php if ($media_item['id'] == $check[0]):?>
<label class="picture_select_label">
<input id="<?=$option_value['id']?>" class="option checkbox" id="<?=$option_value['id']?>" value="<?=$check[1]?>" name="option-<?=$id[0]?>[]" type="checkbox" data-price="<?=$option_value['price']?>" data-modifier="<?=$option_value['price_modifier']?>"<?=$id[2] && $n == 0 ? ' required' : ''?><?=$option_value['quantity']==0?' disabled':''?>>
<span class="picture_select"><img src="<?=$media_item['full_path']?>"></span>
</label>
<?php endif; ?>
<?php endforeach; ?>
<?php else: ?>
<label>
<input id="<?=$option_value['id']?>" class="option checkbox" id="<?=$option_value['id']?>" value="<?=$option_value['name']?>" name="option-<?=$id[0]?>[]" type="checkbox" data-price="<?=$option_value['price']?>" data-modifier="<?=$option_value['price_modifier']?>"<?=$id[2] && $n == 0 ? ' required' : ''?><?=$option_value['quantity']==0?' disabled':''?>><?=$option_value['name']?>
</label>
<?php endif; ?>
<?php endforeach; ?>
</div>
<?php elseif ($id[1] == 'text'): ?>
<?php foreach ($option as $option_value): ?>
<label for="<?=$id[0]?>"><?=$id[0]?></label>
<input id="<?=$id[0]?>" class="option text" name="option-<?=$id[0]?>" type="text" placeholder="<?=$option_value['name']?>" data-price="<?=$option_value['price']?>" data-modifier="<?=$option_value['price_modifier']?>"<?=$id[2] ? ' required' : ''?><?=$option_value['quantity']==0?' disabled':''?>>
<?php endforeach; ?>
<?php elseif ($id[1] == 'datetime'): ?>
<?php foreach ($option as $option_value): ?>
<label for="<?=$id[0]?>"><?=$id[0]?></label>
<input id="<?=$id[0]?>" class="option datetime" name="option-<?=$id[0]?>" type="datetime-local"<?=$option_value['name'] ? 'value="' . date('Y-m-d\TH:i', strtotime($product['date_added'])) . '" ' : ''?> data-price="<?=$option_value['price']?>" data-modifier="<?=$option_value['price_modifier']?>"<?=$id[2] ? ' required' : ''?><?=$option_value['quantity']==0?' disabled':''?>>
<?php endforeach; ?>
<?php endif; ?>
<?php endforeach; ?>
<?php if ($product['quantity'] == 0): ?>
<?php if ((isset($_SESSION['account_loggedin'])) && $notifier == 0) :?>
<input type="hidden" value="1" name="notifier">
<input type="hidden" value="<?=$product['id'].' - '.$product['name']?>" name="product_details">
<input type="submit" value="<?=$out_of_stock_notify?>" class="btn">
<?php elseif (link_to_external_product_site != ''): ?>
<a href="<?= link_to_external_product_site ?>" style="text-align: center;font-style: italic;" class="btn" target="blank"><?=$out_of_stock_notify_2?></a>
<?php else: ?>
<label for="quantity"><?=$product_quantity?></label>
<input id="quantity" type="number" name="quantity" value="1" min="1"<?php if ($product['quantity'] != -1): ?> max="<?=$product['quantity']?>"<?php endif; ?> placeholder="Quantity" required>
<input type="submit" value="<?=$out_of_stock?>" class="btn" disabled>
<?php endif; ?>
<?php else: ?>
<label for="quantity"><?=$product_quantity?></label>
<input id="quantity" type="number" name="quantity" value="1" min="1"<?php if ($product['quantity'] != -1): ?> max="<?=$product['quantity']?>"<?php endif; ?> placeholder="Quantity" required>
<input type="submit" value="<?=$add_to_basket?>" class="btn">
<?php endif; ?>
</form>
<div class="description">
<?=$product['description']?>
</div>
</div>
</div>
<?php endif; ?>
<script>
//Read urlstring
const queryString = window.location.href;
const option_id = queryString.substring(queryString.lastIndexOf('/') + 1)
console.log(queryString)
//Check for option_id
if (option_id != ''){
document.getElementById(option_id).checked = true;
}
</script>
<?=template_footer()?>