Compare commits
	
		
			No commits in common. "a19c082d9a347a8121a0158c0c1465597a21c859" and "e7fda0497e8a38a91c4c6e5c93b0206862c34488" have entirely different histories.
		
	
	
		
			a19c082d9a
			...
			e7fda0497e
		
	
		
| @ -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,13 +30,14 @@ 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 => ( | ||||
|         {product.options.map(option => ( | ||||
|           <div  | ||||
|             key={option.name} | ||||
|             className={`option-item ${selectedOption.name === option.name ? 'selected' : ''}`} | ||||
| @ -53,10 +50,9 @@ const ProductDetails: React.FC<ProductDetailsProps> = ({ product, category }) => | ||||
|           </div> | ||||
|         ))} | ||||
|         {hasSamePrice && ( | ||||
|             <div className="uniform-price">Preis: {options[0].price.toFixed(2)} €</div> | ||||
|           <div className="uniform-price">Preis: {product.options[0].price.toFixed(2)} €</div> | ||||
|         )} | ||||
|       </div> | ||||
|       )} | ||||
|        | ||||
|       <div className="quantity-controls"> | ||||
|         <h3>Menge:</h3> | ||||
|  | ||||
| @ -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(); | ||||
|   // 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 ( | ||||
|       {sortedProducts.map(product => ( | ||||
|         <Link  | ||||
|           to={`/product/${category}/${product.id}`}  | ||||
|           key={product.id}  | ||||
|           className="product-item" | ||||
|               style={style} | ||||
|           style={product.color ? { backgroundColor: `${product.color}80` } : {}} | ||||
|         > | ||||
|           <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> | ||||
|           ); | ||||
|         } | ||||
|       })} | ||||
|       ))} | ||||
|     </div> | ||||
|   ); | ||||
| }; | ||||
| 
 | ||||
| 
 | ||||
| export default ProductList; | ||||
|  | ||||
| @ -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", | ||||
|  | ||||
| @ -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
 | ||||
| }; | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user