طريقة سهلة للغاية لاستخدام الخطوط المخصصة في رسائل البريد الإلكتروني دون الحاجة إلى استخدام برنامج ART.
customFonts.setDefaults(options)customFonts.setOptions(options)customFonts.svg(options)customFonts.img(options)customFonts.png(options, scale)customFonts.png2x(options)customFonts.png3x(options)customFonts.getAvailableFontPaths()customFonts.getAvailableFontNames()customFonts.customFontsCachenode_modules باستخدام مقاعد OS و PKG-Up (على سبيل المثال ، لا تحتاج إلى كتابة Arial.ttf ، يمكنك فقط كتابة Arial ).glyf و PostScript cff ).alt title style تلقائيًا تلقائيًا color font-size بناءً على الخيارات التي تم تمريرها. ها هي الطريقة القديمة والبطاطية والمعقدة التي ستقوم بها:
؟ لا تحتاج إلى القيام بذلك بعد الآن! ؟ إليك مدى سهولة:
import customFonts from 'custom-fonts-in-emails' ;
import path from 'path' ;
const options = {
text : 'Make something people want' ,
fontNameOrPath : 'GoudyBookletter1911' ,
fontColor : 'white' ,
backgroundColor : '#ff6600' ,
fontSize : 40
} ;
customFonts . png2x ( options )
. then ( console . log )
. catch ( console . error ) ; < img width =" 461 " height =" 51 " src ="  " title =" Make something people want " alt =" Make something people want " style =" color: white;font-size: 25.5px;line-height: 51px;text-align: center;background-color: #ff6600; " >يمكنك الآن استخدام أي خط في رسائل البريد الإلكتروني الخاصة بك - دون الحاجة إلى استخدام برنامج فني مثل Photoshop أو Sketch!
إنه يدعم الخطوط على مستوى النظام و node_modules خارج المربع ، ولكن يمكنك تمرير مسار الملف إذا كنت ترغب في استخدام خط غير قياسي مخصص. يمكنك أيضًا تخصيص kerning ، المرساة ، اللون/التعبئة ، السكتة الدماغية ، حجم الخط (حتى في النقاط إذا لزم الأمر) ، إضافة سمات مخصصة إلى علامة HTML ، والمزيد! شاهد الاستخدام والخيارات ومرجع API أدناه لمزيد من المعلومات.
حتى أنه يستخدم خوارزمية levenshtein السريعة لاكتشاف أقرب مباراة إلى تهجئة الخط (على سبيل المثال في حالة اختلاف Arial مثل Arail ).
باستخدام الخيارات المحددة في نهج جديد أعلاه ، يوفر الكود التالي أمثلة لطرق API لهذه الحزمة.
| طريقة API والمعاينة | نوع الصورة |
|---|---|
customFonts.svg(options) | علامة SVG <svg> |
customFonts.img(options) | علامة IMG <img> مع SVG IM-ended base64 |
customFonts.png(options, scale) | علامة IMG <img> مع PNG IMPED BASE64 |
customFonts.png@2x(options) | علامة IMG <img> مع دقة PNG @2x التي ترميزها BASE64 |
customFonts.png@3x(options) | علامة IMG <img> مع دقة PNG @3x التي ترميزها BASE64 |
أخيرًا ، إليك ما يبدو أن الصورة المكسورة قد حاولت تقديمها بطريقة API. يستفيد من الخيار supportsFallback المحدد أدناه في الخيارات. هذا عازلة مفيدة حقًا لرسائل البريد الإلكتروني غير المتصلة بالإنترنت ، والصور المخزنة مؤقتًا غير صالحة ، وأكثر من ذلك!
npm install -s custom-fonts-in-emails import customFonts from 'custom-fonts-in-emails' ;أو
import {
setDefaults ,
setOptions ,
svg ,
img ,
png ,
png2x ,
png3x ,
getClosestFontName ,
getFontPathsByName ,
getFontPathByName ,
getAvailableFontPaths ,
getAvailableFontNames ,
// optional: this is a cache of all the custom fonts loaded
customFontsCache
} from 'custom-fonts-in-emails' ;إذا كنت تخطط لاستخدام هذا لرسائل البريد الإلكتروني الخارجية ، فستحتاج إلى الاستفادة من Nodemailer و Nodemailer-Base64-to-S3. أو يمكنك ببساطة استخدام LAD ، الذي يحتوي على هذا مدمج بالفعل!
وسيطة options في جميع أساليب API هي كائن يقبل الخصائص التالية:
| ملكية | يكتب | وصف |
|---|---|---|
text | خيط | نص للكتابة باستخدام عائلة الخط المحددة في fontNameOrPath (الافتراضيات لسلسلة فارغة من '' ) |
fontNameOrPath | خيط | اسم أو مسار الملف للخط (الافتراضيات إلى Arial لاحظ أنهما افتراضيًا ، نقوم بتحميل خطوط المستخدمين والشبكة والنظام والنظام ، و node_modules عبر أي نظام تشغيل باستخدام أدوات التشغيل ، حتى تتمكن من استخدام أي خط مثبت!) |
fontSize | الرقم أو السلسلة | حجم الخط بالبكسل ، والذي يتم تقريبه إلى أقرب عدد صحيح كامل (هذا يعين تلقائيًا options.textToSvg.fontSize TextToSvg.Fontsize - الافتراضيات إلى 24px ، لكن لا تحتاج إلى تحديد الملاءمة px حيث يتم تجريدها تلقائيًا وتحويلها إلى أقرب عدد صحيح بالكامل باستخدام Math.round(parseInt(val, 10)) - يجب أن تكون هذه القيمة أكبر من 0) |
fontColor | خيط | لون سداسي سداسي صالح أو قيمة RGBA لتقديم لون ملء النص مع (الافتراضيات إلى #000 ) |
backgroundColor | خيط | لون سداسي سداسي صالح أو قيمة RGBA لتقديم لون الخلفية مع (الافتراضيات إلى transparent ) |
supportsFallback | منطقية | تأكد font-size options.fontSize / 2 صورة الإخراج options.fontColor title color options.fontSize text-align: center alt style كلاهما px تعيينه على line-height options.text customFonts.svg (الإعدادات الافتراضية إلى true ) |
resizeToFontSize | منطقية | تأكد من أن ارتفاع صورة الإخراج يتم تغيير حجمه إلى fontSize ، وعرضه يتم تحجيمه نسبيًا - لا ينطبق على customFonts.svg أو customFonts.img (الافتراضيات إلى false ) |
trim | منطقية | تأكد من تقليص صورة الإخراج باستخدام طريقة Sharp's Trim API - فهي تقلب وحدات البكسل "الممل" من الحواف - لا تنطبق على customFonts.svg أو customFonts.img (الافتراضيات إلى false ) |
trimTolerance | رقم | يجب أن يكون من 1-99 شاملًا ، ويضع قيمة التسامح القطع باستخدام TRIM (الافتراضيات إلى 10 ) |
attrs | هدف | السمة ، أزواج قيمة مفتاح السمة التي سيتم تطبيقها على العلامة التي تم إرجاعها (الإعدادات الافتراضية إلى {} ، على سبيل المثال ، إذا كنت ترغب في جعل إخراج الصورة ارتفاعًا ثابتًا بشكل نسبي ، فيمكنك القيام بـ { style: 'height: 40px; width: auto;' } |
textToSvg | هدف | الخيارات المحددة في TextTOSVG أدناه والتي يتم تمريرها إلى Text to-SVG (ثم Opentype.js): |
| ملكية | يكتب | وصف |
|---|---|---|
x | رقم | الموضع الأفقي لبداية النص (الافتراضيات إلى 0 ) |
y | رقم | الموضع الرأسي للخط الأساسي للنص (الافتراضيات إلى 0 ) |
fontSize | رقم | حجم النص في النقاط (الافتراضية إلى options.fontSize ) |
anchor | خيط | مرساة الكائن في الإحداثيات (الافتراضيات إلى left top - تتكون السلسلة من horizontal vertical ، حيث يمكن أن تكون horizontal واحدة من left أو center أو right ، ويمكن أن تكون vertical واحدة من baseline ، top ، middle ، bottom ) |
attributes | هدف | السمة ، أزواج قيمة مفتاح السمة التي سيتم تطبيقها على العنصر <path> الذي تم إرجاعه داخل علامة <svg> (الافتراضيات إلى { fill: '#000', stroke: 'none' } -لاحظ أنه إذا حددت fontColor ، فسيقوم بتعيين fill المساواة مع fontColor ، ولكن يمكن أن يتم تجاوز هذه السمة على التوالي!) |
customFonts.setDefaults(options)وظيفة تقبل الخيارات لتعيين الإعدادات الافتراضية للاستخدام في المستقبل وإرجاع وعد يحل مع الافتراضيات الحزمة الجديدة.
customFonts.setOptions(options) الوظيفة التي تقبل الخيارات وتُرجع وعدًا يحل مع options مكررة.
customFonts.svg(options) وظيفة تقبل الخيارات وتُرجع وعدًا يحل بسلسلة من علامة <svg> HTML للخط المخصص.
تأخذ هذه الوظيفة options الوسيطة وتمررها إلى customFonts.setOptions .
customFonts.img(options) مثل customFonts.svg ، باستثناء أنه يرجع السلسلة كبيانات base64 مضمّنة.
customFonts.png(options, scale) مثل customFonts.img ، باستثناء أنه يرجع بيانات BASE64 المضمّنة لـ PNG بدلاً من SVG.
كما أنه يقبل اختياريًا scale الأرقام (الإعدادات الافتراضية إلى 1 ) ، مما سيؤدي إلى توسيع نطاق الصورة لدعم شبكية العين.
على سبيل المثال ، إذا كان الخط الذي تم تقديمه هو 20 بكسل ، فسيتضاعف 20 بكسل scale (على سبيل المثال إذا كان scale 2 ، فإن الصورة التي يتم إرجاعها ستكون 20px ولكن سيتم تحجيمها إلى 40px ).
customFonts.png2x(options) مثل customFonts.png ، باستثناء أنه يعيد صورة مع ضعف عدد البكسلات (تضاعف fontSize * 2 وإرجاع صورة مقاس إلى 1x لدعم شبكية العين 2x ، فهي تمر 2 scale ).
customFonts.png3x(options) مثل customFonts.png ، باستثناء أنها تُرجع صورة بثلاثة بكسلات (تضاعف fontSize * 3 وتُرجع صورة تم قياسها إلى 1x لدعم Retina 3x ، وهي تمر 3 scale ).
customFonts.getAvailableFontPaths() وظيفة تقوم بإرجاع مجموعة من مسارات الملفات لجميع خطوط المستخدمين والشبكة المحلية والنظام والمواد node_modules المتوفرة على نظام التشغيل الحالي.
customFonts.getAvailableFontNames() مثل customFonts.getAvailableFontPaths ، باستثناء أنه يعيد أسماء الخطوط بدلاً من مسارات الخط.
customFonts.customFontsCacheهذا هو كائن من جميع الخطوط المخصصة المخزنة مؤقتًا.
MIT © Nick Baugh