On This Page
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.