Spaces:
Sleeping
Sleeping
<html lang="en"> | |
<head> | |
<meta charset="UTF-8"> | |
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> | |
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css"> | |
<title>Order History</title> | |
<style> | |
/* Reset padding and margin for all elements */ | |
* { | |
margin: 0; | |
padding: 0; | |
box-sizing: border-box; | |
} | |
body { | |
font-family: Arial, sans-serif; | |
background-color: #fdf4e3; /* Light orange background for the whole page */ | |
margin: 0; | |
padding: 0; | |
} | |
/* Top orange bar */ | |
.top-bar { | |
background-color: #FF6F3C; | |
width: 100%; | |
padding: 10px 15px; | |
display: flex; | |
align-items: center; | |
box-sizing: border-box; | |
} | |
.back-link { | |
display: flex; | |
align-items: center; | |
text-decoration: none; | |
} | |
.back-arrow { | |
font-size: 1.8rem; | |
color: #000; /* Dark black */ | |
font-weight: bold; | |
} | |
.back-label { | |
margin-left: 10px; | |
color: white; | |
font-weight: bold; | |
font-size: 1rem; | |
} | |
h1 { | |
color: #1C1C1C; | |
font-size: 1.2rem; | |
margin: 30px 0 15px; /* Default margin for larger screens */ | |
text-align: center; | |
} | |
/* Title Styling: Dark Black, Centered, and Larger Size */ | |
.order-heading { | |
color: #000; /* Dark black color */ | |
font-size: 2.5rem; /* Larger font size for desktop */ | |
font-weight: bold; | |
text-align: center; | |
margin-top: 30px; /* Spacing from the top */ | |
} | |
/* Light Orange Background for the back-side */ | |
.background { | |
padding: 8vw 0; | |
position: relative; | |
} | |
/* Container */ | |
.container { | |
width: 85%; /* Decreased width for smaller template size */ | |
max-width: 450px; /* Reduced max-width */ | |
margin: 30px auto 0; /* Added margin-top to push content down */ | |
padding: 15px; | |
background-color: white; | |
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); | |
border-radius: 8px; | |
} | |
.order-item { | |
padding: 12px; | |
border: 1px solid #6c757d; | |
margin-bottom: 12px; | |
border-radius: 5px; | |
} | |
.order-details { | |
font-size: 14px; | |
font-weight: bold; | |
color: black; | |
} | |
.order-details p { | |
margin: 4px 0; | |
} | |
.order-date-time { | |
font-size: 11px; | |
color: black; | |
} | |
.order-price { | |
font-size: 13px; | |
font-weight: bold; | |
color: black; | |
margin: 5px 0; | |
} | |
.order-status { | |
font-size: 11px; | |
font-weight: bold; | |
margin-top: 6px; | |
} | |
.order-status.pending { | |
color: green; | |
} | |
.order-status.completed { | |
color: #28a745; | |
} | |
.order-buttons { | |
margin-top: 6px; | |
} | |
.reorder-btn, .rate-order-btn { | |
background-color: #ff7f00; | |
color: white; | |
border: none; | |
padding: 6px 12px; | |
margin-right: 8px; | |
cursor: pointer; | |
border-radius: 4px; | |
} | |
.reorder-btn:hover, .rate-order-btn:hover { | |
background-color: #f55b00; | |
} | |
.total-price { | |
font-size: 14px; | |
font-weight: bold; | |
color: #333; | |
margin-top: 15px; | |
} | |
.show-more-btn { | |
background-color: #ff7f00; | |
color: white; | |
padding: 10px 20px; | |
border: none; | |
cursor: pointer; | |
border-radius: 4px; | |
margin-top: 20px; | |
font-weight: bold; | |
} | |
.show-more-btn:hover { | |
background-color: #f55b00; | |
} | |
/* Responsive design adjustments */ | |
@media (max-width: 480px) { | |
.container { | |
width: 90%; | |
margin: 30px auto 0; | |
padding: 10px; | |
} | |
.order-details { | |
font-size: 12px; | |
} | |
.order-price { | |
font-size: 12px; | |
} | |
.order-status { | |
font-size: 10px; | |
} | |
.order-heading { | |
font-size: 1.8rem; /* Smaller font size for mobile */ | |
} | |
.show-more-btn { | |
padding: 6px 12px; | |
} | |
.back-button { | |
padding: 6px 12px; /* Smaller padding for the button in mobile view */ | |
font-size: 0.9rem; /* Smaller font size for mobile */ | |
} | |
} | |
</style> | |
</head> | |
<body> | |
<!-- Top Orange Label Bar --> | |
<div class="top-bar"> | |
<a href="/menu" class="back-link"> | |
<span class="back-arrow">⟨</span> | |
<span class="back-label">Back to Menu</span> | |
</a> | |
</div> | |
<!-- Order History Title (centered and dark black) --> | |
<div class="order-heading">Order History</div> | |
<!-- Background container with light orange --> | |
<div class="background"> | |
<div class="container"> | |
<!-- Loop through the orders (first 3) --> | |
{% for order in orders[:3] %} | |
<div class="order-item"> | |
<div class="order-details"> | |
<p>{{ order.formatted_items }}</p> | |
</div> | |
<div class="order-date-time"> | |
<p>{{ order.formatted_date }}</p> | |
</div> | |
<div class="order-price"> | |
<p>Total: ${{ order.Total_Bill__c }}</p> | |
</div> | |
<div class="order-status {% if order.order_status == 'Pending' %}pending{% else %}completed{% endif %}"> | |
<p>Status: {{ order.order_status }}</p> | |
</div> | |
</div> | |
{% endfor %} | |
<!-- Loop through the remaining orders (hidden initially) --> | |
<div class="more-orders" id="more-orders"> | |
{% for order in orders[3:] %} | |
<div class="order-item"> | |
<div class="order-details"> | |
<p>{{ order.formatted_items }}</p> | |
</div> | |
<div class="order-date-time"> | |
<p>Order Placed: {{ order.formatted_date }}</p> | |
</div> | |
<div class="order-price"> | |
<p>Total: ${{ order.Total_Bill__c }}</p> | |
</div> | |
<div class="order-status {% if order.order_status == 'Pending' %}pending{% else %}completed{% endif %}"> | |
<p>Status: {{ order.order_status }}</p> | |
</div> | |
</div> | |
{% endfor %} | |
</div> | |
<!-- Show More button --> | |
{% if orders|length > 3 %} | |
<button class="show-more-btn" onclick="toggleOrders()">Show More</button> | |
{% endif %} | |
<!-- If no orders exist --> | |
{% if not orders %} | |
<div class="no-orders"> | |
<p>No orders found.</p> | |
</div> | |
{% endif %} | |
</div> | |
</div> | |
<script> | |
// Function to toggle between Show More and Show Less | |
function toggleOrders() { | |
const moreOrders = document.getElementById("more-orders"); | |
const button = document.querySelector(".show-more-btn"); | |
if (moreOrders.style.display === "none") { | |
moreOrders.style.display = "block"; | |
button.innerHTML = "Show Less"; // Change button text | |
} else { | |
moreOrders.style.display = "none"; | |
button.innerHTML = "Show More"; // Change button text back | |
} | |
} | |
</script> | |
</body> | |
</html> | |