1.0.4 • Published 11 months ago
@saiballo/eleventy-plugin-validate-html v1.0.4
eleventy-plugin-validate-html
A plugin, with options, that runs on the
eleventy.afterevent and validates all the files that were built. Inspired by matt-auckland's plugin
Installation
Available on npm:
npm install @saiballo/eleventy-plugin-validate-html --saveAdd the plugin to your eleventy.config.js:
const pageValidation = require("@saiballo/eleventy-plugin-validate-html");
module.exports =  function(eleventyConfig) {
	eleventyConfig.addPlugin(pageValidation)
};Usage
By default, the plugin checks all pages with the .html or .htm extensions. You can add or change extensions by providing a custom configuration. You can use "extensionList" parameter with a list of extensions (without the dot) separated by commas:
eleventyConfig.addPlugin(pageValidation, {
	"extensionList":  "ext1,ext2"
})This plugin relies on html-validator. This allows you to use some configuration parameters from that package. The complete default configuration that you can override is:
eleventyConfig.addPlugin(pageValidation, {
	"extensionList":  "htm,html",
	"validator":  "WHATWG",
	"isLocal":  false,
	"isFragment":  false,
	"ignore": [],
	"whatwgConfig": {
		"elements": [],
		"rules": {}
	}
})Parameters
// as previously seen, it is a comma-separated list of extensions to check for validation
"extensionList":  "htm,html"
// Possible values: "WHATWG" | "https://validator.w3.org/nu/"
//"WHATWG" is recommended. it will validate against the WHATWG standards.
"validator":  "WHATWG"
// set this to true if you want to validate local urls
"isLocal":  false
// set this to true only if all your pages are not a complete document
// if only certain pages are fragments, you can use "isFragment: true" in these pages as front matter data
"isFragment":  false
// only for "WHATWG" validator. string or array of strings or rules (when using WHATWG) you want the checker to remove in the response. even partial text.
// e.g. "ignore": ["Mismatched close-tag, expected '</div>' but found '</body>'", "another partial error response text"]
"ignore": [],
// only for "WHATWG" validator. additional configuration for elements and rules
"whatwgConfig": {
	"elements": [],
	"rules": {}
}custom WHATWG configuration
// with this example, you add a custom tag called "customtag" to the valid tags in the validation. see https://html-validate.org/guide/metadata/simple-component.html
// additionally, you set the "heading-level" rule to "on" instead of "off". see https://html-validate.org/rules/index.html
"whatwgConfig": {
	"elements": [
		{
			"customtag": {
				"flow": true,
				"phrasing": true
			}
		}
	],
	"rules": {
		"heading-level": "error"
	}
}Front Matter Data
Two parameters can be used as front matter data:
- validateHtml: true|falseto enable or disable validation for individual pages.
- isFragment: true|falseto declare a document as a fragment.
If the parameters are not set, the defaults are:
- validateHtml: true
- isFragment: false
Example:
---
validateHtml: true
isFragment: false
---Team ARMADA 429
- Lorenzo "Saibal" Forti