Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
|
@@ -370,6 +370,8 @@ def update_quantity():
|
|
| 370 |
def checkout():
|
| 371 |
email = session.get('user_email')
|
| 372 |
user_id = session.get('user_id')
|
|
|
|
|
|
|
| 373 |
if not email or not user_id:
|
| 374 |
return jsonify({"success": False, "message": "User not logged in"})
|
| 375 |
|
|
@@ -385,7 +387,7 @@ def checkout():
|
|
| 385 |
return jsonify({"success": False, "message": "Cart is empty"})
|
| 386 |
|
| 387 |
# Calculate the total price of the order
|
| 388 |
-
total_price = sum(item['Price__c'] for item in cart_items)
|
| 389 |
|
| 390 |
# Format order details including instructions
|
| 391 |
order_details = []
|
|
@@ -405,11 +407,31 @@ def checkout():
|
|
| 405 |
}
|
| 406 |
sf.Order__c.create(order_data)
|
| 407 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 408 |
# Clear the cart after placing the order
|
| 409 |
for item in cart_items:
|
| 410 |
sf.Cart_Item__c.delete(item["Id"])
|
| 411 |
|
| 412 |
return jsonify({"success": True, "message": "Order placed successfully!"})
|
|
|
|
| 413 |
except Exception as e:
|
| 414 |
print(f"Error during checkout: {str(e)}")
|
| 415 |
return jsonify({"success": False, "error": str(e)})
|
|
|
|
| 370 |
def checkout():
|
| 371 |
email = session.get('user_email')
|
| 372 |
user_id = session.get('user_id')
|
| 373 |
+
|
| 374 |
+
# Check if the user is logged in
|
| 375 |
if not email or not user_id:
|
| 376 |
return jsonify({"success": False, "message": "User not logged in"})
|
| 377 |
|
|
|
|
| 387 |
return jsonify({"success": False, "message": "Cart is empty"})
|
| 388 |
|
| 389 |
# Calculate the total price of the order
|
| 390 |
+
total_price = sum(item['Price__c'] * item['Quantity__c'] for item in cart_items) # Updated to multiply by quantity
|
| 391 |
|
| 392 |
# Format order details including instructions
|
| 393 |
order_details = []
|
|
|
|
| 407 |
}
|
| 408 |
sf.Order__c.create(order_data)
|
| 409 |
|
| 410 |
+
# Fetch the current Reward_Points__c for the user
|
| 411 |
+
customer_record = sf.query(f"""
|
| 412 |
+
SELECT Reward_Points__c FROM Customer_Login__c
|
| 413 |
+
WHERE Email__c = '{email}'
|
| 414 |
+
""")
|
| 415 |
+
customer = customer_record.get("records", [])[0] if customer_record else None
|
| 416 |
+
|
| 417 |
+
if customer:
|
| 418 |
+
# Calculate 10% of the subtotal
|
| 419 |
+
reward_points_to_add = total_price * 0.10
|
| 420 |
+
|
| 421 |
+
# Add the new reward points to the existing value
|
| 422 |
+
new_reward_points = customer['Reward_Points__c'] + reward_points_to_add if customer.get('Reward_Points__c') else reward_points_to_add
|
| 423 |
+
|
| 424 |
+
# Update the Reward_Points__c field in Salesforce
|
| 425 |
+
sf.Customer_Login__c.update(customer['Id'], {
|
| 426 |
+
"Reward_Points__c": new_reward_points
|
| 427 |
+
})
|
| 428 |
+
|
| 429 |
# Clear the cart after placing the order
|
| 430 |
for item in cart_items:
|
| 431 |
sf.Cart_Item__c.delete(item["Id"])
|
| 432 |
|
| 433 |
return jsonify({"success": True, "message": "Order placed successfully!"})
|
| 434 |
+
|
| 435 |
except Exception as e:
|
| 436 |
print(f"Error during checkout: {str(e)}")
|
| 437 |
return jsonify({"success": False, "error": str(e)})
|