GitHub - zandaqo/esbuild-plugin-lit: Import CSS, SVG, HTML, XLIFF files as tagged-template literals. (original) (raw)

esbuild-plugin-lit

npm

A plugin for esbuild that allows importing CSS, SVG, HTML, XLIFF files as tagged-template literals. The files are (optionally) minified using esbuild minifier (for CSS), html-minifier (for HTML), andsvgo (for SVG).

Installation

npm i esbuild-plugin-lit -D

Usage

Include plugin in your build script:

const { default: litPlugin } = require("esbuild-plugin-lit");

require("esbuild").build({ entryPoints: ["index.ts"], bundle: true, outfile: "index.js", minify: true, plugins: [litPlugin()], });

Now you can import CSS, SVG, HTML files as tagged-template literals:

import styles from 'styles.css'; import icon from 'icon.svg';

class SpecialButton extends LitElement { static styles = styles; ... render() { return html <button> <span class="icon">${icon}</span> </button> } }

TypeScript

For TypeScript support, include ambient module types in your config file:

{ "include": ["./node_modules/esbuild-plugin-lit/modules.d.ts"] }

Customization & Loading SASS, LESS, etc.

The plugin supports setting custom file extensions and transformation for each imported types, for example, the following with load SASS files:

const { default: litPlugin } = require("esbuild-plugin-lit"); const SASS = require("sass");

require("esbuild").build({ ... plugins: [litPlugin( { // augment the global filter filter: /.(css|svg|html|xlf|scss)$/, css: { // specify extension for css extension: /.s?css$/, transform: (data) => Sass.renderSync({ data }).css.toString(), }, }, )], });

Minification

If minification is set for esbuild (minify: true), the plugin will minify imported CCS files using esbuild's built-in minifier. You can setminify: false in settings for CSS to opt-out from minification:

require("esbuild").build({ ... plugins: [litPlugin({ css: { minify: false, }, })], });

To minify SVG and HTML files, the plugin uses svgo and html-minifierpackages respectively, so make sure they are installed if such minification is required:

npm i svgo -D npm i html-minifier -D

Then supply the minifiers' options to the plugin:

require("esbuild").build({ ... minify: true, plugins: [litPlugin({ svg: { svgo: { plugins: [ "preset-default", "removeXMLNS", ], }, }, html: { htmlMinifier: {}, // use the default options }, })], });

Loading XLIFF localization files

Lit provides lit-localize package for localization purposes. When used in the so-called runtime mode, the package relies on a set of rollup based tools to extract messages from templates into XLIFF localization files (lit-localize extract), and to later compile them into "importable" JS files using lit-localize build.

With esbuild-plugin-lit one can skip the build step and "load" XLIFF files directly as shown in ourexample project:

... // Load xliff files statically import * as ce from "./xliff/ce.xlf"; import * as es from "./xliff/es.xlf";

const locales = new Map( [["ce", ce], ["es", es]], );

const { setLocale } = configureLocalization({ sourceLocale: "en", targetLocales: ["ce", "es"], loadLocale: async (locale) => locales.get(locale), }); ...

The files are compiled on the fly by esbuild, thus, simplifying the toolchain and speeding up the process.

To load XLIFF files, install tmxl:

And set xlf option:

require("esbuild").build({ ... loader: { ".xlf": "text", }, plugins: [litPlugin({ xlf: {}, // use default settings })], });

Using with Deno

The plugin also supports building with Deno:

import * as esbuild from "https://deno.land/x/esbuild@v0.15.7/mod.js"; import { denoPlugin } from "https://deno.land/x/esbuild_deno_loader@0.5.2/mod.ts"; import pluginLit from "https://raw.githubusercontent.com/zandaqo/esbuild-plugin-lit/master/mod.ts";

await esbuild .build({ plugins: [ pluginLit({ specifier: "https://cdn.skypack.dev/lit@2.3.1?dts", }), denoPlugin(), ], entryPoints: ["./main.ts"], outfile: "./main.js", target: "es2022", format: "esm", bundle: true, minify: true, sourcemap: true, });

esbuild.stop();

Though, keep in mind that Denodoes not support ambient module typing (declare module) and each asset import has to be typed using// @deno-types.

LICENSE

MIT @ Maga D. Zandaqo