On This Page
Raw Import
A plugin that allows usage of ESM syntax to load a file's contents as a string. Inspired by webpack's raw loader. See the plugin's README for complete usage information.
Installation
You can use your favorite JavaScript package manager to install this plugin:
npm i -D @greenwood/plugin-import-raw
yarn add @greenwood/plugin-import-raw --dev
pnpm add -D @greenwood/plugin-import-raw
Then add this plugin to your greenwood.config.js:
import { greenwoodPluginImportRaw } from "@greenwood/plugin-import-raw";
export default {
plugins: [greenwoodPluginImportRaw()],
};
Usage
This will then allow you to import
any text file as a string.
This can be useful for inlining CSS:
import css from "../path/to/styles.css?type=raw";
const template = document.createElement("template");
export default class Header extends HTMLElement {
connectedCallback() {
template.innerHTML`
<styles>
${css}
</styles>
<!-- HTML content goes here -->
`;
this.attachShadow({ mode: "open" });
this.shadowRoot.appendChild(template.content.cloneNode(true));
}
}
customElements.define("app-header", Header);
Or perfect for statically embedding SVGs into HTML:
import logo from "../images/logo.svg?type=raw";
export default class Header extends HTMLElement {
connectedCallback() {
this.innerHTML = `
<header>
<span>My Website</span>
${logo}
</header>
`;
}
}
customElements.define("app-header", Header);