Compare commits

..

No commits in common. "a19c082d9a347a8121a0158c0c1465597a21c859" and "e7fda0497e8a38a91c4c6e5c93b0206862c34488" have entirely different histories.

4 changed files with 52 additions and 75 deletions

View File

@ -10,17 +10,13 @@ type ProductDetailsProps = {
};
const ProductDetails: React.FC<ProductDetailsProps> = ({ product, category }) => {
const [selectedOption, setSelectedOption] = useState<ProductOption>(
product.options?.[0] || { name: product.name, price: 0 }
);
const [selectedOption, setSelectedOption] = useState<ProductOption>(product.options[0]);
const [quantity, setQuantity] = useState(1);
const { addToCart } = useCart();
const navigate = useNavigate();
// Use a safer approach for options
const options = product.options || [];
const hasSamePrice = options.length > 0 &&
options.every(option => option.price === options[0].price);
// Check if all options have the same price
const hasSamePrice = product.options.every(option => option.price === product.options[0].price);
const handleAddToCart = () => {
addToCart({
@ -34,29 +30,29 @@ const ProductDetails: React.FC<ProductDetailsProps> = ({ product, category }) =>
};
return (
<div className="product-details">
<div
className="product-details"
>
<h2>{product.name}</h2>
{options.length > 0 && (
<div className="options-list">
<h3>Optionen:</h3>
{options.map(option => (
<div
key={option.name}
className={`option-item ${selectedOption.name === option.name ? 'selected' : ''}`}
onClick={() => setSelectedOption(option)}
style={(option.color || product.color) ?
{ backgroundColor: `${option.color || product.color}60` } : {}}
>
<span>{option.name}</span>
{!hasSamePrice && <span className="option-price">{option.price.toFixed(2)} </span>}
</div>
))}
{hasSamePrice && (
<div className="uniform-price">Preis: {options[0].price.toFixed(2)} </div>
)}
</div>
)}
<div className="options-list">
<h3>Optionen:</h3>
{product.options.map(option => (
<div
key={option.name}
className={`option-item ${selectedOption.name === option.name ? 'selected' : ''}`}
onClick={() => setSelectedOption(option)}
style={(option.color || product.color) ?
{ backgroundColor: `${option.color || product.color}60` } : {}}
>
<span>{option.name}</span>
{!hasSamePrice && <span className="option-price">{option.price.toFixed(2)} </span>}
</div>
))}
{hasSamePrice && (
<div className="uniform-price">Preis: {product.options[0].price.toFixed(2)} </div>
)}
</div>
<div className="quantity-controls">
<h3>Menge:</h3>

View File

@ -1,7 +1,6 @@
import React from 'react';
import { Product } from '../types/types';
import { Link } from 'react-router-dom';
import { useCart } from '../contexts/CartContext';
import './ProductList.css';
type ProductListProps = {
@ -10,55 +9,26 @@ type ProductListProps = {
};
const ProductList: React.FC<ProductListProps> = ({ products, category }) => {
const { addToCart } = useCart();
const sortedProducts = [...products].sort((a, b) =>
// Sort products by name alphabetically
const sortedProducts = [...products].sort((a, b) =>
a.name.localeCompare(b.name)
);
const handleDirectAddToCart = (product: Product) => {
addToCart({
productId: product.id,
productName: product.name,
selectedOption: { name: product.name, price: product.basePrice },
quantity: 1,
category
});
};
return (
<div className="product-list">
{sortedProducts.map(product => {
const hasOptions = product.options && product.options.length > 0;
const style = product.color ? { backgroundColor: `${product.color}80` } : {};
if (hasOptions) {
return (
<Link
to={`/product/${category}/${product.id}`}
key={product.id}
className="product-item"
style={style}
>
<div className="product-name">{product.name}</div>
<div className="product-price">{product.basePrice.toFixed(2)} </div>
</Link>
);
} else {
return (
<div
key={product.id}
className="product-item"
style={style}
onClick={() => handleDirectAddToCart(product)}
>
<div className="product-name">{product.name}</div>
<div className="product-price">{product.basePrice.toFixed(2)} </div>
</div>
);
}
})}
{sortedProducts.map(product => (
<Link
to={`/product/${category}/${product.id}`}
key={product.id}
className="product-item"
style={product.color ? { backgroundColor: `${product.color}80` } : {}}
>
<div className="product-name">{product.name}</div>
<div className="product-price">{product.basePrice.toFixed(2)} </div>
</Link>
))}
</div>
);
};
export default ProductList;

View File

@ -15,7 +15,12 @@
"id": "f2",
"name": "Schnitzelsemmel",
"basePrice": 5.80,
"color": "#FFEFC1"
"color": "#FFEFC1",
"options": [
{"name": "Klassisch", "price": 5.80},
{"name": "Mit Salat", "price": 6.50, "color": "#E8F5E9"},
{"name": "Mit Käse", "price": 6.80, "color": "#FFF9C4"}
]
},
{
"id": "f3",
@ -90,7 +95,13 @@
"id": "d3",
"name": "Softdrinks",
"basePrice": 3.50,
"color": "#FFDAB9"
"color": "#FFDAB9",
"options": [
{"name": "Fanta (0,5L)", "price": 3.50},
{"name": "Sprite (0,5L)", "price": 3.50},
{"name": "Almdudler (0,5L)", "price": 3.50},
{"name": "Eistee (0,5L)", "price": 3.50}
]
},
{
"id": "d4",

View File

@ -8,7 +8,7 @@ export type Product = {
id: string;
name: string;
basePrice: number;
options?: ProductOption[];
options: ProductOption[];
color?: string; // Optional color code for background highlight
};