Render

About The Render Function

const tagName = {
  mapping: {},
  async render(template, styles, attrs, innerText) {
    await template(``);
  },
};

The render function is run whenever the template tag is compiled.

Render Parameters

template

The function that adds the template to the widget. A template must only have one root element, or it will not be rendered as expected.

styles

A JSON of the styles (CSS and attributes) for the tag with the names as the keys and values as the values. Attributes overwrite the CSS properties. This object will already be validated based on the mapping object. All unused styles will be set to null.

attrs

A JSON of the attributes for the tag with the attribute names as the keys and values as the values. This object will already be validated based on the mapping object. All unused attributes will be set to null.

innerText

A string of the inner text of the tag.

Template Function

The template function compiles and adds the input to the widget. The input should be made up of the normal tags and attributes, but not the <style> tag. These tags will not be affected by CSS, as they will automatically have the no-css attribute.

Here is an example that would make a <hr>:

async render(template, styles, attrs, innerText) {
  await template(`
    <stack 
      background="${styles.background ?? "#000-#fff"}" 
      url="${styles.url}" 
      cornerRadius="${styles.cornerRadius}"
    >
      ${styles.width === null && "<spacer/>"}
      <img src="" image-size="${
        styles.width ?? 100
      },${styles.height ?? 1}"/>
      ${styles.width === null && "<spacer/>"}
    </stack>
  `);
},

A Few Quick Notes About The Code Above

background="${styles.background ?? "#000-#fff"}"

This sets the background to the input background, or if it doesn’t have a value, it sets it to "#000-#fff"

${styles.width === null && "<spacer/>"}

This will add a spacer to the code to automatically expand it if the width style has no value.

The Children Attribute

The children attribute is a bool type attribute that can go on any tags throughout the template. This attribute will move the children of the original element to this element to be compiled within the template. For example, if you wanted to make a stack-like element that is always laid out vertically, you can do this:

await template(`
  <stack layout="vertically" children="true">
  </stack>
`)

Last updated