Compare commits
	
		
			No commits in common. "73a522be604c5c975858c7c1d4a2d4d186ae5548" and "e390f7892621544578d4f2bcf1648a0764e89882" have entirely different histories.
		
	
	
		
			73a522be60
			...
			e390f78926
		
	
		
| @ -1,62 +1,62 @@ | |||||||
| .cart-overview { | .cart-overview { | ||||||
|   padding: 8px 4px; |   padding: 15px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .cart-summary { | .cart-summary { | ||||||
|   background-color: #f7f9fc; |   background-color: #f5f5f5; | ||||||
|   border-radius: 6px; |   border-radius: 8px; | ||||||
|   padding: 12px; |   padding: 15px; | ||||||
|   margin-bottom: 16px; |   margin-bottom: 20px; | ||||||
|   box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06); |   box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .count-info { | .count-info { | ||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   margin-bottom: 8px; |   margin-bottom: 10px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .food-count, .drink-count { | .food-count, .drink-count { | ||||||
|   font-weight: 500; |   font-weight: 500; | ||||||
|   font-size: 0.9rem; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .total-price { | .total-price { | ||||||
|   font-weight: bold; |   font-weight: bold; | ||||||
|   font-size: 1.1rem; |   font-size: 1.2rem; | ||||||
|   text-align: center; |   text-align: center; | ||||||
|   margin-top: 8px; |   margin-top: 10px; | ||||||
|   color: #2c7be5; |   color: #2c7be5; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .cart-actions { | .clear-cart-button { | ||||||
|   display: flex; |  | ||||||
|   flex-direction: column; |  | ||||||
|   gap: 10px; |  | ||||||
|   margin-bottom: 16px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .calculate-change-button, .clear-cart-button { |  | ||||||
|   width: 100%; |   width: 100%; | ||||||
|   padding: 10px; |   padding: 12px; | ||||||
|  |   margin-bottom: 15px; | ||||||
|  |   background-color: #ff5252; | ||||||
|  |   color: white; | ||||||
|   border: none; |   border: none; | ||||||
|   border-radius: 6px; |   border-radius: 8px; | ||||||
|   font-weight: 600; |   font-weight: bold; | ||||||
|   font-size: 0.95rem; |  | ||||||
|   cursor: pointer; |   cursor: pointer; | ||||||
|   transition: background-color 0.2s; |   transition: background-color 0.2s; | ||||||
| } | } | ||||||
| 
 |  | ||||||
| .calculate-change-button { | .calculate-change-button { | ||||||
|  |   width: 100%; | ||||||
|  |     padding: 12px; | ||||||
|     background-color: #2c7be5; |     background-color: #2c7be5; | ||||||
|     color: white; |     color: white; | ||||||
|  |     border: none; | ||||||
|  |     border-radius: 8px; | ||||||
|  |     font-weight: bold; | ||||||
|  |     cursor: pointer; | ||||||
|  |     transition: background-color 0.2s; | ||||||
| } | } | ||||||
| 
 | .cart-actions { | ||||||
| .clear-cart-button { |   display: flex; | ||||||
|   background-color: #ff5252; |   flex-direction: column; | ||||||
|   color: white; |   gap: 12px; | ||||||
|  |   margin-bottom: 20px; | ||||||
| } | } | ||||||
| 
 |  | ||||||
| .calculate-change-button:active { | .calculate-change-button:active { | ||||||
|     background-color: #1b5eb5; |     background-color: #1b5eb5; | ||||||
| } | } | ||||||
| @ -68,51 +68,49 @@ | |||||||
| .cart-items { | .cart-items { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|   gap: 8px; |   gap: 15px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .cart-item { | .cart-item { | ||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   background-color: #f7f9fc; |   background-color: white; | ||||||
|   padding: 12px; |   padding: 15px; | ||||||
|   border-radius: 6px; |   border-radius: 8px; | ||||||
|   box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06); |   box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .item-info { | .item-info { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|   gap: 3px; |   gap: 5px; | ||||||
|   flex: 1; |   flex: 1; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .item-name { | .item-name { | ||||||
|   font-weight: 500; |   font-weight: 500; | ||||||
|   font-size: 0.95rem; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .item-option { | .item-option { | ||||||
|   font-size: 0.85rem; |   font-size: 0.9rem; | ||||||
|   color: #666; |   color: #666; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .item-price { | .item-price { | ||||||
|   font-weight: bold; |   font-weight: bold; | ||||||
|   color: #2c7be5; |   color: #2c7be5; | ||||||
|   font-size: 0.9rem; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .item-quantity { | .item-quantity { | ||||||
|   display: flex; |   display: flex; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   gap: 8px; |   gap: 10px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .item-quantity button { | .item-quantity button { | ||||||
|   width: 26px; |   width: 30px; | ||||||
|   height: 26px; |   height: 30px; | ||||||
|   border: none; |   border: none; | ||||||
|   border-radius: 50%; |   border-radius: 50%; | ||||||
|   background-color: #2c7be5; |   background-color: #2c7be5; | ||||||
| @ -128,8 +126,7 @@ | |||||||
| 
 | 
 | ||||||
| .empty-cart { | .empty-cart { | ||||||
|   text-align: center; |   text-align: center; | ||||||
|   padding: 20px; |   padding: 30px; | ||||||
|   color: #888; |   color: #666; | ||||||
|   font-style: italic; |   font-style: italic; | ||||||
|   font-size: 0.9rem; |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,9 +15,6 @@ const ProductDetails: React.FC<ProductDetailsProps> = ({ product, category }) => | |||||||
|   const { addToCart } = useCart(); |   const { addToCart } = useCart(); | ||||||
|   const navigate = useNavigate(); |   const navigate = useNavigate(); | ||||||
| 
 | 
 | ||||||
|   // Check if all options have the same price
 |  | ||||||
|   const hasSamePrice = product.options.every(option => option.price === product.options[0].price); |  | ||||||
| 
 |  | ||||||
|   const handleAddToCart = () => { |   const handleAddToCart = () => { | ||||||
|     addToCart({ |     addToCart({ | ||||||
|       productId: product.id, |       productId: product.id, | ||||||
| @ -29,10 +26,14 @@ const ProductDetails: React.FC<ProductDetailsProps> = ({ product, category }) => | |||||||
|     navigate('/'); |     navigate('/'); | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  |   const incrementQuantity = () => setQuantity(prev => prev + 1); | ||||||
|  |   const decrementQuantity = () => setQuantity(prev => Math.max(1, prev - 1)); | ||||||
|  | 
 | ||||||
|  |   // Check if all options have the same price
 | ||||||
|  |   const hasSamePrice = product.options.every(option => option.price === product.options[0].price); | ||||||
|  | 
 | ||||||
|   return ( |   return ( | ||||||
|     <div  |     <div className="product-details"> | ||||||
|       className="product-details" |  | ||||||
|     > |  | ||||||
|       <h2>{product.name}</h2> |       <h2>{product.name}</h2> | ||||||
|        |        | ||||||
|       <div className="options-list"> |       <div className="options-list"> | ||||||
| @ -42,24 +43,24 @@ const ProductDetails: React.FC<ProductDetailsProps> = ({ product, category }) => | |||||||
|             key={option.name} |             key={option.name} | ||||||
|             className={`option-item ${selectedOption.name === option.name ? 'selected' : ''}`} |             className={`option-item ${selectedOption.name === option.name ? 'selected' : ''}`} | ||||||
|             onClick={() => setSelectedOption(option)} |             onClick={() => setSelectedOption(option)} | ||||||
|             style={(option.color || product.color) ?  |  | ||||||
|               { backgroundColor: `${option.color || product.color}60` } : {}} |  | ||||||
|           > |           > | ||||||
|             <span>{option.name}</span> |             <span>{option.name}</span> | ||||||
|             {!hasSamePrice && <span className="option-price">{option.price.toFixed(2)} €</span>} |             {!hasSamePrice && <span className="option-price">{option.price.toFixed(2)} €</span>} | ||||||
|           </div> |           </div> | ||||||
|         ))} |         ))} | ||||||
|         {hasSamePrice && ( |         {hasSamePrice && ( | ||||||
|           <div className="uniform-price">Preis: {product.options[0].price.toFixed(2)} €</div> |           <div className="uniform-price"> | ||||||
|  |             Preis: {product.options[0].price.toFixed(2)} € | ||||||
|  |           </div> | ||||||
|         )} |         )} | ||||||
|       </div> |       </div> | ||||||
|        |        | ||||||
|       <div className="quantity-controls"> |       <div className="quantity-controls"> | ||||||
|         <h3>Menge:</h3> |         <h3>Menge:</h3> | ||||||
|         <div className="quantity-buttons"> |         <div className="quantity-buttons"> | ||||||
|           <button onClick={() => setQuantity(prev => Math.max(1, prev - 1))}>-</button> |           <button onClick={decrementQuantity}>-</button> | ||||||
|           <span>{quantity}</span> |           <span>{quantity}</span> | ||||||
|           <button onClick={() => setQuantity(prev => prev + 1)}>+</button> |           <button onClick={incrementQuantity}>+</button> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|        |        | ||||||
|  | |||||||
| @ -1,35 +1,34 @@ | |||||||
| .product-list { | .product-list { | ||||||
|   display: flex; |   display: flex; | ||||||
|   flex-direction: column; |   flex-direction: column; | ||||||
|   gap: 8px; |   gap: 10px; | ||||||
|   padding: 6px; |   padding: 10px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .product-item { | .product-item { | ||||||
|   display: flex; |   display: flex; | ||||||
|   justify-content: space-between; |   justify-content: space-between; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   padding: 14px; |   padding: 15px; | ||||||
|   background-color: #fff; |   background-color: #fff; | ||||||
|   border-radius: 6px; |   border-radius: 8px; | ||||||
|   box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08); |   box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); | ||||||
|   text-decoration: none; |   text-decoration: none; | ||||||
|   color: #333; |   color: #333; | ||||||
|   transition: transform 0.2s, box-shadow 0.2s; |   transition: transform 0.2s, box-shadow 0.2s; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .product-item:active { | .product-item:active { | ||||||
|   transform: scale(0.99); |   transform: scale(0.98); | ||||||
|   box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .product-name { | .product-name { | ||||||
|   font-weight: 500; |   font-weight: 500; | ||||||
|   font-size: 1rem; |   font-size: 1.1rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .product-price { | .product-price { | ||||||
|   font-weight: 600; |   font-weight: bold; | ||||||
|   color: #2c7be5; |   color: #2c7be5; | ||||||
|   font-size: 0.95rem; |   font-size: 1.1rem; | ||||||
| } | } | ||||||
|  | |||||||
| @ -21,7 +21,6 @@ const ProductList: React.FC<ProductListProps> = ({ products, category }) => { | |||||||
|           to={`/product/${category}/${product.id}`}  |           to={`/product/${category}/${product.id}`}  | ||||||
|           key={product.id}  |           key={product.id}  | ||||||
|           className="product-item" |           className="product-item" | ||||||
|           style={product.color ? { backgroundColor: `${product.color}80` } : {}} |  | ||||||
|         > |         > | ||||||
|           <div className="product-name">{product.name}</div> |           <div className="product-name">{product.name}</div> | ||||||
|           <div className="product-price">{product.basePrice.toFixed(2)} €</div> |           <div className="product-price">{product.basePrice.toFixed(2)} €</div> | ||||||
|  | |||||||
| @ -4,10 +4,9 @@ | |||||||
|       "id": "f1", |       "id": "f1", | ||||||
|       "name": "Hendl", |       "name": "Hendl", | ||||||
|       "basePrice": 9.50, |       "basePrice": 9.50, | ||||||
|       "color": "#FFEBCD", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Halbes Hendl", "price": 9.50}, |         {"name": "Halbes Hendl", "price": 9.50}, | ||||||
|         {"name": "Ganzes Hendl", "price": 16.00, "color": "#FFDAB9"}, |         {"name": "Ganzes Hendl", "price": 16.00}, | ||||||
|         {"name": "Hendl mit Semmel", "price": 11.00} |         {"name": "Hendl mit Semmel", "price": 11.00} | ||||||
|       ] |       ] | ||||||
|     }, |     }, | ||||||
| @ -15,18 +14,16 @@ | |||||||
|       "id": "f2", |       "id": "f2", | ||||||
|       "name": "Schnitzelsemmel", |       "name": "Schnitzelsemmel", | ||||||
|       "basePrice": 5.80, |       "basePrice": 5.80, | ||||||
|       "color": "#FFEFC1", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Klassisch", "price": 5.80}, |         {"name": "Klassisch", "price": 5.80}, | ||||||
|         {"name": "Mit Salat", "price": 6.50, "color": "#E8F5E9"}, |         {"name": "Mit Salat", "price": 6.50}, | ||||||
|         {"name": "Mit Käse", "price": 6.80, "color": "#FFF9C4"} |         {"name": "Mit Käse", "price": 6.80} | ||||||
|       ] |       ] | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": "f3", |       "id": "f3", | ||||||
|       "name": "Pommes", |       "name": "Pommes", | ||||||
|       "basePrice": 3.50, |       "basePrice": 3.50, | ||||||
|       "color": "#FFD700", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Klein", "price": 3.50}, |         {"name": "Klein", "price": 3.50}, | ||||||
|         {"name": "Groß", "price": 4.50}, |         {"name": "Groß", "price": 4.50}, | ||||||
| @ -37,7 +34,6 @@ | |||||||
|       "id": "f4", |       "id": "f4", | ||||||
|       "name": "Grillwurst", |       "name": "Grillwurst", | ||||||
|       "basePrice": 4.20, |       "basePrice": 4.20, | ||||||
|       "color": "#FFCCCB", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Bratwurst", "price": 4.20}, |         {"name": "Bratwurst", "price": 4.20}, | ||||||
|         {"name": "Käsekrainer", "price": 4.50}, |         {"name": "Käsekrainer", "price": 4.50}, | ||||||
| @ -48,7 +44,6 @@ | |||||||
|       "id": "f5", |       "id": "f5", | ||||||
|       "name": "Leberkässemmel", |       "name": "Leberkässemmel", | ||||||
|       "basePrice": 4.00, |       "basePrice": 4.00, | ||||||
|       "color": "#FFE4E1", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Klassisch", "price": 4.00}, |         {"name": "Klassisch", "price": 4.00}, | ||||||
|         {"name": "Mit Gurkerl", "price": 4.30}, |         {"name": "Mit Gurkerl", "price": 4.30}, | ||||||
| @ -59,7 +54,6 @@ | |||||||
|       "id": "f6", |       "id": "f6", | ||||||
|       "name": "Langos", |       "name": "Langos", | ||||||
|       "basePrice": 4.80, |       "basePrice": 4.80, | ||||||
|       "color": "#DEB887", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Mit Knoblauch", "price": 4.80}, |         {"name": "Mit Knoblauch", "price": 4.80}, | ||||||
|         {"name": "Mit Käse", "price": 5.50}, |         {"name": "Mit Käse", "price": 5.50}, | ||||||
| @ -72,18 +66,16 @@ | |||||||
|       "id": "d1", |       "id": "d1", | ||||||
|       "name": "Bier", |       "name": "Bier", | ||||||
|       "basePrice": 4.20, |       "basePrice": 4.20, | ||||||
|       "color": "#F0E68C", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Krügerl (0,5L)", "price": 4.20, "color": "#F5DEB3"}, |         {"name": "Krügerl (0,5L)", "price": 4.20}, | ||||||
|         {"name": "Seidl (0,3L)", "price": 3.50}, |         {"name": "Seidl (0,3L)", "price": 3.50}, | ||||||
|         {"name": "Radler (0,5L)", "price": 4.20, "color": "#FAFAD2"} |         {"name": "Radler (0,5L)", "price": 4.20} | ||||||
|       ] |       ] | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       "id": "d2", |       "id": "d2", | ||||||
|       "name": "Cola", |       "name": "Cola", | ||||||
|       "basePrice": 3.50, |       "basePrice": 3.50, | ||||||
|       "color": "#D2B48C", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Cola Rot (0,5L)", "price": 3.50}, |         {"name": "Cola Rot (0,5L)", "price": 3.50}, | ||||||
|         {"name": "Cola Weiß (0,5L)", "price": 3.50}, |         {"name": "Cola Weiß (0,5L)", "price": 3.50}, | ||||||
| @ -95,7 +87,6 @@ | |||||||
|       "id": "d3", |       "id": "d3", | ||||||
|       "name": "Softdrinks", |       "name": "Softdrinks", | ||||||
|       "basePrice": 3.50, |       "basePrice": 3.50, | ||||||
|       "color": "#FFDAB9", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Fanta (0,5L)", "price": 3.50}, |         {"name": "Fanta (0,5L)", "price": 3.50}, | ||||||
|         {"name": "Sprite (0,5L)", "price": 3.50}, |         {"name": "Sprite (0,5L)", "price": 3.50}, | ||||||
| @ -107,7 +98,6 @@ | |||||||
|       "id": "d4", |       "id": "d4", | ||||||
|       "name": "Mineral", |       "name": "Mineral", | ||||||
|       "basePrice": 2.80, |       "basePrice": 2.80, | ||||||
|       "color": "#E0FFFF", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Prickelnd (0,5L)", "price": 2.80}, |         {"name": "Prickelnd (0,5L)", "price": 2.80}, | ||||||
|         {"name": "Still (0,5L)", "price": 2.80}, |         {"name": "Still (0,5L)", "price": 2.80}, | ||||||
| @ -119,7 +109,6 @@ | |||||||
|       "id": "d5", |       "id": "d5", | ||||||
|       "name": "Gespritzt", |       "name": "Gespritzt", | ||||||
|       "basePrice": 3.00, |       "basePrice": 3.00, | ||||||
|       "color": "#FFDAB9", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Apfelsaft g'spritzt", "price": 3.00}, |         {"name": "Apfelsaft g'spritzt", "price": 3.00}, | ||||||
|         {"name": "Johannisbeer g'spritzt", "price": 3.20}, |         {"name": "Johannisbeer g'spritzt", "price": 3.20}, | ||||||
| @ -131,7 +120,6 @@ | |||||||
|       "id": "d6", |       "id": "d6", | ||||||
|       "name": "Spritzer", |       "name": "Spritzer", | ||||||
|       "basePrice": 3.80, |       "basePrice": 3.80, | ||||||
|       "color": "#FFE4E1", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Weißer Spritzer", "price": 3.80}, |         {"name": "Weißer Spritzer", "price": 3.80}, | ||||||
|         {"name": "Aperol Spritzer", "price": 4.50}, |         {"name": "Aperol Spritzer", "price": 4.50}, | ||||||
| @ -143,7 +131,6 @@ | |||||||
|       "id": "d7", |       "id": "d7", | ||||||
|       "name": "Schnaps", |       "name": "Schnaps", | ||||||
|       "basePrice": 3.00, |       "basePrice": 3.00, | ||||||
|       "color": "#E6E6FA", |  | ||||||
|       "options": [ |       "options": [ | ||||||
|         {"name": "Marille (2cl)", "price": 3.00}, |         {"name": "Marille (2cl)", "price": 3.00}, | ||||||
|         {"name": "Williams (2cl)", "price": 3.00}, |         {"name": "Williams (2cl)", "price": 3.00}, | ||||||
|  | |||||||
| @ -1,61 +1,37 @@ | |||||||
| .home-page { | .home-page { | ||||||
|   display: flex; |   padding-bottom: 20px; | ||||||
|   flex-direction: column; |  | ||||||
|   min-height: 100vh; |  | ||||||
|   background-color: #f9fafb; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .app-header { | .app-header { | ||||||
|   background-color: #2c7be5; |   background-color: #2c7be5; | ||||||
|   color: white; |   color: white; | ||||||
|   text-align: center; |   text-align: center; | ||||||
|   padding: 12px; |   padding: 15px; | ||||||
|   box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); |   box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .app-header h1 { | .app-header h1 { | ||||||
|   margin: 0; |   margin: 0; | ||||||
|   font-size: 1.4rem; |   font-size: 1.5rem; | ||||||
|   font-weight: 600; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .main-container { |  | ||||||
|   flex: 1; |  | ||||||
|   display: flex; |  | ||||||
|   flex-direction: column; |  | ||||||
|   gap: 16px; |  | ||||||
|   padding: 16px; |  | ||||||
|   max-width: 600px; |  | ||||||
|   margin: 0 auto; |  | ||||||
|   width: 100%; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .section-title { |  | ||||||
|   margin: 8px 0; |  | ||||||
|   font-size: 1.2rem; |  | ||||||
|   color: #333; |  | ||||||
|   font-weight: 500; |  | ||||||
|   padding-left: 8px; |  | ||||||
|   border-left: 3px solid #2c7be5; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .category-tabs { | .category-tabs { | ||||||
|   display: flex; |   display: flex; | ||||||
|  |   margin: 10px; | ||||||
|   border-radius: 8px; |   border-radius: 8px; | ||||||
|   overflow: hidden; |   overflow: hidden; | ||||||
|   box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); |   box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); | ||||||
|   margin-bottom: 4px; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .category-tabs button { | .category-tabs button { | ||||||
|   flex: 1; |   flex: 1; | ||||||
|   padding: 12px; |   padding: 15px; | ||||||
|   background-color: #f5f5f5; |   background-color: #f5f5f5; | ||||||
|   border: none; |   border: none; | ||||||
|   font-size: 1rem; |   font-size: 1.1rem; | ||||||
|   font-weight: 500; |   font-weight: 500; | ||||||
|   cursor: pointer; |   cursor: pointer; | ||||||
|   transition: all 0.2s ease; |   transition: background-color 0.2s; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .category-tabs button.active { | .category-tabs button.active { | ||||||
| @ -63,22 +39,14 @@ | |||||||
|   color: white; |   color: white; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .products-container { | .products-section, .cart-section { | ||||||
|   background-color: white; |   margin: 20px 0; | ||||||
|   border-radius: 10px; |  | ||||||
|   padding: 12px; |  | ||||||
|   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .cart-container { | .products-section h2, .cart-section h2 { | ||||||
|   background-color: white; |   margin: 0 10px 10px 10px; | ||||||
|   border-radius: 10px; |   font-size: 1.3rem; | ||||||
|   padding: 12px; |   color: #333; | ||||||
|   box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05); |   padding-left: 10px; | ||||||
| } |   border-left: 4px solid #2c7be5; | ||||||
| 
 |  | ||||||
| @media (min-width: 768px) { |  | ||||||
|   .main-container { |  | ||||||
|     max-width: 800px; |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -9,11 +9,23 @@ const HomePage: React.FC = () => { | |||||||
|   const [activeTab, setActiveTab] = useState<'food' | 'drinks'>('drinks'); |   const [activeTab, setActiveTab] = useState<'food' | 'drinks'>('drinks'); | ||||||
|    |    | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     import('../data/products.json') |     const loadProducts = async () => { | ||||||
|       .then(data => { |       try { | ||||||
|         setProductsData(data); |         const data = await import('../data/products.json'); | ||||||
|       }) |          | ||||||
|       .catch(error => console.error('Failed to load products:', error)); |         // Sort both food and drinks by name
 | ||||||
|  |         const sortedData = { | ||||||
|  |           food: [...data.food].sort((a, b) => a.name.localeCompare(b.name)), | ||||||
|  |           drinks: [...data.drinks].sort((a, b) => a.name.localeCompare(b.name)) | ||||||
|  |         }; | ||||||
|  |          | ||||||
|  |         setProductsData(sortedData); | ||||||
|  |       } catch (error) { | ||||||
|  |         console.error('Failed to load products:', error); | ||||||
|  |       } | ||||||
|  |     }; | ||||||
|  |      | ||||||
|  |     loadProducts(); | ||||||
|   }, []); |   }, []); | ||||||
|    |    | ||||||
|   return ( |   return ( | ||||||
| @ -22,14 +34,12 @@ const HomePage: React.FC = () => { | |||||||
|         <h1>Preis Rechner</h1> |         <h1>Preis Rechner</h1> | ||||||
|       </header> |       </header> | ||||||
| 
 | 
 | ||||||
|       <div className="main-container"> |  | ||||||
|         <div className="products-container"> |  | ||||||
|       <div className="category-tabs"> |       <div className="category-tabs"> | ||||||
|           <button |           <button | ||||||
|           className={activeTab === 'drinks' ? 'active' : ''} |           className={activeTab === 'drinks' ? 'active' : ''} | ||||||
|           onClick={() => setActiveTab('drinks')} |           onClick={() => setActiveTab('drinks')} | ||||||
|       > |       > | ||||||
|               Getränke |           Trinken | ||||||
|       </button> |       </button> | ||||||
|         <button  |         <button  | ||||||
|           className={activeTab === 'food' ? 'active' : ''} |           className={activeTab === 'food' ? 'active' : ''} | ||||||
| @ -37,21 +47,20 @@ const HomePage: React.FC = () => { | |||||||
|         > |         > | ||||||
|           Essen |           Essen | ||||||
|         </button> |         </button> | ||||||
|  | 
 | ||||||
|       </div> |       </div> | ||||||
|        |        | ||||||
|           <h2 className="section-title">{activeTab === 'food' ? 'Essen' : 'Getränke'}</h2> |       <div className="products-section"> | ||||||
|           <ProductList  |         <h2>{activeTab === 'food' ? 'Essen' : 'Getränke'}</h2> | ||||||
|             products={productsData[activeTab]}  |         {activeTab === 'food' && <ProductList products={productsData.food} category="food" />} | ||||||
|             category={activeTab}  |         {activeTab === 'drinks' && <ProductList products={productsData.drinks} category="drinks" />} | ||||||
|           /> |  | ||||||
|       </div> |       </div> | ||||||
|        |        | ||||||
|         <div className="cart-container"> |       <div className="cart-section"> | ||||||
|           <h2 className="section-title">Warenkorb</h2> |         <h2>Warenkorb</h2> | ||||||
|         <CartOverview /> |         <CartOverview /> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     </div> |  | ||||||
|   ); |   ); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,7 +1,6 @@ | |||||||
| export type ProductOption = { | export type ProductOption = { | ||||||
|   name: string; |   name: string; | ||||||
|   price: number; |   price: number; | ||||||
|   color?: string; // Optional color for this specific option
 |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export type Product = { | export type Product = { | ||||||
| @ -9,7 +8,6 @@ export type Product = { | |||||||
|   name: string; |   name: string; | ||||||
|   basePrice: number; |   basePrice: number; | ||||||
|   options: ProductOption[]; |   options: ProductOption[]; | ||||||
|   color?: string; // Optional color code for background highlight
 |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export type ProductsData = { | export type ProductsData = { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user