Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to load assets correctly from webpack-generated NPM package?

I'm using webpack to generate the appropriate files for a npm package which will host a few react components. They have some CSS attached, which references some fonts and icons.

When using the file loader, these assets are mis-referenced using their absolute paths (i.e. fonts/my-font.woff) in the main app which are missing.

Is there a way to fix this and make my main app look for the right files? I'd rather fix the package itself than doing things like copying the assets like someone has mentioned as I may not have full control of the main app.

like image 644
Pedro Nascimento Avatar asked May 11 '16 19:05

Pedro Nascimento


People also ask

What is clean webpack plugin?

By default, this plugin will remove all files inside webpack's output. path directory, as well as all unused webpack assets after every successful rebuild.

How do I bundle files in webpack?

You can bundle your JavaScript using the CLI command by providing an entry file and output path. Webpack will automatically resolve all dependencies from import and require and bundle them into a single output together with your app's script. But that's just the bare minimum it can do.

How does webpack import work?

Webpack is a command line tool to create bundles of assets (code and files). Webpack doesn't run on the server or the browser. Webpack takes all your javascript files and any other assets and transforms then into one huge file. This big file can then be sent by the server to a client's browser.


1 Answers

Well, I'm going to preface this by saying that including fonts in a component is usually a bad idea since the main app likely has its own style/branding/etc that you'll be fighting with.

That said, if the fonts are something like icons you could base64 encode them and inline that in the CSS. There are several Webpack encoder plugins to do that.

You also mentioned icons, I would try to convert these to SVG and serve them up inside the code. You could also base64 encode the PNGs into your CSS as a fallback.

The benefits, to this approach:

  • Eliminating HTTP requests in the parent app
  • Parent app always has the latest (non-cached) icons/fonts when you update your package
  • You don't have to worry about paths, packaging external files, etc

Cons I can think of:

  • You're increasing script sizes significantly
  • You lose some caching benefits
  • If you're not the copyright owner of the icons/fonts, this may violate TOS
like image 69
Bryce Howitson Avatar answered Jan 11 '23 06:01

Bryce Howitson