نود HTML to PDF در N8N

نود HTML to PDF در N8N

نود HTML to PDF برای تبدیل محتوای HTML به فایل PDF درون ورکفلوهای n8n استفاده می‌شود. این نود وقتی به درد می‌خورد که بخواهید خروجی قابل چاپ و رسمی (مثل فاکتور، قرارداد، گزارش یا رسید پرداخت) را به‌صورت خودکار تولید کنید و سپس آن را ایمیل کنید، در فضای ابری ذخیره کنید یا به سیستم‌های دیگر ارسال کنید.

معرفی نود در N8N

این نود معمولاً HTML را (به‌صورت متن خام یا تولیدشده در مراحل قبلی) دریافت می‌کند، آن را با یک موتور رندر (معمولاً مبتنی بر Chromium) به PDF تبدیل می‌کند و خروجی را به شکل فایل باینری تحویل می‌دهد.

  • کارکرد اصلی: رندر HTML/CSS و تولید PDF خروجی
  • دسته‌بندی نود: Action
  • اهمیت در ورکفلوها: تبدیل خروجی‌های پویا (HTML قالب‌بندی‌شده) به سند استاندارد PDF که قابل آرشیو، امضا، چاپ و ارسال است.

موارد استفاده

1) تولید فاکتور PDF و ارسال برای مشتری

  • دریافت سفارش از WooCommerce/Shopify یا یک فرم
  • ساخت HTML فاکتور با داده‌های سفارش
  • تبدیل به PDF با HTML to PDF
  • ارسال PDF با Email (SMTP/Gmail) یا ذخیره در Google Drive

2) ساخت گزارش روزانه/هفتگی از داده‌ها

  • جمع‌آوری داده از Google Sheets، Notion، دیتابیس یا API
  • تبدیل داده به یک جدول HTML
  • خروجی PDF برای مدیر یا آرشیو

3) تولید قرارداد یا نامه اداری با قالب آماده

  • گرفتن اطلاعات مخاطب از CRM
  • جایگذاری متغیرها داخل قالب HTML
  • PDF نهایی برای امضا یا ارسال

سناریوهای متداول ترکیب با نودهای دیگر

  • Set / Edit Fields: ساخت فیلدهای لازم مثل نام مشتری، مبلغ، تاریخ
  • Function / Code: تولید HTML پویا، حلقه روی آیتم‌ها، ساخت جدول
  • HTTP Request: دریافت داده یا قالب HTML از سرویس خارجی
  • Move Binary Data: تبدیل بین JSON و Binary یا تغییر نام فایل
  • Email / Gmail / Microsoft Outlook: ارسال PDF به عنوان پیوست
  • Google Drive / S3 / Dropbox: ذخیره و بایگانی فایل PDF

پارامترها و تنظیمات

نام فیلدها ممکن است بسته به نسخه n8n یا پیاده‌سازی نود کمی متفاوت باشد، اما مفهوم و کاربردها معمولاً ثابت است. در ادامه رایج‌ترین پارامترها و تنظیمات این نود آورده شده است.

1) HTML

  • نام پارامتر: HTML
  • نوع داده: String
  • توضیح: محتوای HTML که باید به PDF تبدیل شود. بهتر است یک سند کامل HTML (شامل html و head و body) ارسال شود تا رندر پایدارتر باشد.
  • مثال عملی:

<html><head><meta charset=”utf-8″><style>body{font-family:Arial} .box{border:1px solid #ddd;padding:16px}</style></head><body><div class=”box”><h1>Invoice #123</h1><p>Total: 250,000 IRR</p></div></body></html>

2) Output Binary Property

  • نام پارامتر: Output Binary Property
  • نوع داده: String
  • توضیح: نام پراپرتی باینری که فایل PDF در آن ذخیره می‌شود (مثلاً pdf یا data).
  • مثال عملی: pdf

3) File Name

  • نام پارامتر: File Name
  • نوع داده: String
  • توضیح: نام فایل خروجی. اگر نود اجازه دهد، می‌توانید با Expression نام را پویا کنید.
  • مثال عملی: invoice-{{$json.orderId}}.pdf

4) Page Format / Paper Size

  • نام پارامتر: Page Format یا Paper Size
  • نوع داده: Option (A4, Letter, …)
  • توضیح: اندازه صفحه PDF.
  • مثال عملی: A4

5) Orientation

  • نام پارامتر: Orientation
  • نوع داده: Option (Portrait / Landscape)
  • توضیح: حالت عمودی یا افقی بودن صفحه.
  • مثال عملی: Portrait

6) Margins

  • نام پارامتر: Margins (Top/Right/Bottom/Left)
  • نوع داده: Number/String (بسته به پیاده‌سازی)
  • توضیح: حاشیه‌های صفحه. معمولاً با واحدهایی مثل mm, cm, in یا px قابل تنظیم است.
  • مثال عملی: Top: 10mm, Right: 10mm, Bottom: 12mm, Left: 10mm

7) Print Background

  • نام پارامتر: Print Background
  • نوع داده: Boolean
  • توضیح: اگر فعال باشد رنگ پس‌زمینه‌ها و تصاویر پس‌زمینه CSS در PDF چاپ می‌شوند. برای قالب‌های برندینگ بسیار مهم است.
  • مثال عملی: true

8) Scale

  • نام پارامتر: Scale
  • نوع داده: Number
  • توضیح: مقیاس رندر (مثلاً 0.9 یا 1.0 یا 1.1). برای جا شدن محتوا در صفحه کاربرد دارد.
  • مثال عملی: 1

9) Header / Footer Template

  • نام پارامتر: Header Template / Footer Template
  • نوع داده: String (HTML Template)
  • توضیح: HTML جداگانه برای سربرگ و پابرگ چاپ. معمولاً محدودیت‌هایی دارد و فقط برخی CSSها را می‌پذیرد.
  • مثال عملی:

<div style=”font-size:10px;width:100%;text-align:right;”>Page <span class=”pageNumber”></span> of <span class=”totalPages”></span></div>

10) Wait for Network / Timeout (در برخی پیاده‌سازی‌ها)

  • نام پارامتر: Timeout / Wait Until
  • نوع داده: Number/Option
  • توضیح: اگر HTML شما منابع خارجی (تصویر، فونت، CSS) را از اینترنت می‌گیرد، تنظیم زمان انتظار می‌تواند از ناقص شدن PDF جلوگیری کند.
  • مثال عملی: Timeout: 30000 (میلی‌ثانیه)

نکات مهم هنگام پیکربندی

  • فونت فارسی: اگر متن فارسی دارید، بهتر است از فونت‌های در دسترس محیط اجرا استفاده کنید یا فونت را به‌صورت Base64 در CSS Embed کنید؛ در غیر این صورت ممکن است حروف جدا جدا یا ناخوانا شوند.
  • CSS چاپ: از media print و اندازه‌های ثابت استفاده کنید تا شکست صفحات قابل کنترل باشد.
  • منابع خارجی: در محیط‌های محدود (Docker/Server بدون اینترنت) تصاویر یا CSSهای خارجی ممکن است لود نشوند؛ بهتر است فایل‌ها را inline یا به‌صورت Data URI قرار دهید.
  • اندازه تصاویر: تصاویر خیلی بزرگ می‌توانند زمان رندر را زیاد و خروجی را سنگین کنند.

ورودی‌ها و خروجی‌ها

ورودی (Input)

ورودی معمولاً آیتم‌های JSON است که داخل آن یک فیلد شامل HTML تولیدشده قرار دارد (یا HTML مستقیماً در تنظیمات نود نوشته می‌شود). در سناریوهای حرفه‌ای، HTML با Expression از فیلدهای ورودی ساخته می‌شود.

نمونه ساختار ورودی JSON

{ “orderId”: 123, “customer”: { “name”: “Ali Ahmadi”, “email”: “ali@example.com” }, “total”: 250000, “items”: [ { “title”: “Product A”, “qty”: 1, “price”: 150000 }, { “title”: “Product B”, “qty”: 1, “price”: 100000 } ], “html”: “<html>…</html>” }

خروجی (Output)

خروجی معمولاً همان آیتم(های) ورودی است به‌اضافه یک پراپرتی باینری که فایل PDF در آن قرار دارد. سپس می‌توانید این فایل را به نودهای ارسال ایمیل یا ذخیره‌سازی فایل وصل کنید.

نمونه خروجی (نمایش خلاصه ساختار)

{ “orderId”: 123, “customer”: { “name”: “Ali Ahmadi”, “email”: “ali@example.com” }, “total”: 250000, “binary”: { “pdf”: { “fileName”: “invoice-123.pdf”, “mimeType”: “application/pdf”, “fileSize”: 48231, “data”: “…” } } }

نکات پیشرفته و ترفندها

1) ساخت جدول آیتم‌ها به‌صورت پویا با Code node

اگر تعداد آیتم‌ها متغیر است، تولید HTML را در Code node انجام دهید و خروجی را در فیلد html قرار دهید. سپس HTML to PDF همان فیلد را به PDF تبدیل می‌کند.

2) کنترل شکست صفحه (Page Break) در CSS

برای گزارش‌ها و فاکتورهای چندصفحه‌ای، از CSS چاپ استفاده کنید:

<style> .page-break{page-break-after:always;} table{width:100%;border-collapse:collapse;} td,th{border:1px solid #ddd;padding:8px;} </style>

3) Embed کردن تصویر لوگو با Data URI

اگر لوگو از URL لود شود ممکن است در برخی محیط‌ها به PDF نرسد. راه بهتر این است که تصویر را به base64 تبدیل و inline کنید:

<img src=”…” style=”height:40px” />

4) ساخت نام فایل استاندارد و قابل جستجو

  • ترکیب تاریخ + شناسه: invoice-{{$json.orderId}}-{{$now.toFormat(‘yyyyLLdd’)}}.pdf
  • پرهیز از کاراکترهای غیرمجاز در نام فایل (مثل / : * ? ” < > |)

5) بهینه‌سازی حجم PDF

  • تصاویر را قبل از embed کردن کوچک‌سازی کنید.
  • از سایه‌ها و افکت‌های سنگین CSS کمتر استفاده کنید.
  • در صورت امکان، از فونت‌های سبک‌تر استفاده کنید.

محدودیت‌ها و خطاها

محدودیت‌ها

  • پشتیبانی ناقص از برخی CSSها: بعضی ویژگی‌های مدرن CSS ممکن است در رندر PDF دقیق مثل مرورگر نهایی نباشد.
  • وابستگی به محیط اجرا: اگر موتور رندر نیاز به کتابخانه‌های سیستم داشته باشد، در Docker یا سرور ممکن است نیاز به نصب پیش‌نیازها باشد.
  • منابع خارجی: تصاویر/فونت/stylesheetهای بیرونی ممکن است به دلیل محدودیت شبکه، CORS یا DNS لود نشوند.
  • فونت فارسی: اگر فونت مناسب در دسترس نباشد، نمایش فارسی ممکن است به‌هم بریزد.

خطاهای رایج و راه‌حل‌ها

  • PDF سفید یا ناقص: HTML ناقص است یا منابع خارجی لود نشده‌اند. HTML را کامل ارسال کنید، Timeout را افزایش دهید، و منابع را inline کنید.
  • به‌هم‌ریختگی فارسی یا جدا شدن حروف: فونت مناسب تعریف نشده است. فونت فارسی را Embed کنید یا از فونت نصب‌شده روی سیستم استفاده کنید و direction: rtl را تنظیم کنید.
  • عدم نمایش پس‌زمینه‌ها: Print Background غیرفعال است. آن را فعال کنید.
  • بزرگ شدن بیش از حد محتوا: Scale را تنظیم کنید یا از CSS برای کنترل عرض (مثلاً max-width) استفاده کنید.
  • خطای زمان اجرا (Timeout): HTML سنگین است یا تصاویر زیاد هستند. حجم تصاویر را کاهش دهید و زمان انتظار را افزایش دهید.

ایده ها

  • سیستم خودکار صدور گواهی دوره: دریافت نام و نمره از Google Sheets و خروجی PDF گواهی با QR Code
  • ساخت رزومه PDF از فرم آنلاین: دریافت اطلاعات از Typeform و تولید CV با قالب HTML
  • گزارش ماهانه فروش: جمع‌آوری داده از CRM و ارسال PDF به مدیران با ایمیل زمان‌بندی‌شده
  • تولید رسید پرداخت: بعد از تایید پرداخت از درگاه، رسید PDF ساخته و در تلگرام/ایمیل ارسال شود
  • آرشیو خودکار صفحات مهم: دریافت HTML از یک URL (با HTTP Request) و ذخیره نسخه PDF در S3

منابع و مستندات اصلی

دسته بندی: N8N برچسب ها:

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

18 + 13 =