update install
This commit is contained in:
parent
3ae0051e55
commit
7b40c86b40
3 changed files with 145 additions and 1 deletions
|
|
@ -81,6 +81,9 @@ def before_save(doc, method):
|
||||||
|
|
||||||
def after_save(doc, method):
|
def after_save(doc, method):
|
||||||
print("DEBUG: After Save Triggered for Project:", doc.name)
|
print("DEBUG: After Save Triggered for Project:", doc.name)
|
||||||
|
if doc.status == "Completed":
|
||||||
|
print("DEBUG: Project marked as Completed. Generating and sending final invoice.")
|
||||||
|
|
||||||
if doc.ready_to_schedule:
|
if doc.ready_to_schedule:
|
||||||
service_apt_ready_to_schedule = frappe.get_value("Service Address 2", doc.service_appointment, "ready_to_schedule")
|
service_apt_ready_to_schedule = frappe.get_value("Service Address 2", doc.service_appointment, "ready_to_schedule")
|
||||||
if not service_apt_ready_to_schedule:
|
if not service_apt_ready_to_schedule:
|
||||||
|
|
|
||||||
|
|
@ -1414,7 +1414,7 @@ def create_accounts():
|
||||||
"parent_account": account["parent_account"],
|
"parent_account": account["parent_account"],
|
||||||
"is_group": 0
|
"is_group": 0
|
||||||
})
|
})
|
||||||
doc.insert(ignore_permissions=True)
|
doc.insert(ignore_permissions=True, ignore_if_duplicate=True)
|
||||||
|
|
||||||
frappe.db.commit()
|
frappe.db.commit()
|
||||||
|
|
||||||
|
|
|
||||||
141
custom_ui/www/cancelled_payment.html
Normal file
141
custom_ui/www/cancelled_payment.html
Normal file
|
|
@ -0,0 +1,141 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Payment Cancelled</title>
|
||||||
|
<link href="https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap" rel="stylesheet">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
font-family: 'Roboto', sans-serif;
|
||||||
|
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
||||||
|
color: #333;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
min-height: 100vh;
|
||||||
|
}
|
||||||
|
.payment-container {
|
||||||
|
text-align: center;
|
||||||
|
background-color: #fff;
|
||||||
|
padding: 50px;
|
||||||
|
border-radius: 20px;
|
||||||
|
box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
|
||||||
|
max-width: 500px;
|
||||||
|
width: 90%;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
.cancelled-icon {
|
||||||
|
font-size: 5rem;
|
||||||
|
color: #e74c3c;
|
||||||
|
margin-bottom: 30px;
|
||||||
|
animation: cancelledAnimation 1.5s ease-out;
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes cancelledAnimation {
|
||||||
|
0% {
|
||||||
|
transform: scale(0) rotate(180deg);
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
50% {
|
||||||
|
transform: scale(1.2) rotate(0deg);
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
70% {
|
||||||
|
transform: scale(0.9) rotate(0deg);
|
||||||
|
}
|
||||||
|
100% {
|
||||||
|
transform: scale(1) rotate(0deg);
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.payment-title {
|
||||||
|
font-size: 2.5rem;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
color: #333;
|
||||||
|
font-weight: 700;
|
||||||
|
}
|
||||||
|
|
||||||
|
.payment-message {
|
||||||
|
font-size: 1.2rem;
|
||||||
|
line-height: 1.6;
|
||||||
|
margin-bottom: 30px;
|
||||||
|
color: #666;
|
||||||
|
font-weight: 400;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cancelled-notice {
|
||||||
|
background-color: #ffeaea;
|
||||||
|
padding: 20px;
|
||||||
|
border-radius: 10px;
|
||||||
|
margin-top: 30px;
|
||||||
|
border: 1px solid #f5c6cb;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cancelled-notice h3 {
|
||||||
|
margin: 0 0 10px 0;
|
||||||
|
color: #721c24;
|
||||||
|
font-size: 1.3rem;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cancelled-notice p {
|
||||||
|
margin: 0;
|
||||||
|
color: #721c24;
|
||||||
|
font-weight: 400;
|
||||||
|
line-height: 1.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
.next-steps {
|
||||||
|
background-color: #f8f9fa;
|
||||||
|
padding: 20px;
|
||||||
|
border-radius: 10px;
|
||||||
|
margin-top: 20px;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.next-steps h4 {
|
||||||
|
margin: 0 0 15px 0;
|
||||||
|
color: #333;
|
||||||
|
font-size: 1.1rem;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
|
||||||
|
.next-steps ul {
|
||||||
|
margin: 0;
|
||||||
|
padding-left: 20px;
|
||||||
|
color: #666;
|
||||||
|
}
|
||||||
|
|
||||||
|
.next-steps li {
|
||||||
|
margin-bottom: 8px;
|
||||||
|
line-height: 1.4;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="payment-container">
|
||||||
|
<div class="cancelled-icon">✕</div>
|
||||||
|
<h1 class="payment-title">Payment Cancelled</h1>
|
||||||
|
<p class="payment-message">Your payment has been cancelled.</p>
|
||||||
|
|
||||||
|
<div class="cancelled-notice">
|
||||||
|
<h3>Payment Not Processed</h3>
|
||||||
|
<p>No charges have been made to your account. If you cancelled by mistake or need assistance, please try again or contact support.</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="next-steps">
|
||||||
|
<h4>What happens next?</h4>
|
||||||
|
<ul>
|
||||||
|
<li>No payment has been processed</li>
|
||||||
|
<li>You can safely close this window</li>
|
||||||
|
<li>Try your payment again if needed</li>
|
||||||
|
<li>Contact us if you need help</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
Loading…
Add table
Add a link
Reference in a new issue