Skip to main content
  1. WolfspyreLabs Shortcodes Theme/

AutoGen

I’ve declared the following configuration knobs

Global Attributes #

Global Enablement #

Site.Params.sitemeta.enabled
Bool (Default: false)
Controls if we do a god damned thing.
If this parameter is false All processing is aborted.

Color #

Site.Params.sitemeta.sitecolor
RGB Hex (Default: #000000)
The Hex Value Web Color associated with the site’s theme.

Author #

Site.Params.sitemeta.siteauthor
String (Default: null)
If set, this will be used as the site author.
If null, we default to $.Site.Title

Description #

Site.Params.sitemeta.sitedesc
String (Default: null)
If set, this will be used as the site description.
If null, we default to $.Site.BaseURL

Language #

Site.Params.sitemeta.sitelang
String (Default: null)
If set, this will be used as the Site lang.
If null, we default to $.Site.Params.isocode

Short Name #

Site.Params.sitemeta.siteshortname
String (Default: null)
If set, this will be used as the Site short_name.
If null, we default to $.Site.Title

Title #

Site.Params.sitemeta.sitetitle
String (Default: null)
If set, this will be used as the Site name.
If null, we default to $.Site.Title

URL #

Site.Params.sitemeta.siteurl
URL (Default: null)
If set, this will be used as the site start_url.
If null, we default to $.Site.BaseURL

Source Image #

Site.Params.sitemeta.sourceimage
String (Default: null)
This is the full-sized image that will be used by default to create the rest of the images, unless an alternate is specified in a narrower scope.

Meta Tags #

Site.Params.sitemeta.metatags
Slice (Default: name)
There are several metadata tags included in site headers. The supported attribute keys at time of writing are charset, content, http-equiv, name

Each tag has an attribute key, and a content key, which stores the associated value string.

FavIcon #

Site.Params.sitemeta.favicon
Dict (Default: generate: true) Whether or not to create/populate favicon metadata and files.

Params.yaml config: #

.Site.Params.sitemeta.webmanifest

sitemeta

webmanifest

{
  "background_color": "auto",
  "debug": false,
  "dir": "ltr",
  "display": "standalone",
  "icons": {
    "defaultimage": "sitemeta/img/wpl-1024-src.png",
    "generate": [
      {
        "color": "auto",
        "format": "svg",
        "inclsize": false,
        "mimetype": "image/svg+xml",
        "postfix": "",
        "prefix": "safari-pinned-tab",
        "purpose": "any",
        "rel": "mask-icon",
        "sizes": [
          "any"
        ],
        "src": "sitemeta/img/WPLMono.svg"
      },
      {
        "format": "png",
        "inclsize": true,
        "mimetype": null,
        "postfix": "",
        "prefix": "apple-touch-icon",
        "purpose": "any",
        "rel": "apple-touch-icon",
        "sizes": [
          "16",
          "32",
          "57",
          "72",
          "114",
          "144"
        ],
        "src": "sitemeta/img/favicon.png"
      },
      {
        "format": "png",
        "inclsize": false,
        "mimetype": null,
        "postfix": "",
        "prefix": "apple-touch-icon",
        "purpose": "any",
        "rel": "apple-touch-icon",
        "sizes": [
          "512"
        ],
        "src": "sitemeta/img/favicon.png"
      },
      {
        "format": "png",
        "inclsize": true,
        "mimetype": null,
        "postfix": "precomposed",
        "prefix": "apple-touch-icon-precomposed",
        "purpose": "any",
        "rel": "apple-touch-icon-precomposed",
        "sizes": [
          "57",
          "72",
          "114",
          "144"
        ],
        "src": "sitemeta/img/wpl-1024-src.png"
      },
      {
        "format": "png",
        "inclsize": false,
        "mimetype": null,
        "postfix": "precomposed",
        "prefix": "apple-touch-icon",
        "purpose": "any",
        "rel": "apple-touch-icon-precomposed",
        "sizes": [
          "512"
        ],
        "src": "sitemeta/img/wpl-1024-src.png"
      },
      {
        "format": "ico",
        "inclsize": false,
        "mimetype": "image/x-icon",
        "prefix": "favicon",
        "purpose": "any",
        "rel": "icon",
        "sizes": [
          "48"
        ],
        "src": "sitemeta/img/favicon.ico"
      },
      {
        "format": "svg",
        "inclsize": false,
        "mimetype": "image/svg+xml",
        "postfix": "",
        "prefix": "favicon",
        "purpose": "any",
        "rel": "icon",
        "sizes": [
          "any"
        ],
        "src": "sitemeta/img/WolfspyreSquare-1024.svg"
      },
      {
        "format": "png",
        "inclsize": true,
        "mimetype": null,
        "postfix": "",
        "prefix": "favicon",
        "purpose": "any",
        "rel": "icon",
        "sizes": [
          16,
          32
        ],
        "src": "sitemeta/img/favicon.png"
      },
      {
        "format": "png",
        "inclsize": true,
        "mimetype": null,
        "postfix": "",
        "prefix": "android-chrome",
        "purpose": "any",
        "rel": "icon",
        "sizes": [
          512,
          256,
          192,
          128
        ],
        "src": "sitemeta/img/wpl-1024-src.png"
      },
      {
        "format": "png",
        "inclsize": false,
        "mimetype": null,
        "postfix": "",
        "prefix": "apple-touch-icon",
        "purpose": "any",
        "rel": "icon",
        "sizes": [
          64
        ],
        "src": "sitemeta/img/wpl-1024-src.png"
      }
    ],
    "version": "0.2"
  },
  "orientation": "natural",
  "scope": "/"
}

BrowserConfig #

Site.Params.sitemeta.browserconfig.generate
Bool (Default: true)
Controls if we should generate the browserconfig.xml asset.
Site.Params.sitemeta.browserconfig.images.generate.src
File (Default null)
The source image to use to generate the images for browserconfig.
If null, we use the sourceimage asset declared for the sitemeta scope.
Site.Params.sitemeta.browserconfig.images.generate.variants
Dict (Default:)
Site.Params.sitemeta.browserconfig.images.generate.version
String (Default: 1.0 )
appended to the image resource declaration inside the generated browserconfig file.
Site.Params.sitemeta.browserconfig.include
Bool (Default: true)
Controls if we should include the browserconfig.xml asset in the header metadata.
Site.Params.sitemeta.browserconfig.target
String (Default: browserconfig.xml)
The target to populate from the browserconfig template.
This should usually just be browserconfig.xml
Site.Params.sitemeta.browserconfig.template
String (Default: sitemeta/browserconfig.xml-template)
The template file to use to generate the browserconfig file.
This should usually just be sitemeta/browserconfig.xml-template.
Template Location: note
For the template generation to work as anticipated, it’s expected that these templates will be pathed relative to your site’s assets directory.
Site.Params.sitemeta.browserconfig.tilecolor
RGB Hex (Default: undef)
If set, This will populate the Hex Value Web Color in the generated browserconfig xml file.
If not set, The value used will be populated from the global ``

WebManifest #

a webmanifest file

Site.Params.sitemeta.webmanifest.generate
Bool (Default: true)
Controls if we should generate the webmanifest.json asset.
Site.Params.sitemeta.webmanifest.include
Bool (Default: true)
Controls if we should include the webmanifest.json asset in the header metadata.
Site.Params.sitemeta.webmanifest.include_all
Bool (Default: true)
Controls if we should include any additional copies of the webmanifest data in the header metadata.
Site.Params.sitemeta.webmanifest.template
String (Default: sitemeta/webmanifest.json-template)
The template file to use to generate the browserconfig file.
This should usually just be sitemeta/webmanifest.json-template.
Template Location
For the template generation to work as anticipated, it’s expected that these templates will be pathed relative to your site’s assets directory.
Site.Params.sitemeta.webmanifest.target
String (Default: manifest.webmanifest) The target to populate with the webmanifest content.
Site.Params.sitemeta.webmanifest.additional_targets
Slice (Default:
[ '.webmanifest', 'webmanifest.json', 'site.webmanifest', 'manifest.json'])
A list of additional targets to populate in addition to the resource created above.
Site.Params.sitemeta.webmanifest.background_color
bool (Default: undef)
The manifest’s background_color member describes the expected background color of the web application.
Docs1
Site.Params.sitemeta.webmanifest.dir
String (Default: undef)
The text direction. acceptable options are ltr, rtl, and auto.

https://w3c.github.io/manifest/#dir-member

Site.Params.sitemeta.webmanifest.display
bool (Default: undef)
Site.Params.sitemeta.webmanifest.description
String (Default: undef)
The content to use for the Site Description. If null we failback to consuming params.sitemeta.sitedesc which consumes Params.description
Docs
Site.Params.sitemeta.webmanifest.icons
Dict
This is a slice of dicts, each represents a different name variant of the images we want added to the webmanifest, and created. Site.Params.sitemeta.webmanifest.icons.generate.src

Site.Params.sitemeta.webmanifest.icons.generate.version

Site.Params.sitemeta.webmanifest.icons.generate.variants

prefix: ``
src:
postfix: ``
rel: `icon` `mask-icon`
inclsize: bool - include the size in the filename or not
purpose:
format:
sizes:
mimetype:

purpose: [‘monochrome’, ‘maskable’, ‘any’ ] Docs2

Site.Params.sitemeta.webmanifest.id
String (Default: undef )
The id property represents the identity of the PWA to the browser.
When the browser sees a manifest that does not have an identity that matches an already installed PWA, it will treat it as a new PWA, even if it is served from the same URL as another PWA.
But if it sees a manifest with an identity that matches the already installed PWA, it will treat that as the installed PWA.
Docs: Chrome3 w3cdocs4
Site.Params.sitemeta.webmanifest.lang
String (Default: undef)
The language tag for the site. Defaults to consuming $.Site.Params.sitemeta.sitelang Docs5
Site.Params.sitemeta.webmanifest.name
bool (Default: undef)
The name member serves as the accessible name of an installed web application.
Docs:6
Site.Params.sitemeta.webmanifest.orientation
bool (Default: undef)
Site.Params.sitemeta.webmanifest.prefer_related_applications
bool (Default: undef)
Site.Params.sitemeta.webmanifest.related_applications
bool (Default: undef)
Site.Params.sitemeta.webmanifest.scope
bool (Default: undef)
Site.Params.sitemeta.webmanifest.short_name
String (Default: null)
A string that represents a short version of the name of the web application.
It is intended to be used where there is insufficient space to display the full name of the web application.
If null, we default to $.Site.Title Docs:7
Site.Params.sitemeta.webmanifest.shortcuts
Dict (Default: undef) If populated, may be a list of sub pages relevant to the site.
Docs8
Site.Params.sitemeta.webmanifest.start_url
bool (Default: undef)
Site.Params.sitemeta.webmanifest.theme_color
bool (Default: undef)
Site.Params.sitemeta.webmanifest.lang
Bool (Default: true)
Controls if we should include the webmanifest.json asset in the header metadata.
Site.Params.sitemeta.webmanifest.display
String (Default: standalone)
The different modes a webapp may request.
Accepted Values:
  • fullscreen
  • standalone
  • minimal-ui
  • `browse

Controls if we should include the webmanifest.json asset in the header metadata.


References:

Favicons:

WebManifest:

BrowserConfig and Tiles:

Hugo Discourse:

Hugo Docpages:

https://mailchimp.com/resources/favicon-size/ https://dev.to/abbeyperini/what-are-favicons-2e9d