@mcansh/vite-svg-sprite-plugin
this vite plugin will transform any imported svg files and combine them into an svg sprite sheet
installation and set up
npm i -D @mcansh/vite-svg-sprite-plugin
this is an example using Remix, but this plugin works with any vite configuration
import { createSvgSpritePlugin } from "@mcansh/vite-svg-sprite-plugin";
import { vitePlugin as remix } from "@remix-run/dev";
import { defineConfig } from "vite";
import tsconfigPaths from "vite-tsconfig-paths";
export default defineConfig({
plugins: [remix(), tsconfigPaths(), createSvgSpritePlugin()],
});
you can configure the generated sprite file name as well as the generated symbol id pattern
// these are the default options
createSvgSpritePlugin({
spriteOutputName: "sprite.svg",
symbolId: "icon-[name]-[hash]",
});
usage
import spriteUrl from "virtual:@mcansh/vite-svg-sprite-plugin";
import linkIconHref from "@primer/octicons/build/svg/link-16.svg";
import type { LinksFunction } from "@remix-run/node";
export const links: LinksFunction = () => {
return [{ rel: "preload", as: "image", href: spriteUrl, type: "image/svg+xml" }];
};
export default function Component() {
return (
<svg className="size-4" aria-hidden>
<use href={linkIconHref} />
</svg>
);
}