Metas

Automatically add <meta> tags for SEO and social networks.

Options

extensions string[]

The list extensions this plugin applies to

name string

The key name for the transformations definitions

Description

This plugin generates <meta> tags in your HTML pages for Open graph, Twitter cards, Schema.org, and SEO purposes. The data must be defined in the metas keyword of every page and the supported values are:

  • type: The page type (by default is website).
  • site: The name of the site.
  • title: The title of the page, article, post, etc.
  • lang: The language of the page.
  • description: Page description.
  • image: The main image of the page, article, post, etc.
  • icon: The logotype or icon of the site.
  • keywords: An array of keywords.
  • twitter: The twitter username.
  • fediverse: The fediverse handler for author atribution.
  • color: The color theme of the website. It can be a string with a single color (like #fff) or an array of two colors for light and dark mode (i.e. ["white", "black"]).
  • robots: Configuration for search engines (a boolean to enable/disable or a string with a custom value).
  • generator: The software that generated the page (Lume v1.x). It can be true to autogenerate or a string with a custom value.

Installation

Import this plugin in your _config.ts file to use it:

import lume from "lume/mod.ts";
import metas from "lume/plugins/metas.ts";

const site = lume();

site.use(metas(/* Options */));

export default site;

Usage

In a data file (like /_data.yml) in the root of your project, add the default values.

metas:
  site: Oscar's blog
  twitter: "@misteroom"
  fediverse: "@misteroom@mastodon.gal"
  icon: /img/icon.png
  lang: en
  generator: true

You can complete the meta values with the specific values for every page. For example:

---
metas:
  title: Hello world
  description: My first post
  image: /hello-world.png
---

This is my first post

The output HTML page will include the <meta> tags with the result of merging the default values with the specific page values. It should be something similar to:

<html>
  <head>
    <meta property="og:type" content="website" />
    <meta property="og:site_name" content="Oscar's blog" />
    <meta property="og:locale" content="en" />
    <meta property="og:title" content="Hello world" />
    <meta property="og:description" content="My first post" />
    <meta property="og:url" content="http://example.com/" />
    <meta property="og:image" content="http://example.com/hello-world.png" />
    <meta name="twitter:card" content="summary_large_image" />
    <meta name="twitter:site" content="@misteroom" />
    <meta name="fediverse:creator" content="@misteroom@mastodon.gal" />
    <meta itemprop="name" content="Hello world" />
    <meta itemprop="description" content="My first post" />
    <meta itemprop="image" content="http://example.com/hello-world.png" />
    <meta name="description" content="My first post" />
    <meta name="generator" content="Lume v1.10.1" />
  </head>
  <body>
    <p>This is my first post</p>
  </body>
</html>

Field aliases

Field aliases allow to use an existing value in the metas. Aliases start with = following by the field name:

title: This is the title

metas:
  title: "=title" # Alias to the title value

It's also possible to use dots for subvalues:

title: This is the title
intro:
  text: Page description
metas:
  title: "=title"
  description: "=intro.text"

As of Lume 1.17.0 is possible to use CSS selectors using the $ prefix:

metas:
  title: "$ h1" # Use the content of the first <h1> element
  image: "$ img.cover attr(src)" # Use the src attribute of img.cover element

As of Lume 2.4.0 is possible to use different fallbacks separated with ||:

metas:
  title: "=title || $ h1 || Default title"

In the example above, the plugin will try to get the value from the title variable, if it doesn't exist, get the value from the h1 CSS selector, and if it doesn't exist, use the Default title value.

Additional values

As of Lume 2.2, any additional value is used to create a custom <meta> tag. For example the following metas object has additional twitter:* keys:

title: Lume is awesome
author: Dark Vader
metas:
  title: =title
  "twitter:label1": Reading time
  "twitter:data1": 1 minute
  "twitter:label2": Written by
  "twitter:data1": =author

This configuration generates the following code:

<meta name="title" content="Lume is awesome" />
<meta name="twitter:label1" content="Reading time" />
<meta name="twitter:data1" content="1 minute" />
<meta name="twitter:label2" content="Written by" />
<meta name="twitter:data2" content="Dark Vader" />