Un moyen extrêmement facile d'utiliser des polices personnalisées dans les e-mails sans avoir à utiliser un logiciel artistique.
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 à l'aide de FONTS OS et PKG-UP (par exemple, vous n'avez pas besoin d'écrire Arial.ttf , vous pouvez simplement écrire Arial ).glyf et PostScript cff COULLES).alt , title et style de color et font-size en fonction des options passées. Voici l'ancienne, lente et alambiquée, vous feriez ceci:
? Vous n'avez plus besoin de faire ça! ? Voici à quel point c'est facile:
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; " >Vous pouvez maintenant utiliser n'importe quelle police dans vos e-mails - sans avoir à utiliser un logiciel d'art comme Photoshop ou Sketch!
Il prend en charge les polices à l'échelle du système et node_modules hors de la boîte, mais vous pouvez passer un chemin de fichier si vous souhaitez utiliser une police non standard personnalisée. Vous pouvez également personnaliser ses créances, son ancre, sa couleur / remplissage, son trait, sa taille de police (même en points si nécessaire), ajouter des attributs personnalisés à la balise HTML, et plus encore! Voir l'utilisation, les options et la référence API ci-dessous pour plus d'informations.
Il utilise même l'algorithme rapide-levenshtein pour détecter la correspondance la plus proche de l'orthographe d'une police (par exemple, au cas où vous seriez mal orthographié Arial comme Arail ).
En utilisant les options définies dans la nouvelle approche ci-dessus, le code suivant fournit des exemples des méthodes API de ce package.
| Méthode API et aperçu | Type d'image |
|---|---|
customFonts.svg(options) | SVG TAG <svg> |
customFonts.img(options) | Tag IMG <img> avec SVG en ligne codé en ligne Base64 |
customFonts.png(options, scale) | Tag IMG <img> avec PNG en ligne en ligne de base64 |
customFonts.png@2x(options) | Tag IMG <img> avec Résolution en ligne en ligne en ligne de base64 |
customFonts.png@3x(options) | Tag IMG <img> avec Résolution en ligne en ligne en ligne de base64 |
Enfin, voici à quoi ressemble une image cassée qui a été tenté d'être rendu avec une méthode API. Il utilise l'option supportsFallback défini ci-dessous dans les options. Il s'agit d'un repli très utile pour les e-mails hors ligne, des images mises en cache non valides, et plus encore!
npm install -s custom-fonts-in-emails import customFonts from 'custom-fonts-in-emails' ;ou
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 vous prévoyez de l'utiliser pour les e-mails sortants, vous voudrez utiliser Nodemailer et Nodemailer-Base64 à-S3. Ou vous pouvez simplement utiliser Lad, qui a déjà cette partie intégrée!
L'argument options dans toutes les méthodes API est un objet qui accepte les propriétés suivantes:
| Propriété | Taper | Description |
|---|---|---|
text | Chaîne | Texte à écrire en utilisant la famille de police spécifiée dans fontNameOrPath (par défaut, une chaîne vide de '' ) |
fontNameOrPath | Chaîne | Nom ou chemin de fichier de la police (par défaut, Arial - Notez que par défaut, nous chargeons les polices d'utilisateur, local, réseau, système et node_modules sur n'importe quel système d'exploitation à l'aide de FONTS OS, afin que vous puissiez utiliser n'importe quelle police installée!) |
fontSize | Numéro ou chaîne | Taille px 24px police dans les pixels , qui est arrondi à entier entier le plus proche Math.round(parseInt(val, 10)) cela définit automatiquement options.textToSvg.fontSize . |
fontColor | Chaîne | Couleur hexagonale valide ou valeur RGBA pour rendre la couleur de remplissage de texte avec (par défaut à #000 ) |
backgroundColor | Chaîne | Couleur hexagonale valide ou valeur RGBA pour rendre la couleur d'arrière-plan avec (par défaut est transparent ) |
supportsFallback | Booléen | Assurez-vous que l'image de sortie a title des attributs de secours et alt (tous deux définis sur la valeur d' options.text ), et style qui est défini ou concaténé avec color définies sur options.fontColor , font-size définie sur options.fontSize / 2 (pour le centrage vertical, nous text-align: center par 2), line-height définie sur px options.fontSize customFonts.svg (par défaut est true ) |
resizeToFontSize | Booléen | Assurez-vous que la hauteur de l'image de sortie est redimensionnée pour fontSize , et sa largeur est proportionnellement mise à l'échelle - sans applicable à customFonts.svg ni customFonts.img (par défaut est false ) |
trim | Booléen | Assurez-vous que l'image de sortie est coupée à l'aide de la méthode de l'API de TRIM de Sharp - il coupe les pixels "ennuyeux" des bords - sans s'appliquer à customFonts.svg ni customFonts.img (par défaut à false ) |
trimTolerance | Nombre | Doit être de 1 à 99 inclusivité, définit la valeur de tolérance de finition à l'aide de la garniture (par défaut à 10 ) |
attrs | Objet | Paires de valeurs de clé d'attribut qui seront appliquées à la balise renvoyée (par défaut à {} , par exemple si vous souhaitez faire de la sortie de l'image une taille fixe à l'échelle proportionnellement, alors vous pouvez faire { style: 'height: 40px; width: auto;' } , cela est utile si vous voulez ajouter des classes CSS personnalisées, des attributs de style ou d'autres attributs en général aux balises retournées )) |
textToSvg | Objet | Options définies dans TextTosvg ci-dessous qui sont transmises à Text-to-Svg (et par la suite OpenType.js): |
| Propriété | Taper | Description |
|---|---|---|
x | Nombre | Position horizontale du début du texte (par défaut à 0 ) |
y | Nombre | Position verticale de la ligne de base du texte (par défaut à 0 ) |
fontSize | Nombre | Taille du texte en points (par défaut aux options.fontSize ) |
anchor | Chaîne | L'ancre de l'objet en coordonnées (par défaut en left top - la chaîne se compose d' horizontal vertical , où horizontal peut être l'un de left , center ou right , et vertical peut être l'une des baseline , du top , middle , bottom ) |
attributes | Objet | Paires de valeurs de clé d'attribut qui seront appliquées à l'élément <path> renvoyé à l'intérieur de la balise <svg> (par défaut à { fill: '#000', stroke: 'none' } - Notez que si vous spécifiez fontColor , il définira fill égal à fontColor , mais qu'il peut être remplacé cet attribut explicitement!) |
customFonts.setDefaults(options)Une fonction qui accepte les options de définition par défaut pour une utilisation future et renvoie une promesse qui résout avec les nouveaux paramètres par défaut.
customFonts.setOptions(options) Une fonction qui accepte les options et renvoie une promesse qui résout avec options raffinées.
customFonts.svg(options) Une fonction qui accepte les options et renvoie une promesse qui résout avec une chaîne de la balise HTML <svg> pour la police personnalisée.
Cette fonction prend les options d'argument et la transmet sur customFonts.setOptions .
customFonts.img(options) Identique à customFonts.svg , sauf qu'il renvoie la chaîne en tant que données incorporées Base64.
customFonts.png(options, scale) Identique à customFonts.img , sauf qu'il renvoie les données incorporées Base64 pour une PNG au lieu d'un SVG.
Il accepte également éventuellement une scale de numéros (par défaut à 1 ), qui fera évoluer l'image pour la prise en charge de la rétine.
Par exemple, si la police rendue est de 20px, elle multipliera 20Px par scale (par exemple, si scale est 2 , alors l'image renvoyée sera 20px mais elle sera mise à l'échelle à 40px ).
customFonts.png2x(options) Identique à customFonts.png , sauf qu'il renvoie une image avec deux fois plus de pixels (il multiplie fontSize * 2 et renvoie une image mise à l'échelle à 1x pour le support de rétine 2x, il passe 2 comme scale ).
customFonts.png3x(options) Identique à customFonts.png , sauf qu'il renvoie une image avec trois autant de pixels (il multiplie fontSize * 3 et renvoie une image mise à l'échelle à 1x pour le support de rétine 3X, il passe 3 comme scale ).
customFonts.getAvailableFontPaths() Une fonction qui renvoie un tableau de chemins de fichier pour toutes les polices d'utilisateur, local, réseau, système et node_modules disponibles sur le système d'exploitation actuel.
customFonts.getAvailableFontNames() Identique à customFonts.getAvailableFontPaths , sauf qu'il renvoie des noms de police au lieu des chemins de police.
customFonts.customFontsCacheCeci est un objet de toutes les polices personnalisées mises en cache.
MIT © Nick Baugh