On This Page

  1. Installation
  2. Usage

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);