-
Notifications
You must be signed in to change notification settings - Fork 60
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature request: support loading fonts with raw data #101
Comments
Yes, this feature is possible and scheduled. We'll find some time to implement it soon. |
@zimond |
@snelsi just so you know for the future, to illicit a positive response a better way to phase this question would be "is there anything I can do to help with this feature such as providing ideas, coding, testing or monetary support?" |
Never mind. It indeed takes longer time than estimated. There's an open PR #118 addressing this feature. It works now it you manually built the artifacts. So if this is what you really want, you could try the pr and any feedback is welcomed as it dramatically changed the current API design. |
Hi everyone! I'm having the exact same problem. Everything works on Vercel, except the fonts. Has anyone found a workaround? |
I found a way to make it work on Vercel 🤝 the above link is working and should show you this: Inside your experimental: {
nftTracing: true,
}, For example, my current module.exports = {
pageExtensions: ['public.js'],
eslint: {
ignoreDuringBuilds: true,
},
experimental: {
nftTracing: true,
},
compiler: {
styledComponents: true,
},
i18n: {
locales: ['pt-br'],
defaultLocale: 'pt-br',
},
}; And then, you can resolve the file path like this: const { join, resolve } = require('path');
// ...
const result = await renderAsync(svg, {
fitTo: {
mode: 'width',
value: 1280,
},
font: {
fontFiles: [
join(resolve('.'), 'fonts', 'Roboto-Regular.ttf'),
join(resolve('.'), 'fonts', 'Roboto-Bold.ttf'),
join(resolve('.'), 'fonts', 'NotoEmoji-Bold.ttf'),
],
loadSystemFonts: false,
defaultFontFamily: 'Roboto',
},
}); But, there's still one problem [deprecated, it's working]Despite that it works 100% on Vercel, I can't make it work on Github Actions. @homerjam is there any way to make the module more [edit] Never mind, it's working. [edit2] Implementation is already running in production. It's hosted on Vercel and it's using resvg to create dynamic custom thumbnails of a post, just like Github does, for example: The post: The thumbnail: |
@filipedeschamps do you host the fonts locally? and how did you apply font to each text? |
Yes, in the path join(resolve('.'), 'fonts', 'Roboto-Regular.ttf'),
No, it's being applied globally: defaultFontFamily: 'Roboto', |
Any updates on this? I've tried @filipedeschamps solution, but without any success. My font is located at
I've also tried forgetting about custom fonts and just using system fonts but that didn't work either. On local machine everything is fine, but on vercel deployments text is not rendered.
During local development I just used to have an absolute path, which works perfectly fine, but obviously breaks during deployments...
I've also inspected build output in Vercel and I can see my font file as part of it, but none of the path resolutions from above would work during deployments. |
I'm sorry this is currently halted. Maybe #217 could fit your needs? If so we will try to merge that PR this week. @pondorasti |
Did you manage to find a solution in the end? |
OK, so I got it to work. I'm using Next 13. Here's how: Put the fonts in the root of your repo in a folder called fonts. Strangely this does not show up in the build output. I tried creating a public/fonts folder and that did show up, but the files couldn't be loaded and it didn't work. This is the font section of my opts: font: {
fontFiles: [
join(process.cwd(), 'fonts', 'OpenSans-Medium.ttf'),
join(process.cwd(), 'fonts', 'RobotoMono-Regular.ttf')
], // Load custom fonts.
loadSystemFonts: false, // It will be faster to disable loading system fonts.
defaultFontFamily: 'Roboto Mono' // Set default font family.
}
next.config.js is as follows: const nextConfig = {
reactStrictMode: true,
experimental: {
nftTracing: true
},
outputFileTracing: true
} Successfully picking up the fonts on the Vercel side and rendering them ok! Working project here if you're interested: |
thanks for sharing your findings @arkaydeus, I've got it working too 🤗! Looks like the missing piece was to place the fonts at root instead of the
No kidding, it breaks the Vercel dashboard output page for me. 🤣 Btw, const nextConfig = {
reactStrictMode: true,
- experimental: {
- nftTracing: true
- },
outputFileTracing: true
} |
I'm loading fonts from Fontsource using the wasm version. Not sure if that would fix the problems folks on Vercel are running into, at least temporarily. |
Hello, thanks for this awesome library - I came across it via svg2img.
Would it be possible to support loading fonts via raw data? It's seems this might be possible using the font library dependency https://github.com/RazrFalcon/fontdb#features
The reason is that on Vercel I can't seem to use fonts because file system access is protected/complicated. I've also tried embedding the font in the svg with font-face/data-uri but this doesn't seem to be supported either.
Thanks
The text was updated successfully, but these errors were encountered: