Lit SSR

A plugin for using Lit's SSR capabilities as a custom server-side renderer instead of Greenwood's default renderer (WCC), which means you will need to use LitElement as your base class in all instances where you are pre-rendering or using SSR. This plugin also gives the ability to statically generate entire pages and layouts to output completely static sites (SSG). See the plugin's README for complete usage information and additional usage caveats.

Prerequisite

This packages depends on the Lit as a peerDependency. This means you must have Lit already installed in your project.

npm i lit
yarn add lit
pnpm add lit

Installation

You can use your favorite JavaScript package manager to install this plugin.

npm i -D @greenwood/plugin-renderer-lit
yarn add @greenwood/plugin-renderer-lit --dev
pnpm add -D @greenwood/plugin-renderer-lit

For PNPM users, you'll want to add public-hoist-pattern[]=@lit-labs/* to your .npmrc file

Then add this plugin to your greenwood.config.js.

import { greenwoodPluginRendererLit } from "@greenwood/plugin-renderer-lit";

export default {
  prerender: true, // add this if you want SSR at build time
  plugins: [greenwoodPluginRendererLit()],
};

Usage

Now, you can author SSR pages using Lit templates using Greenwood's getBody API or prerender components included via <script> tags.

Below is an example of generating a page of LitElement based Web Components:

import { html } from "lit";
import { getProducts } from "../db/product.js";
import "../components/card.js";

export async function getBody() {
  const products = await getProducts();

  return html`
    ${products.map((product, idx) => {
      const { title, thumbnail } = product;

      return html` <app-card title="${idx + 1}) ${title}" thumbnail="${thumbnail}"></app-card> `;
    })}
  `;
}

Keep in mind you will need to make sure your Lit Web Components are isomorphic and properly leveraging LitElement's lifecycles and browser / Node APIs accordingly for maximum compatibility and portability.