Skip to content

Template Projection

You can create templates in Astro SFC's by using a function called useTemplaterAndProjector. It's a function that returns two components in a tuple. Templater and Projector. Templater is a component that is supposed to have a child. The content inside the child is a template that needs to be rendered. Projector is the component that renders the content in Define template.

The two components can send props to each other through using a prop called the context. The context is an object literal that holds information that needs to be used.

There are two of them.

  • The projector context the information sent from the projector to the templater.
  • The templater context the information sent from the templater to the projector.

To use either context you will need to use a function child. The templater function child can either accept the context and slot or just a slot. The projector function child can only accept the context.

Use Templater and Projector

function useTemplaterAndProjector<
ProjectorProps extends Record<string, unknown> | null,
TemplaterProps extends Record<string, unknown> | null = null,
>(
debugName?: string,
): [
Templater<ProjectorProps, TemplaterProps>,
Projector<TemplaterProps, ProjectorProps>,
];

The use templater and projector function returns two Astro Components.

It uses two generics that influence the types for components returned.

When you pass in a context into templater. The projector is expected to return a function as it's child with it as the first argument. When you pass in a context and a slot into projector the templater is expected to receive it as the first argument. If only a slot is injected into projector then the templater will get it as the first argument.

These ideas are enforced on the type level.

The only argument that can be passed to this function is called a debug name. The debug name is a name that is used during errors. It's used to identify which component threw an error all you have to do is look at the cause in the error page that astro sends you. The names Templater or Projector will be used as a part of the cause.

Templater

A component that requires a child. That child is stored so that it could be used by Projector. The child could either be a function, html or a string. When the child is a function the function can either accept an object or an object with a slot as it's arguments.

When the slot is passed it must be evaluated as an expression. The slot could either return something for templater to render or nothing.

The only prop that can be passed is the context=. When passed the projector will receive it as the first argument to it's function child.

Usage

Projector

A component that is used to render the child of Templater. It's a component that can pass in a slot as it's child. It's only required to pass in a child only! when templater passes in a context and a projector context is passed. When activated it can pass it's context to the templater to use.

Usage

Limitations