Una manera extremadamente fácil de usar fuentes personalizadas en correos electrónicos sin tener que usar software de arte.
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 usando el sistema operativo y PKG-up (por ejemplo, no necesita escribir Arial.ttf , simplemente puede escribir Arial ).glyf y PostScript cff ).alt , title y style de color y font-size en función de las opciones aprobadas. Aquí está la forma antigua, lenta y enrevesada que harías esto:
? ¡Ya no necesitas hacer eso! ? Así es lo fácil que es:
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; " >Ahora puede usar cualquier fuente en sus correos electrónicos, ¡sin tener que usar software de arte como Photoshop o Sketch!
Admite las fuentes de todo el sistema y node_modules fuera de la caja, pero puede pasar una ruta de archivo si desea usar una fuente no estándar personalizada. También puede personalizar su kerning, ancla, color/relleno, trazo, tamaño de fuente (incluso en puntos si es necesario), agregar atributos personalizados a la etiqueta HTML y más. Consulte el uso, las opciones y la referencia de API a continuación para obtener más información.
Incluso usa el algoritmo Fast-Levenshtein para detectar la coincidencia más cercana con la ortografía de una fuente (por ejemplo, en caso de que haya malcronizado Arial como Arail ).
Utilizando las opciones definidas en el nuevo enfoque anterior, el siguiente código proporciona ejemplos de los métodos API de este paquete.
| Método API y vista previa | Tipo de imagen |
|---|---|
customFonts.svg(options) | Etiqueta SVG <svg> |
customFonts.img(options) | Etiqueta img <img> con svg en línea codificada en base64 |
customFonts.png(options, scale) | Etiqueta img <img> con PNG en línea codificado Base64 |
customFonts.png@2x(options) | Etiqueta img <img> con resolución PNG @2x codificada en línea de base64 |
customFonts.png@3x(options) | Etiqueta img <img> con resolución png @3x codificada en línea de base64 |
Por último, así es como se ve una imagen rota que se intentó ser representada con un método API. Hace uso de la opción supportsFallback definida a continuación en las opciones. ¡Esta es un retroceso realmente útil para correos electrónicos fuera de línea, imágenes en caché no válidas y más!
npm install -s custom-fonts-in-emails import customFonts from 'custom-fonts-in-emails' ;o
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' ;Si planea usar esto para correos electrónicos de salida, entonces querrá utilizar NodEmailer y NodEmailer-Base64 a S3. ¡O simplemente puedes usar LAD, que ya tiene esto incorporado!
El argumento options en todos los métodos API es un objeto que acepta las siguientes propiedades:
| Propiedad | Tipo | Descripción |
|---|---|---|
text | Cadena | Texto para escribir usando la familia de fuentes especificada en fontNameOrPath (predeterminada en una cadena vacía de '' ) |
fontNameOrPath | Cadena | Nombre o ruta de archivo de la fuente (predeterminada a Arial : tenga en cuenta que, de forma predeterminada, cargamos las fuentes de usuario, locales, redes, sistemas y node_modules en cualquier sistema operativo utilizando el sistema operativo, por lo que puede usar cualquier fuente instalada!) |
fontSize | Número o cadena | Tamaño de fuente en píxeles , que se redondea al entero completo más cercano (esto establece automáticamente options.textToSvg.fontSize : predeterminado a 24px , pero no necesita especificar el Afix px ya que está despojado automáticamente y se converpa al entero completo más cercano usando Math.round(parseInt(val, 10)) - Este valor debe ser mayor que 0)) |
fontColor | Cadena | Color hexagonal válido o valor RGBA para representar el color de relleno de texto con (valores predeterminados a #000 ) |
backgroundColor | Cadena | Color hexadecible válido o valor RGBA para representar el color de fondo con (predeterminado a transparent ) |
supportsFallback | Booleano | Asegúrese options.fontSize / 2 que la imagen de salida tenga title de los atributos de retroceso y font-size alt options.fontSize ambos establecidos en el valor de options.text ) y line-height style que se establece o se concatena con px conjunto text-align: center color options.fontColor customFonts.svg (predeterminado es true ) |
resizeToFontSize | Booleano | Asegúrese de que la altura de la imagen de salida se redicie a fontSize , y su ancho se escala proporcionalmente, no aplicable a customFonts.svg ni customFonts.img (predeterminado a false ) |
trim | Booleano | Asegúrese de que la imagen de salida se recorte utilizando el método API TRIM de Sharp: recorta píxeles "aburridos" de los bordes, no aplicables a customFonts.svg ni customFonts.img (predeterminado a false ) |
trimTolerance | Número | Debe ser de 1-99 inclusive, establece el valor de tolerancia de TRIM usando TRIM (valores predeterminados a 10 ) |
attrs | Objeto | Pares de valor clave de atributo que se aplicarán a la etiqueta devuelta (predeterminada a {} , por ejemplo, si desea que la salida de la imagen sea una altura fija escalada proporcionalmente, entonces puede hacer { style: 'height: 40px; width: auto;' } , esto es útil si desea agregar clases de CSS personalizadas, atributos de estilo u otros atributos en general a las etiquetas de regreso ) |
textToSvg | Objeto | Opciones definidas en TextToSVG a continuación que se pasan a Text-to SVG (y posteriormente OpenType.js): |
| Propiedad | Tipo | Descripción |
|---|---|---|
x | Número | Posición horizontal del comienzo del texto (predeterminado es 0 ) |
y | Número | Posición vertical de la línea de base del texto (predeterminados a 0 ) |
fontSize | Número | Tamaño del texto en puntos (predeterminados a options.fontSize ) |
anchor | Cadena | Ancla de objeto en coordenadas (predeterminada en left top : la cadena consiste en horizontal vertical , donde horizontal puede ser uno de left , center o right y vertical puede ser una de baseline , top , middle , bottom ) |
attributes | Objeto | Atributo Los pares de valor clave de clave que se aplicarán al elemento <path> devuelto dentro de la etiqueta <svg> (predeterminada a { fill: '#000', stroke: 'none' } -¡Tenga en cuenta que si especifica fontColor entonces establecerá fill igual a fontColor , pero puede ser anulado este atributo expícitamente!)) |
customFonts.setDefaults(options)Una función que acepta opciones para establecer valores predeterminados para uso futuro y devuelve una promesa que se resuelve con el nuevo paquete predeterminados.
customFonts.setOptions(options) Una función que acepta opciones y devuelve una promesa que se resuelve con options refinadas.
customFonts.svg(options) Una función que acepta opciones y devuelve una promesa que se resuelve con una cadena de la etiqueta <svg> HTML para la fuente personalizada.
Esta función toma las options de argumento y la pasa a customFonts.setOptions .
customFonts.img(options) Igual que customFonts.svg , excepto que devuelve la cadena como datos de ingreso base64.
customFonts.png(options, scale) Igual que customFonts.img , excepto que devuelve los datos ingresados de Base64 para un PNG en lugar de un SVG.
También acepta opcionalmente una scale de números (valores predeterminados a 1 ), lo que escalará la imagen para el soporte de Retina.
Por ejemplo, si la fuente representada es 20px, se multiplicará 20px por scale (por ejemplo, si scale es 2 , entonces la imagen devuelta será 20px pero se escalará a 40px ).
customFonts.png2x(options) Igual que customFonts.png , excepto que devuelve una imagen con el doble de píxeles (multiplica fontSize * 2 y devuelve una imagen escalada a 1x para soporte de retina 2x, pasa 2 que la scale ).
customFonts.png3x(options) Igual que customFonts.png , excepto que devuelve una imagen con tres tantos píxeles (multiplica fontSize * 3 y devuelve una imagen escalada a 1x para soporte de retina 3x, pasa 3 como la scale ).
customFonts.getAvailableFontPaths() Una función que devuelve una matriz de rutas de archivo para todas las fuentes de usuario, locales, redes, sistemas y node_modules disponibles en el sistema operativo actual.
customFonts.getAvailableFontNames() Lo mismo que customFonts.getAvailableFontPaths , excepto que devuelve nombres de fuentes en lugar de rutas de fuentes.
customFonts.customFontsCacheEste es un objeto de todas las fuentes personalizadas en caché.
MIT © Nick Baugh