Uma maneira extremamente fácil de usar fontes personalizadas em e -mails sem ter que usar o 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-fonts e pkg-up (por exemplo, você não precisa escrever Arial.ttf , você pode apenas escrever Arial ).glyf e PostScript cff ).alt , title e style de color e font-size com base nas opções aprovadas. Aqui está a maneira antiga, lenta e complicada da maneira que você faria isso:
? Você não precisa mais fazer isso! ? Veja como é fácil:
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; " >Agora você pode usar qualquer fonte em seus e -mails - sem precisar usar software de arte como Photoshop ou Sketch!
Ele suporta fontes em todo o sistema e node_modules prontos para uso, mas você pode passar um caminho de arquivo se desejar usar uma fonte não padrão personalizada. Você também pode personalizar seu kerning, âncora, cor/preenchimento, curso, tamanho da fonte (mesmo em pontos, se necessário), adicione atributos personalizados à tag HTML e muito mais! Veja o uso, as opções e a referência da API abaixo para obter mais informações.
Ele até usa o algoritmo de fast-levenshtein para detectar a partida mais próxima da ortografia de uma fonte (por exemplo, caso você tenha corado mal Arial como Arail ).
Usando as opções definidas na nova abordagem acima, o código a seguir fornece exemplos dos métodos da API deste pacote.
| Método da API e visualização | Tipo de imagem |
|---|---|
customFonts.svg(options) | Tag SVG <svg> |
customFonts.img(options) | Tag IMG <img> com Base64 codificado em linha SVG |
customFonts.png(options, scale) | Tag IMG <img> com Base64 codificado em linha em linha PNG |
customFonts.png@2x(options) | Tag IMG <img> com Base64 codificada em linha PNG @2x Resolução |
customFonts.png@3x(options) | Tag IMG <img> com base em linha de base |
Por fim, aqui está uma imagem quebrada que parece ter tentada de ser renderizada com um método da API. Ele utiliza a opção supportsFallback definido abaixo nas opções. Este é um fallback realmente útil para e -mails offline, imagens em cache inválidas e muito mais!
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' ;Se você planeja usar isso para e-mails de saída, você deseja usar o NodeMailer e o NodeMailer-Base64-to-S3. Ou você pode simplesmente usar o LAD, que já tem esse embutido!
O argumento options em todos os métodos da API é um objeto que aceita as seguintes propriedades:
| Propriedade | Tipo | Descrição |
|---|---|---|
text | Corda | Texto para gravar usando a família de fontes especificada no fontNameOrPath (padrão para uma sequência vazia de '' ) |
fontNameOrPath | Corda | Nome ou caminho do arquivo da fonte (Padrões para Arial -Observe que, por padrão, carregamos fontes de usuário, local, rede, sistema e node_modules em qualquer sistema operacional usando OS-Fonts, para que você possa usar qualquer fonte instalada!) |
fontSize | Número ou string | O tamanho da fonte em pixels , que é arredondado para o número inteiro inteiro mais próximo (isso define automaticamente options.textToSvg.fontSize - padrão é de 24px , mas você não precisa especificar o Afixo px pois é retirado automaticamente e convertido para o inteiro inteiro mais próximo que o número Math.round(parseInt(val, 10)) - e convertido no inteiro inteiro mais próximo) (Val 10) - |
fontColor | Corda | Cor hexadecimal válida ou valor RGBA para renderizar a cor do texto com (padrão para #000 ) |
backgroundColor | Corda | Cor hexadecimal válida ou valor RGBA para renderizar a cor de fundo (padrão para transparent ) |
supportsFallback | Booleano | Certifique-se de que a imagem de saída tenha atributos de fallback title e alt (ambos definidos para o valor de options.text ) e style que é definido ou concatenado com color definidas como options.fontColor , font-size definido para options.fontSize options.fontSize / 2 (para centralização px We Divide by 2), o conjunto line-height para text-align: center customFonts.svg (Padrões para true ) |
resizeToFontSize | Booleano | Certifique -se de que a altura da imagem de saída seja redimensionada para fontSize e sua largura é proporcionalmente escalonada - não aplicável ao customFonts.svg nem customFonts.img (padrão para false ) |
trim | Booleano | Certifique -se de que a imagem de saída seja aparada usando o método da API de TRIM da Sharp - ela apara pixels "entediantes" das bordas - não aplicável ao customFonts.svg nem customFonts.img (Padrões para false ) |
trimTolerance | Número | Deve ser de 1-99 inclusive, define o valor da tolerância a acabamentos usando acabamento (padrões para 10 ) |
attrs | Objeto | Atributo pares de valor-chave que serão aplicados à tag retornada (padrão para {} , por exemplo, se você deseja fazer com que a imagem tenha uma altura fixa em escala proporcionalmente proporcionalmente, você pode fazer { style: 'height: 40px; width: auto;' } , isso é útil se você deseja adicionar as classes CSS personalizadas, atributos de estilo, ou outros atributos, ou outros atributos, ou outros atribuídos, ou outros atribuídos, ou outros atributos de css, ou outros atributos de css, ou outros, ou outros atribuições de css adicionais, ou outros atributos de css adicionais, ou outros, ou outros, ou outros atribuições de css . |
textToSvg | Objeto | Opções definidas no TextToSVG abaixo, que são passadas para o texto para SVG (e posteriormente openType.js): |
| Propriedade | Tipo | Descrição |
|---|---|---|
x | Número | Posição horizontal do início do texto (padrão para 0 ) |
y | Número | Posição vertical da linha de base do texto (padrão para 0 ) |
fontSize | Número | Tamanho do texto em pontos (padrão para options.fontSize ) |
anchor | Corda | Âncora do objeto em coordenadas (padrões para left top - a corda consiste em horizontal vertical , onde horizontal pode ser de left , center ou right e vertical pode ser de baseline , top , middle , bottom ) |
attributes | Objeto | Atributo pares de valor-chave que serão aplicados ao elemento <path> retornado dentro da tag <svg> (padrão para { fill: '#000', stroke: 'none' } -observe que, se você especificar fontColor , ele definirá fill igual ao fontColor , mas pode ser substituído esse atributo explicitamente!) |
customFonts.setDefaults(options)Uma função que aceita opções para definir padrões para uso futuro e retorna uma promessa que resolve com os novos padrões do pacote.
customFonts.setOptions(options) Uma função que aceita opções e retorna uma promessa que resolve com options refinadas.
customFonts.svg(options) Uma função que aceita opções e retorna uma promessa que resolve com uma string da tag <svg> html para a fonte personalizada.
Esta função leva as options de argumento e a passa para o customFonts.setOptions .
customFonts.img(options) O mesmo que customFonts.svg , exceto que retorna a sequência como Base64 Dados Inlinados.
customFonts.png(options, scale) O mesmo que customFonts.img , exceto que retorna os dados inlinados base64 para um PNG em vez de um SVG.
Opcionalmente, ele também aceita uma scale numérica (padrão para 1 ), que dimensionará a imagem para o suporte da retina.
Por exemplo, se a fonte renderizada for 20px, ela multiplicará 20px por scale (por exemplo, se scale for 2 , a imagem retornada será 20px , mas será dimensionada para 40px ).
customFonts.png2x(options) O mesmo que customFonts.png , exceto que retorna uma imagem com o dobro de pixels (multiplica fontSize * 2 e retorna uma imagem escalada a 1x para suporte de retina 2x, ele passa 2 como a scale ).
customFonts.png3x(options) O mesmo que customFonts.png , exceto que retorna uma imagem com três pixels (multiplica fontSize * 3 e retorna uma imagem escalada a 1x para o suporte da retina 3x, ele passa 3 como a scale ).
customFonts.getAvailableFontPaths() Uma função que retorna uma matriz de caminhos de arquivo para todas as fontes de usuário, local, rede, sistema e node_modules disponíveis no sistema operacional atual.
customFonts.getAvailableFontNames() O mesmo que customFonts.getAvailableFontPaths , exceto que ele retorna nomes de fontes em vez de caminhos de fonte.
customFonts.customFontsCacheEste é um objeto de todas as fontes personalizadas em cache.
Mit © Nick Baugh