Files
mc_cars_gmbh_infraestructure/n8n/workflows/01-qualification-payment-email.json
T

132 lines
8.1 KiB
JSON

{
"name": "Lead Qualified -> Payment Email",
"nodes": [
{
"parameters": {
"triggerOnNotify": true,
"channel": "lead_qualified",
"additionalFields": {}
},
"id": "pg-trigger",
"name": "Postgres Trigger",
"type": "n8n-nodes-base.postgresTrigger",
"typeVersion": 1,
"position": [
250,
300
],
"credentials": {
"postgres": {
"id": "1",
"name": "MC Cars Postgres"
}
}
},
{
"parameters": {
"operation": "executeQuery",
"query": "SELECT c.id, c.name, c.email, c.phone,\n so.order_number, so.total_eur, so.deposit_eur,\n so.date_from, so.date_to, so.vehicle_label,\n so.daily_subtotal, so.weekend_subtotal,\n so.subtotal_eur, so.vat_eur,\n so.total_days, so.weekday_count, so.weekend_day_count\nFROM public.customers c\nJOIN public.sales_orders so ON so.customer_id = c.id\nWHERE so.id = '{{ $json.sales_order_id }}'::uuid",
"additionalFields": {}
},
"id": "fetch-order-data",
"name": "Fetch Order Data",
"type": "n8n-nodes-base.postgres",
"typeVersion": 2.5,
"position": [
470,
300
],
"credentials": {
"postgres": {
"id": "1",
"name": "MC Cars Postgres"
}
}
},
{
"parameters": {
"mode": "runOnceForEachItem",
"language": "javaScript",
"jsCode": "const item = $json;\n\nconst formatEur = (value) => {\n const n = Number(value || 0);\n return new Intl.NumberFormat(\"de-AT\", { style: \"currency\", currency: \"EUR\" }).format(n);\n};\n\nconst formatDate = (value) => {\n if (!value) return \"-\";\n const d = new Date(value);\n if (Number.isNaN(d.getTime())) return String(value);\n return new Intl.DateTimeFormat(\"de-AT\", { day: \"2-digit\", month: \"2-digit\", year: \"numeric\" }).format(d);\n};\n\nconst orderNumber = item.order_number || \"\";\nconst dateFrom = formatDate(item.date_from);\nconst dateTo = formatDate(item.date_to);\nconst rentalRange = `${dateFrom} bis ${dateTo}`;\nconst paymentLink = `https://www.mc-cars.at/zahlung/${encodeURIComponent(orderNumber)}`;\n\nconst depositEur = formatEur(item.deposit_eur);\nconst rentalEur = formatEur(item.total_eur);\nconst subtotalEur = formatEur(item.subtotal_eur);\nconst vatEur = formatEur(item.vat_eur);\n\nconst safeName = item.name || \"Kundin/Kunde\";\nconst vehicle = item.vehicle_label || \"-\";\n\nconst subject = `MC Cars - Buchung bestaetigt (${orderNumber}) - Zahlungsinfos`;\n\nconst html = `\n<div style=\"margin:0;padding:24px;background:#f3f1ed;font-family:Arial,sans-serif;color:#151515;\">\n <table role=\"presentation\" style=\"width:100%;max-width:680px;margin:0 auto;border-collapse:collapse;background:#ffffff;border-radius:14px;overflow:hidden;\">\n <tr>\n <td style=\"background:#101010;padding:24px 28px;\">\n <div style=\"font-size:13px;letter-spacing:0.18em;text-transform:uppercase;color:#caa06a;\">MC Cars</div>\n <h1 style=\"margin:10px 0 0 0;font-size:24px;line-height:1.2;color:#ffffff;\">Ihre Miete wurde freigegeben</h1>\n </td>\n </tr>\n <tr>\n <td style=\"padding:28px;\">\n <p style=\"margin:0 0 14px 0;font-size:16px;\">Guten Tag <strong>${safeName}</strong>,</p>\n <p style=\"margin:0 0 18px 0;font-size:15px;line-height:1.6;\">\n Ihre Buchung wurde auf Basis der von Ihnen bereitgestellten Informationen geprueft und freigegeben.\n Nachfolgend finden Sie die Zahlungsanweisungen fuer Kaution und Mietbetrag.\n </p>\n\n <table role=\"presentation\" style=\"width:100%;border-collapse:collapse;background:#f8f8f8;border:1px solid #e8e8e8;border-radius:10px;overflow:hidden;margin:0 0 22px 0;\">\n <tr>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;width:44%;color:#666;\">Bestellnummer</td>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;\"><strong>${orderNumber}</strong></td>\n </tr>\n <tr>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;width:44%;color:#666;\">Fahrzeug</td>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;\">${vehicle}</td>\n </tr>\n <tr>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;width:44%;color:#666;\">Mietzeitraum</td>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;\">${rentalRange}</td>\n </tr>\n <tr>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;width:44%;color:#666;\">Zwischensumme</td>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;\">${subtotalEur}</td>\n </tr>\n <tr>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;width:44%;color:#666;\">MwSt.</td>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;\">${vatEur}</td>\n </tr>\n <tr>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;width:44%;color:#666;\">Mietbetrag</td>\n <td style=\"padding:12px 14px;border-bottom:1px solid #e8e8e8;\"><strong>${rentalEur}</strong></td>\n </tr>\n <tr>\n <td style=\"padding:12px 14px;width:44%;color:#666;\">Kaution</td>\n <td style=\"padding:12px 14px;\"><strong>${depositEur}</strong></td>\n </tr>\n </table>\n\n <h2 style=\"margin:0 0 10px 0;font-size:18px;color:#101010;\">1) Kaution per Ueberweisung</h2>\n <p style=\"margin:0 0 10px 0;font-size:14px;line-height:1.6;\">Bitte ueberweisen Sie die Kaution in Hoehe von <strong>${depositEur}</strong> mit folgendem Verwendungszweck: <strong>Kaution ${orderNumber}</strong>.</p>\n\n <h2 style=\"margin:18px 0 10px 0;font-size:18px;color:#101010;\">2) Mietbetrag online bezahlen</h2>\n <p style=\"margin:0 0 14px 0;font-size:14px;line-height:1.6;\">Den Mietbetrag von <strong>${rentalEur}</strong> koennen Sie direkt ueber folgenden Link bezahlen:</p>\n\n <p style=\"margin:0 0 20px 0;\">\n <a href=\"${paymentLink}\" style=\"display:inline-block;background:#c28a4a;color:#ffffff;text-decoration:none;font-weight:700;padding:12px 18px;border-radius:8px;\">Zur Zahlung (${orderNumber})</a>\n </p>\n\n <p style=\"margin:0 0 6px 0;font-size:14px;line-height:1.6;\">Falls Sie Fragen haben, antworten Sie einfach auf diese E-Mail.</p>\n <p style=\"margin:0;font-size:14px;line-height:1.6;\">Freundliche Gruesse<br><strong>MC Cars Team</strong></p>\n </td>\n </tr>\n </table>\n</div>`;\n\nreturn {\n toEmail: item.email,\n subject,\n html,\n};"
},
"id": "build-payment-email",
"name": "Build Payment Email",
"type": "n8n-nodes-base.code",
"typeVersion": 2,
"position": [
690,
300
]
},
{
"parameters": {
"fromEmail": "office@mc-cars.at",
"toEmail": "={{ $json.toEmail }}",
"subject": "={{ $json.subject }}",
"emailType": "html",
"html": "={{ $json.html }}",
"options": {}
},
"id": "send-email",
"name": "Send Payment Email",
"type": "n8n-nodes-base.emailSend",
"typeVersion": 2.1,
"position": [
910,
300
],
"credentials": {
"smtp": {
"id": "2",
"name": "MC Cars SMTP"
}
}
}
],
"connections": {
"Postgres Trigger": {
"main": [
[
{
"node": "Fetch Order Data",
"type": "main",
"index": 0
}
]
]
},
"Fetch Order Data": {
"main": [
[
{
"node": "Build Payment Email",
"type": "main",
"index": 0
}
]
]
},
"Build Payment Email": {
"main": [
[
{
"node": "Send Payment Email",
"type": "main",
"index": 0
}
]
]
}
},
"settings": {
"executionOrder": "v1"
},
"staticData": null,
"tags": [
{
"name": "mc-cars"
}
],
"triggerCount": 1
}