{
  "features": {
    "spectrumThemes": true,
    "intelligentLoading": true,
    "deviceAwareness": true,
    "state": true,
    "customThemes": true,
    "devicePreview": true,
    "messagePassing": true
  },
  "layout": {
    "name": "Layout",
    "description": "This component is specific only to layouts",
    "icon": "Sandbox",
    "hasChildren": true,
    "styles": ["padding", "background"],
    "settings": [
      {
        "type": "text",
        "label": "Logo URL",
        "key": "logoUrl"
      },
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "select",
        "label": "Navigation",
        "key": "navigation",
        "options": ["Top", "Left", "None"],
        "defaultValue": "Top"
      },
      {
        "type": "select",
        "label": "Width",
        "key": "width",
        "options": ["Small", "Medium", "Large", "Max"],
        "defaultValue": "Large"
      },
      {
        "type": "navigation",
        "label": "Links",
        "key": "links"
      },
      {
        "type": "boolean",
        "label": "Hide title",
        "key": "hideTitle",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Hide logo",
        "key": "hideLogo",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Sticky header",
        "key": "sticky",
        "defaultValue": false
      }
    ]
  },
  "container": {
    "name": "Container",
    "description": "This component contains things within itself",
    "icon": "Sandbox",
    "hasChildren": true,
    "showSettingsBar": true,
    "styles": ["padding", "size", "background", "border", "shadow"],
    "settings": [
      {
        "type": "select",
        "label": "Direction",
        "key": "direction",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [
          {
            "label": "Column",
            "value": "column",
            "barIcon": "ViewColumn",
            "barTitle": "Column layout"
          },
          {
            "label": "Row",
            "value": "row",
            "barIcon": "ViewRow",
            "barTitle": "Row layout"
          }
        ],
        "defaultValue": "column"
      },
      {
        "type": "select",
        "label": "Horiz. Align",
        "key": "hAlign",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [
          {
            "label": "Left",
            "value": "left",
            "barIcon": "AlignLeft",
            "barTitle": "Align left"
          },
          {
            "label": "Center",
            "value": "center",
            "barIcon": "AlignCenter",
            "barTitle": "Align center"
          },
          {
            "label": "Right",
            "value": "right",
            "barIcon": "AlignRight",
            "barTitle": "Align right"
          },
          {
            "label": "Stretch",
            "value": "stretch",
            "barIcon": "MoveLeftRight",
            "barTitle": "Align stretched horizontally"
          }
        ],
        "defaultValue": "stretch"
      },
      {
        "type": "select",
        "label": "Vert. Align",
        "key": "vAlign",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [
          {
            "label": "Top",
            "value": "top",
            "barIcon": "AlignTop",
            "barTitle": "Align top"
          },
          {
            "label": "Middle",
            "value": "middle",
            "barIcon": "AlignMiddle",
            "barTitle": "Align middle"
          },
          {
            "label": "Bottom",
            "value": "bottom",
            "barIcon": "AlignBottom",
            "barTitle": "Align bottom"
          },
          {
            "label": "Stretch",
            "value": "stretch",
            "barIcon": "MoveUpDown",
            "barTitle": "Align stretched vertically"
          }
        ],
        "defaultValue": "top"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [
          {
            "label": "Shrink",
            "value": "shrink",
            "barIcon": "Minimize",
            "barTitle": "Shrink container"
          },
          {
            "label": "Grow",
            "value": "grow",
            "barIcon": "Maximize",
            "barTitle": "Grow container"
          }
        ],
        "defaultValue": "shrink"
      },
      {
        "type": "select",
        "label": "Gap",
        "key": "gap",
        "showInBar": true,
        "barStyle": "picker",
        "options": [
          {
            "label": "None",
            "value": "N"
          },
          {
            "label": "Small",
            "value": "S"
          },
          {
            "label": "Medium",
            "value": "M"
          },
          {
            "label": "Large",
            "value": "L"
          }
        ],
        "defaultValue": "M"
      },
      {
        "type": "boolean",
        "label": "Wrap",
        "key": "wrap",
        "showInBar": true,
        "barIcon": "ModernGridView",
        "barTitle": "Wrap"
      }
    ]
  },
  "section": {
    "name": "Section",
    "description": "Add a section to your application",
    "icon": "ColumnTwoB",
    "hasChildren": true,
    "illegalChildren": ["section"],
    "showEmptyState": false,
    "settings": [
      {
        "type": "section",
        "label": "Type",
        "key": "type",
        "defaultValue": "mainSidebar"
      }
    ]
  },
  "screenslot": {
    "name": "Screenslot",
    "icon": "WebPage",
    "description": "Contains your app screens",
    "static": true
  },
  "button": {
    "name": "Button",
    "description": "A basic html button that is ready for styling",
    "icon": "Button",
    "editable": true,
    "showSettingsBar": true,
    "settings": [
      {
        "type": "text",
        "label": "Text",
        "key": "text"
      },
      {
        "type": "select",
        "showInBar": true,
        "label": "Variant",
        "key": "type",
        "options": [
          {
            "label": "Primary",
            "value": "primary"
          }, {
            "label": "Secondary",
            "value": "secondary"
          },
          {
            "label": "Action",
            "value": "cta"
          },
          {
            "label": "Warning",
            "value": "warning"
          },
          {
            "label": "Over Background",
            "value": "overBackground"
          }
        ],
        "defaultValue": "primary"
      },
      {
        "type": "select",
        "label": "Size",
        "showInBar": true,
        "key": "size",
        "options": [
          {
            "label": "Small",
            "value": "S"
          },
          {
            "label": "Medium",
            "value": "M"
          },
          {
            "label": "Large",
            "value": "L"
          },
          {
            "label": "Extra large",
            "value": "XL"
          }
        ],
        "defaultValue": "M"
      },
      {
        "type": "boolean",
        "label": "Quiet",
        "key": "quiet",
        "showInBar": true,
        "barIcon": "VisibilityOff",
        "barTitle": "Quiet variant",
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "showInBar": true,
        "barIcon": "NoEdit",
        "barTitle": "Disable button",
        "key": "disabled"
      },
      {
        "type": "event",
        "label": "On Click",
        "key": "onClick"
      }
    ]
  },
  "divider": {
    "name": "Divider",
    "description": "A basic divider",
    "icon": "Separator",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "options": [
          {
            "label": "Small",
            "value": "S"
          },
          {
            "label": "Medium",
            "value": "M"
          },
          {
            "label": "Large",
            "value": "L"
          }
        ],
        "defaultValue": "M"
      },
      {
        "type": "boolean",
        "label": "Vertical",
        "key": "vertical"
      }
    ]
  },
  "repeater": {
    "name": "Repeater",
    "description": "A configurable data list that attaches to your backend tables.",
    "icon": "ViewList",
    "illegalChildren": ["section"],
    "hasChildren": true,
    "showSettingsBar": true,
    "settings": [
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "text",
        "label": "Empty Text",
        "key": "noRowsMessage",
        "defaultValue": "No rows found"
      },
      {
        "type": "select",
        "label": "Direction",
        "key": "direction",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [
          {
            "label": "Column",
            "value": "column",
            "barIcon": "ViewColumn",
            "barTitle": "Column layout"
          },
          {
            "label": "Row",
            "value": "row",
            "barIcon": "ViewRow",
            "barTitle": "Row layout"
          }
        ],
        "defaultValue": "column"
      },
      {
        "type": "select",
        "label": "Horiz. Align",
        "key": "hAlign",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [
          {
            "label": "Left",
            "value": "left",
            "barIcon": "AlignLeft",
            "barTitle": "Align left"
          },
          {
            "label": "Center",
            "value": "center",
            "barIcon": "AlignCenter",
            "barTitle": "Align center"
          },
          {
            "label": "Right",
            "value": "right",
            "barIcon": "AlignRight",
            "barTitle": "Align right"
          },
          {
            "label": "Stretch",
            "value": "stretch",
            "barIcon": "MoveLeftRight",
            "barTitle": "Align stretched horizontally"
          }
        ],
        "defaultValue": "stretch"
      },
      {
        "type": "select",
        "label": "Vert. Align",
        "key": "vAlign",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [
          {
            "label": "Top",
            "value": "top",
            "barIcon": "AlignTop",
            "barTitle": "Align top"
          },
          {
            "label": "Middle",
            "value": "middle",
            "barIcon": "AlignMiddle",
            "barTitle": "Align middle"
          },
          {
            "label": "Bottom",
            "value": "bottom",
            "barIcon": "AlignBottom",
            "barTitle": "Align bottom"
          },
          {
            "label": "Stretch",
            "value": "stretch",
            "barIcon": "MoveUpDown",
            "barTitle": "Align stretched vertically"
          }
        ],
        "defaultValue": "top"
      },
      {
        "type": "select",
        "label": "Gap",
        "key": "gap",
        "showInBar": true,
        "barStyle": "picker",
        "options": [
          {
            "label": "None",
            "value": "N"
          },
          {
            "label": "Small",
            "value": "S"
          },
          {
            "label": "Medium",
            "value": "M"
          },
          {
            "label": "Large",
            "value": "L"
          }
        ],
        "defaultValue": "M"
      }
    ],
    "context": [
      {
        "type": "schema"
      },
      {
        "type": "static",
        "values":  [
          {
            "label": "Row Index",
            "key": "index"
          }
        ]
      }
    ]
  },
  "stackedlist": {
    "deprecated": true,
    "name": "Stacked List",
    "icon": "TaskList",
    "description": "A basic card component that can contain content and actions.",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Image",
        "key": "imageUrl"
      },
      {
        "type": "text",
        "label": "Heading",
        "key": "heading"
      },
      {
        "type": "text",
        "label": "Subheading",
        "key": "subheading"
      },
      {
        "type": "text",
        "label": "Link URL",
        "key": "destinationUrl",
        "placeholder": "/screen"
      }
    ]
  },
  "card": {
    "name": "Vertical Card",
    "description": "A basic card component that can contain content and actions.",
    "icon": "ViewColumn",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Image",
        "key": "imageUrl"
      },
      {
        "type": "text",
        "label": "Heading",
        "key": "heading"
      },
      {
        "type": "text",
        "label": "Description",
        "key": "description"
      },
      {
        "type": "text",
        "label": "Link Text",
        "key": "linkText"
      },
      {
        "type": "text",
        "label": "Link URL",
        "key": "linkUrl",
        "placeholder": "/screen"
      },
      {
        "type": "color",
        "label": "Link Color",
        "key": "linkColor",
        "defaultValue": "#000"
      },
      {
        "type": "color",
        "label": "Hover Color",
        "key": "linkHoverColor",
        "defaultValue": "#222"
      },
      {
        "type": "select",
        "label": "Image Height",
        "key": "imageHeight",
        "options": ["auto", "12rem", "16rem", "20rem", "24rem"],
        "defaultValue": "auto"
      },
      {
        "type": "select",
        "label": "Card Width",
        "key": "cardWidth",
        "options": ["16rem", "20rem", "24rem"],
        "defaultValue": "20rem"
      }
    ]
  },
  "text": {
    "name": "Paragraph",
    "description": "A component for displaying paragraph text.",
    "icon": "TextParagraph",
    "illegalChildren": ["section"],
    "showSettingsBar": true,
    "editable": true,
    "settings": [
      {
        "type": "text",
        "label": "Text",
        "key": "text"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "defaultValue": "M",
        "showInBar": true,
        "barStyle": "picker",
        "options": [{
          "label": "Extra Small",
          "value": "XS"
        }, {
          "label": "Small",
          "value": "S"
        }, {
          "label": "Medium",
          "value": "M"
        }, {
          "label": "Large",
          "value": "L"
        }, {
          "label": "Extra Large",
          "value": "XL"
        }, {
          "label": "2XL",
          "value": "XXL"
        }, {
          "label": "3XL",
          "value": "XXXL"
        }]
      },
      {
        "type": "color",
        "label": "Color",
        "key": "color",
        "showInBar": true,
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Bold",
        "key": "bold",
        "showInBar": true,
        "barIcon": "TagBold",
        "barTitle": "Bold text",
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Italic",
        "key": "italic",
        "showInBar": true,
        "barIcon": "TagItalic",
        "barTitle": "Italic text",
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Underline",
        "key": "underline",
        "showInBar": true,
        "barIcon": "TagUnderline",
        "barTitle": "Underline text"
      },
      {
        "type": "select",
        "label": "Alignment",
        "key": "align",
        "defaultValue": "left",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [{
          "label": "Left",
          "value": "left",
          "barIcon": "TextAlignLeft",
          "barTitle": "Align left"
        }, {
          "label": "Center",
          "value": "center",
          "barIcon": "TextAlignCenter",
          "barTitle": "Align center"
        }, {
          "label": "Right",
          "value": "right",
          "barIcon": "TextAlignRight",
          "barTitle": "Align right"
        }, {
          "label": "Justify",
          "value": "justify",
          "barIcon": "TextAlignJustify",
          "barTitle": "Justify text"
        }]
      }
    ]
  },
  "heading": {
    "name": "Headline",
    "icon": "TextBold",
    "description": "A component for displaying heading text",
    "illegalChildren": ["section"],
    "showSettingsBar": true,
    "editable": true,
    "settings": [
      {
        "type": "text",
        "key": "text",
        "label": "Text"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "defaultValue": "M",
        "showInBar": true,
        "barStyle": "picker",
        "options": [{
          "label": "Extra Small",
          "value": "XS"
        }, {
          "label": "Small",
          "value": "S"
        }, {
          "label": "Medium",
          "value": "M"
        }, {
          "label": "Large",
          "value": "L"
        }, {
          "label": "Extra Large",
          "value": "XL"
        }, {
          "label": "2XL",
          "value": "XXL"
        }, {
          "label": "3XL",
          "value": "XXXL"
        }]
      },
      {
        "type": "color",
        "label": "Color",
        "key": "color",
        "showInBar": true,
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Bold",
        "key": "bold",
        "showInBar": true,
        "barIcon": "TagBold",
        "barTitle": "Bold text",
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Italic",
        "key": "italic",
        "showInBar": true,
        "barIcon": "TagItalic",
        "barTitle": "Italic text",
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Underline",
        "key": "underline",
        "showInBar": true,
        "barIcon": "TagUnderline",
        "barTitle": "Underline text"
      },
      {
        "type": "select",
        "label": "Alignment",
        "key": "align",
        "defaultValue": "left",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [{
          "label": "Left",
          "value": "left",
          "barIcon": "TextAlignLeft",
          "barTitle": "Align left"
        }, {
          "label": "Center",
          "value": "center",
          "barIcon": "TextAlignCenter",
          "barTitle": "Align center"
        }, {
          "label": "Right",
          "value": "right",
          "barIcon": "TextAlignRight",
          "barTitle": "Align right"
        }, {
          "label": "Justify",
          "value": "justify",
          "barIcon": "TextAlignJustify",
          "barTitle": "Justify text"
        }]
      }
    ]
  },
  "tag": {
    "name": "Tag",
    "icon": "TextParagraph",
    "showSettingsBar": true,
    "settings": [
      {
        "type": "text",
        "label": "Text",
        "key": "text"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "defaultValue": "M",
        "showInBar": true,
        "barStyle": "picker",
        "options": [{
          "label": "Small",
          "value": "S"
        }, {
          "label": "Medium",
          "value": "M"
        }, {
          "label": "Large",
          "value": "L"
        }]
      },
      {
        "type": "color",
        "label": "Color",
        "key": "color",
        "showInBar": true,
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Show delete icon",
        "key": "closable",
        "showInBar": true,
        "barIcon": "TagItalic",
        "barTitle": "Show delete icon"
      },
      {
        "type": "event",
        "label": "On click delete icon",
        "key": "onClick",
        "dependsOn": "closable"
      }
    ]
  },
  "image": {
    "name": "Image",
    "description": "A basic component for displaying images",
    "icon": "Image",
    "illegalChildren": ["section"],
    "styles": ["size"],
    "settings": [
      {
        "type": "text",
        "label": "URL",
        "key": "url"
      }
    ]
  },
  "backgroundimage": {
    "name": "Background Image",
    "description": "A background image",
    "icon": "Images",
    "styles": ["size"],
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "URL",
        "key": "url"
      },
      {
        "type": "select",
        "label": "Position",
        "key": "position",
        "defaultValue": "center center",
        "options": [
          {
            "label": "Center Top",
            "value": "center top"
          },
          {
            "label": "Center",
            "value": "center center"
          },
          {
            "label": "Center Bottom",
            "value": "center bottom"
          },
          {
            "label": "Left Top",
            "value": "left top"
          },
          {
            "label": "Left Center",
            "value": "left center"
          },
          {
            "label": "Left Bottom",
            "value": "left bottom"
          },
          {
            "label": "Right Top",
            "value": "right top"
          },
          {
            "label": "Right Center",
            "value": "right center"
          },
          {
            "label": "Right Bottom",
            "value": "right bottom"
          }
        ]
      }
    ]
  },
  "icon": {
    "name": "Icon",
    "description": "A basic component for displaying icons",
    "icon": "Bell",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "icon",
        "label": "Icon",
        "key": "icon"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "defaultValue": "ri-1x",
        "options": [
          { "value": "ri-xxs", "label": "XXS" },
          { "value": "ri-xs", "label": "XS" },
          { "value": "ri-sm", "label": "Small" },
          { "value": "ri-1x", "label": "Medium" },
          { "value": "ri-lg", "label": "Large" },
          { "value": "ri-xl", "label": "XL" },
          { "value": "ri-2x", "label": "2XL" },
          { "value": "ri-3x", "label": "3XL" },
          { "value": "ri-4x", "label": "4XL" },
          { "value": "ri-5x", "label": "5XL" },
          { "value": "ri-6x", "label": "6XL" },
          { "value": "ri-7x", "label": "7XL" },
          { "value": "ri-8x", "label": "8XL" },
          { "value": "ri-9x", "label": "9XL" },
          { "value": "ri-10x", "label": "10XL" }
        ]
      },
      {
        "type": "color",
        "label": "Color",
        "key": "color"
      },
      {
        "type": "event",
        "label": "On Click",
        "key": "onClick"
      }
    ]
  },
  "navigation": {
    "deprecated": true,
    "name": "Nav Bar",
    "description": "A component for handling the navigation within your app.",
    "icon": "BreadcrumbNavigation",
    "illegalChildren": ["section"],
    "hasChildren": true,
    "settings": [
      {
        "type": "text",
        "label": "Logo URL",
        "key": "logoUrl"
      },
      {
        "type": "boolean",
        "label": "Hide logo",
        "key": "hideLogo",
        "defaultValue": false
      }
    ]
  },
  "link": {
    "name": "Link",
    "description": "A basic link component for internal and external links",
    "icon": "Link",
    "showSettingsBar": true,
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Text",
        "key": "text"
      },
      {
        "type": "url",
        "label": "URL",
        "key": "url",
        "placeholder": "/screen"
      },
      {
        "type": "boolean",
        "label": "New Tab",
        "key": "openInNewTab"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "defaultValue": "M",
        "showInBar": true,
        "barStyle": "picker",
        "options": [{
          "label": "Small",
          "value": "S"
        }, {
          "label": "Medium",
          "value": "M"
        }, {
          "label": "Large",
          "value": "L"
        }]
      },
      {
        "type": "color",
        "label": "Color",
        "key": "color",
        "showInBar": true,
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Bold",
        "key": "bold",
        "showInBar": true,
        "barIcon": "TagBold",
        "barTitle": "Bold text",
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Italic",
        "key": "italic",
        "showInBar": true,
        "barIcon": "TagItalic",
        "barTitle": "Italic text",
        "barSeparator": false
      },
      {
        "type": "boolean",
        "label": "Underline",
        "key": "underline",
        "showInBar": true,
        "barIcon": "TagUnderline",
        "barTitle": "Underline text"
      },
      {
        "type": "select",
        "label": "Alignment",
        "key": "align",
        "defaultValue": "left",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [{
          "label": "Left",
          "value": "left",
          "barIcon": "TextAlignLeft",
          "barTitle": "Align left"
        }, {
          "label": "Center",
          "value": "center",
          "barIcon": "TextAlignCenter",
          "barTitle": "Align center"
        }, {
          "label": "Right",
          "value": "right",
          "barIcon": "TextAlignRight",
          "barTitle": "Align right"
        }, {
          "label": "Justify",
          "value": "justify",
          "barIcon": "TextAlignJustify",
          "barTitle": "Justify text"
        }]
      }
    ]
  },
  "cardhorizontal": {
    "name": "Horizontal Card",
    "description": "A basic card component that can contain content and actions.",
    "icon": "ViewRow",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Image",
        "key": "imageUrl"
      },
      {
        "type": "text",
        "label": "Heading",
        "key": "heading"
      },
      {
        "type": "text",
        "label": "Description",
        "key": "description"
      },
      {
        "type": "text",
        "label": "Subtext",
        "key": "subtext"
      },
      {
        "type": "text",
        "label": "Link Text",
        "key": "linkText"
      },
      {
        "type": "text",
        "label": "Link URL",
        "key": "linkUrl",
        "placeholder": "/screen"
      },
      {
        "type": "color",
        "label": "Link Color",
        "key": "linkColor",
        "defaultValue": "#000"
      },
      {
        "type": "color",
        "label": "Hover Color",
        "key": "linkHoverColor",
        "defaultValue": "#222"
      },
      {
        "type": "select",
        "label": "Card Width",
        "key": "cardWidth",
        "options": ["24rem", "28rem", "32rem", "40rem", "48rem", "60rem", "100%"],
        "defaultValue": "32rem"
      },
      {
        "type": "select",
        "label": "Image Width",
        "key": "imageWidth",
        "options": ["auto", "8rem", "12rem", "16rem"],
        "defaultValue": "8rem"
      },
      {
        "type": "select",
        "label": "Image Height",
        "key": "imageHeight",
        "options": ["auto", "8rem", "12rem", "16rem", "auto"],
        "defaultValue": "auto"
      }
    ]
  },
  "cardstat": {
    "name": "Stat Card",
    "description": "A card component for displaying numbers.",
    "icon": "Card",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title",
        "placeholder": "Total Revenue"
      },
      {
        "type": "text",
        "label": "Value",
        "key": "value",
        "placeholder": "$1,981,983"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label",
        "placeholder": "Stripe"
      }
    ]
  },
  "embed": {
    "name": "Embed",
    "icon": "Code",
    "description": "Embed content from 3rd party sources",
    "illegalChildren": ["section"],
    "styles": ["size"],
    "settings": [
      {
        "type": "text",
        "label": "Embed",
        "key": "embed"
      }
    ]
  },
  "bar": {
    "name": "Bar Chart",
    "description": "Bar chart",
    "icon": "GraphBarVertical",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "field",
        "label": "Label Col.",
        "key": "labelColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "multifield",
        "label": "Data Cols.",
        "key": "valueColumns",
        "dependsOn": "dataProvider"
      },
      {
        "type": "select",
        "label": "Format",
        "key": "yAxisUnits",
        "options": ["Default", "Thousands", "Millions"],
        "defaultValue": "Default"
      },
      {
        "type": "text",
        "label": "Y Axis Label",
        "key": "yAxisLabel"
      },
      {
        "type": "text",
        "label": "X Axis Label",
        "key": "xAxisLabel"
      },
      {
        "type": "text",
        "label": "Width",
        "key": "width"
      },
      {
        "type": "text",
        "label": "Height",
        "key": "height",
        "defaultValue": "400"
      },
      {
        "type": "select",
        "label": "Colours",
        "key": "palette",
        "defaultValue": "Palette 1",
        "options": [
          "Palette 1",
          "Palette 2",
          "Palette 3",
          "Palette 4",
          "Palette 5",
          "Palette 6",
          "Palette 7",
          "Palette 8",
          "Palette 9",
          "Palette 10"
        ]
      },
      {
        "type": "boolean",
        "label": "Stacked",
        "key": "stacked",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Horizontal",
        "key": "horizontal",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Data Labels",
        "key": "dataLabels",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Animate",
        "key": "animate",
        "defaultValue": true
      },
      {
        "type": "boolean",
        "label": "Legend",
        "key": "legend",
        "defaultValue": false
      }
    ]
  },
  "line": {
    "name": "Line Chart",
    "description": "Line chart",
    "icon": "GraphTrend",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "field",
        "label": "Label Col.",
        "key": "labelColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "multifield",
        "label": "Data Cols.",
        "key": "valueColumns",
        "dependsOn": "dataProvider"
      },
      {
        "type": "select",
        "label": "Format",
        "key": "yAxisUnits",
        "options": ["Default", "Thousands", "Millions"],
        "defaultValue": "Default"
      },
      {
        "type": "text",
        "label": "Y Axis Label",
        "key": "yAxisLabel"
      },
      {
        "type": "text",
        "label": "X Axis Label",
        "key": "xAxisLabel"
      },
      {
        "type": "text",
        "label": "Width",
        "key": "width"
      },
      {
        "type": "text",
        "label": "Height",
        "key": "height",
        "defaultValue": "400"
      },
      {
        "type": "select",
        "label": "Colours",
        "key": "palette",
        "defaultValue": "Palette 1",
        "options": [
          "Palette 1",
          "Palette 2",
          "Palette 3",
          "Palette 4",
          "Palette 5",
          "Palette 6",
          "Palette 7",
          "Palette 8",
          "Palette 9",
          "Palette 10"
        ]
      },
      {
        "type": "select",
        "label": "Curve",
        "key": "curve",
        "options": ["Smooth", "Straight", "Stepline"],
        "defaultValue": "Smooth"
      },
      {
        "type": "boolean",
        "label": "Data Labels",
        "key": "dataLabels",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Animate",
        "key": "animate",
        "defaultValue": true
      },
      {
        "type": "boolean",
        "label": "Legend",
        "key": "legend",
        "defaultValue": false
      }
    ]
  },
  "area": {
    "name": "Area Chart",
    "description": "Line chart",
    "icon": "GraphAreaStacked",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "field",
        "label": "Label Col.",
        "key": "labelColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "multifield",
        "label": "Data Cols.",
        "key": "valueColumns",
        "dependsOn": "dataProvider"
      },
      {
        "type": "select",
        "label": "Format",
        "key": "yAxisUnits",
        "options": ["Default", "Thousands", "Millions"],
        "defaultValue": "Default"
      },
      {
        "type": "text",
        "label": "Y Axis Label",
        "key": "yAxisLabel"
      },
      {
        "type": "text",
        "label": "X Axis Label",
        "key": "xAxisLabel"
      },
      {
        "type": "text",
        "label": "Width",
        "key": "width"
      },
      {
        "type": "text",
        "label": "Height",
        "key": "height",
        "defaultValue": "400"
      },
      {
        "type": "select",
        "label": "Colours",
        "key": "palette",
        "defaultValue": "Palette 1",
        "options": [
          "Palette 1",
          "Palette 2",
          "Palette 3",
          "Palette 4",
          "Palette 5",
          "Palette 6",
          "Palette 7",
          "Palette 8",
          "Palette 9",
          "Palette 10"
        ]
      },
      {
        "type": "select",
        "label": "Curve",
        "key": "curve",
        "options": ["Smooth", "Straight", "Stepline"],
        "defaultValue": "Smooth"
      },
      {
        "type": "boolean",
        "label": "Data Labels",
        "key": "dataLabels",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Animate",
        "key": "animate",
        "defaultValue": true
      },
      {
        "type": "boolean",
        "label": "Legend",
        "key": "legend",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Stacked",
        "key": "stacked",
        "defaultValue": true
      },
      {
        "type": "boolean",
        "label": "Gradient",
        "key": "gradient",
        "defaultValue": false
      }
    ]
  },
  "pie": {
    "name": "Pie Chart",
    "description": "Pie chart",
    "icon": "GraphPie",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "field",
        "label": "Label Col.",
        "key": "labelColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "field",
        "label": "Data Col.",
        "key": "valueColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "text",
        "label": "Width",
        "key": "width"
      },
      {
        "type": "text",
        "label": "Height",
        "key": "height",
        "defaultValue": "400"
      },
      {
        "type": "select",
        "label": "Colours",
        "key": "palette",
        "defaultValue": "Palette 1",
        "options": [
          "Palette 1",
          "Palette 2",
          "Palette 3",
          "Palette 4",
          "Palette 5",
          "Palette 6",
          "Palette 7",
          "Palette 8",
          "Palette 9",
          "Palette 10"
        ]
      },
      {
        "type": "boolean",
        "label": "Data Labels",
        "key": "dataLabels",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Animate",
        "key": "animate",
        "defaultValue": true
      },
      {
        "type": "boolean",
        "label": "Legend",
        "key": "legend",
        "defaultValue": false
      }
    ]
  },
  "donut": {
    "name": "Donut Chart",
    "description": "Donut chart",
    "icon": "GraphDonut",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "field",
        "label": "Label Col.",
        "key": "labelColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "field",
        "label": "Data Col.",
        "key": "valueColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "text",
        "label": "Width",
        "key": "width"
      },
      {
        "type": "text",
        "label": "Height",
        "key": "height",
        "defaultValue": "400"
      },
      {
        "type": "select",
        "label": "Colours",
        "key": "palette",
        "defaultValue": "Palette 1",
        "options": [
          "Palette 1",
          "Palette 2",
          "Palette 3",
          "Palette 4",
          "Palette 5",
          "Palette 6",
          "Palette 7",
          "Palette 8",
          "Palette 9",
          "Palette 10"
        ]
      },
      {
        "type": "boolean",
        "label": "Data Labels",
        "key": "dataLabels",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Animate",
        "key": "animate",
        "defaultValue": true
      },
      {
        "type": "boolean",
        "label": "Legend",
        "key": "legend",
        "defaultValue": false
      }
    ]
  },
  "candlestick": {
    "name": "Candlestick Chart",
    "description": "Candlestick chart",
    "icon": "GraphBarVerticalStacked",
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "field",
        "label": "Date Col.",
        "key": "dateColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "field",
        "label": "Open Col.",
        "key": "openColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "field",
        "label": "Close Col.",
        "key": "closeColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "field",
        "label": "High Col.",
        "key": "highColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "field",
        "label": "Low Col.",
        "key": "lowColumn",
        "dependsOn": "dataProvider"
      },
      {
        "type": "select",
        "label": "Format",
        "key": "yAxisUnits",
        "options": ["Default", "Thousands", "Millions"],
        "defaultValue": "Default"
      },
      {
        "type": "text",
        "label": "Y Axis Label",
        "key": "yAxisLabel"
      },
      {
        "type": "text",
        "label": "X Axis Label",
        "key": "xAxisLabel"
      },
      {
        "type": "text",
        "label": "Width",
        "key": "width"
      },
      {
        "type": "text",
        "label": "Height",
        "key": "height",
        "defaultValue": "400"
      },
      {
        "type": "boolean",
        "label": "Animate",
        "key": "animate",
        "defaultValue": true
      }
    ]
  },
  "form": {
    "name": "Form",
    "icon": "Form",
    "hasChildren": true,
    "illegalChildren": ["section", "form"],
    "actions": [
      "ValidateForm",
      "ClearForm",
      "ChangeFormStep"
    ],
    "styles": ["size"],
    "settings": [
      {
        "type": "select",
        "label": "Type",
        "key": "actionType",
        "options": ["Create", "Update"],
        "defaultValue": "Create"
      },
      {
        "type": "schema",
        "label": "Schema",
        "key": "dataSource",
        "defaultValue": {
          "name": "Custom",
          "label": "Custom"
        }
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "options": [
          {
            "label": "Medium",
            "value": "spectrum--medium"
          }, {
            "label": "Large",
            "value": "spectrum--large"
          }
        ],
        "defaultValue": "spectrum--medium"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      }
    ],
    "context": [
      {
        "type": "static",
        "values":  [
          {
            "label": "Value",
            "key": "__value"
          },
          {
            "label": "Valid",
            "key": "__valid"
          },
          {
            "label": "Current Step",
            "key": "__currentStep"
          },
          {
            "label": "Current Step Valid",
            "key": "__currentStepValid"
          }
        ]
      },
      {
        "type": "form"
      }
    ]
  },
  "formstep": {
    "name": "Form Step",
    "icon": "AssetsAdded",
    "hasChildren": true,
    "illegalChildren": ["section", "form", "form step"],
    "styles": ["size"],
    "settings": [
      {
        "type": "number",
        "label": "Step",
        "key": "step",
        "defaultValue": 1,
        "min": 1
      }
    ]
  },
  "fieldgroup": {
    "name": "Field Group",
    "icon": "Group",
    "illegalChildren": ["section"],
    "styles": ["size"],
    "hasChildren": true,
    "settings": [
      {
        "type": "select",
        "label": "Labels",
        "key": "labelPosition",
        "defaultValue": "above",
        "options": [
          {
            "label": "Left",
            "value": "left"
          },
          {
            "label": "Right",
            "value": "right"
          },
          {
            "label": "Above",
            "value": "above"
          }
        ]
      }
    ]
  },
  "stringfield": {
    "name": "Text Field",
    "icon": "Text",
    "illegalChildren": ["section"],
    "styles": ["size"],
    "editable": true,
    "settings": [
      {
        "type": "field/string",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder"
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/string",
        "label": "Validation",
        "key": "validation"
      },
      {
        "type": "select",
        "label": "Alignment",
        "key": "align",
        "defaultValue": "left",
        "showInBar": true,
        "barStyle": "buttons",
        "options": [{
          "label": "Left",
          "value": "left",
          "barIcon": "TextAlignLeft",
          "barTitle": "Align left"
        }, {
          "label": "Center",
          "value": "center",
          "barIcon": "TextAlignCenter",
          "barTitle": "Align center"
        }, {
          "label": "Right",
          "value": "right",
          "barIcon": "TextAlignRight",
          "barTitle": "Align right"
        }, {
          "label": "Justify",
          "value": "justify",
          "barIcon": "TextAlignJustify",
          "barTitle": "Justify text"
        }]
      }
    ]
  },
  "numberfield": {
    "name": "Number Field",
    "icon": "123",
    "styles": ["size"],
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/number",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder"
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/number",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "passwordfield": {
    "name": "Password Field",
    "icon": "LockClosed",
    "styles": ["size"],
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/string",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder"
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/string",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "optionsfield": {
    "name": "Options Picker",
    "icon": "ViewList",
    "styles": ["size"],
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/options",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder",
        "placeholder": "Choose an option"
      },
      {
        "type": "select",
        "label": "Type",
        "key": "optionsType",
        "defaultValue": "select",
        "placeholder": "Pick an options type",
        "options": [
          {
            "label": "Select",
            "value": "select"
          },
          {
            "label": "Radio buttons",
            "value": "radio"
          }
        ]
      },
      {
        "type": "select",
        "label": "Direction",
        "key": "direction",
        "defaultValue": "vertical",
        "options": [
          {
            "label": "Horizontal",
            "value": "horizontal"
          },
          {
            "label": "Vertical",
            "value": "vertical"
          }
        ],
        "dependsOn": {
          "setting": "optionsType",
          "value": "radio"
        }
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Autocomplete",
        "key": "autocomplete",
        "defaultValue": false,
        "dependsOn": {
          "setting": "optionsType",
          "value": "select"
        }
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "select",
        "label": "Options source",
        "key": "optionsSource",
        "defaultValue": "schema",
        "placeholder": "Pick an options source",
        "options": [
          {
            "label": "Schema",
            "value": "schema"
          },
          {
            "label": "Data provider",
            "value": "provider"
          },
          {
            "label": "Custom",
            "value": "custom"
          }
        ]
      },
      {
        "type": "dataProvider",
        "label": "Options Provider",
        "key": "dataProvider",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "provider"
        }
      },
      {
        "type": "field",
        "label": "Label Column",
        "key": "labelColumn",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "provider"
        }
      },
      {
        "type": "field",
        "label": "Value Column",
        "key": "valueColumn",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "provider"
        }
      },
      {
        "type": "options",
        "key": "customOptions",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "custom"
        }
      },
      {
        "type": "validation/string",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "multifieldselect": {
    "name": "Multi-select Picker",
    "icon": "ViewList",
    "styles": ["size"],
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/array",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder",
        "placeholder": "Choose an option"
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Autocomplete",
        "key": "autocomplete",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "select",
        "label": "Options source",
        "key": "optionsSource",
        "defaultValue": "schema",
        "placeholder": "Pick an options source",
        "options": [
          {
            "label": "Schema",
            "value": "schema"
          },
          {
            "label": "Data provider",
            "value": "provider"
          },
          {
            "label": "Custom",
            "value": "custom"
          }
        ]
      },
      {
        "type": "dataProvider",
        "label": "Options Provider",
        "key": "dataProvider",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "provider"
        }
      },
      {
        "type": "field",
        "label": "Label Column",
        "key": "labelColumn",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "provider"
        }
      },
      {
        "type": "field",
        "label": "Value Column",
        "key": "valueColumn",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "provider"
        }
      },
      {
        "type": "options",
        "key": "customOptions",
        "dependsOn": {
          "setting": "optionsSource",
          "value": "custom"
        }
      },
      {
        "type": "validation/array",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "booleanfield": {
    "name": "Checkbox",
    "icon": "Checkmark",
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/boolean",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Text",
        "key": "text"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "options": [
          {
            "label": "Small",
            "value": "S"
          },
          {
            "label": "Medium",
            "value": "M"
          },
          {
            "label": "Large",
            "value": "L"
          },
          {
            "label": "Extra large",
            "value": "XL"
          }
        ],
        "defaultValue": "M"
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/boolean",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "longformfield": {
    "name": "Rich Text",
    "icon": "TextParagraph",
    "styles": ["size"],
    "editable": true,
    "settings": [
      {
        "type": "field/longform",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder",
        "placeholder": "Type something..."
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/string",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "datetimefield": {
    "name": "Date Picker",
    "icon": "DateInput",
    "styles": ["size"],
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/datetime",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder"
      },
      {
        "type": "boolean",
        "label": "Show Time",
        "key": "enableTime",
        "defaultValue": true
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/datetime",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "attachmentfield": {
    "name": "Attachment",
    "icon": "Attach",
    "styles": ["size"],
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/attachment",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Extensions",
        "key": "extensions"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/attachment",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "relationshipfield": {
    "name": "Relationship Picker",
    "icon": "TaskList",
    "styles": ["size"],
    "editable": true,
    "illegalChildren": ["section"],
    "settings": [
      {
        "type": "field/link",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder"
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Autocomplete",
        "key": "autocomplete",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/link",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "jsonfield": {
    "name": "JSON Field",
    "icon": "Brackets",
    "styles": ["size"],
    "editable": true,
    "settings": [
      {
        "type": "field/json",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "text",
        "label": "Placeholder",
        "key": "placeholder"
      },
      {
        "type": "text",
        "label": "Default value",
        "key": "defaultValue"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      }
    ]
  },
  "dataprovider": {
    "name": "Data Provider",
    "info": "Pagination is only available for data stored in tables.",
    "icon": "Data",
    "illegalChildren": ["section"],
    "hasChildren": true,
    "actions": ["RefreshDatasource"],
    "settings": [
      {
        "type": "dataSource",
        "label": "Data",
        "key": "dataSource"
      },
      {
        "type": "filter",
        "label": "Filtering",
        "key": "filter"
      },
      {
        "type": "field",
        "label": "Sort Column",
        "key": "sortColumn"
      },
      {
        "type": "select",
        "label": "Sort Order",
        "key": "sortOrder",
        "options": ["Ascending", "Descending"],
        "defaultValue": "Descending"
      },
      {
        "type": "number",
        "label": "Limit",
        "key": "limit",
        "defaultValue": 50
      },
      {
        "type": "boolean",
        "label": "Paginate",
        "key": "paginate",
        "defaultValue": true
      }
    ],
    "context": {
      "type": "static",
      "values":  [
        {
          "label": "Rows",
          "key": "rows"
        },
	{
	  "label": "Extra Info",
	  "key": "info"
	},
        {
          "label": "Rows Length",
          "key": "rowsLength"
        },
        {
          "label": "Schema",
          "key": "schema"
        },
        {
          "label": "Page Number",
          "key": "pageNumber"
        }
      ]
    }
  },
  "table": {
    "name": "Table",
    "icon": "Table",
    "illegalChildren": ["section"],
    "hasChildren": true,
    "showEmptyState": false,
    "settings": [
      {
        "type": "dataProvider",
        "label": "Data provider",
        "key": "dataProvider"
      },
      {
        "type": "number",
        "label": "Row count",
        "key": "rowCount",
        "defaultValue": 8
      },
      {
        "type": "multifield",
        "label": "Columns",
        "key": "columns",
        "dependsOn": "dataProvider",
        "placeholder": "All columns"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "defaultValue": "spectrum--medium",
        "options": [
          {
            "label": "Medium",
            "value": "spectrum--medium"
          },
          {
            "label": "Large",
            "value": "spectrum--large"
          }
        ]
      },
      {
        "type": "boolean",
        "label": "Quiet",
        "key": "quiet"
      },
      {
        "type": "boolean",
        "label": "Show auto columns",
        "key": "showAutoColumns",
        "defaultValue": false
      },
      {
        "type": "boolean",
        "label": "Link table rows",
        "key": "linkRows"
      },
      {
        "type": "boolean",
        "label": "Open link screens in modal",
        "key": "linkPeek"
      },
      {
        "type": "url",
        "label": "Link screen",
        "key": "linkURL"
      },
      {
        "section": true,
        "name": "Advanced",
        "settings": [
          {
            "type": "field",
            "label": "ID column for linking (appended to URL)",
            "key": "linkColumn",
            "placeholder": "Default"
          }
        ]
      }
    ],
    "context": {
      "type": "schema"
    }
  },
  "daterangepicker": {
    "name": "Date Range",
    "icon": "Date",
    "styles": ["size"],
    "hasChildren": false,
    "info": "Your data provider will be automatically filtered to the given date range.",
    "settings": [
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "field",
        "label": "Date field",
        "key": "field"
      },
      {
        "type": "select",
        "label": "Default range",
        "key": "defaultValue",
        "options": [
          "Last 1 day",
          "Last 7 days",
          "Last 30 days",
          "Last 3 months",
          "Last 6 months",
          "Last 1 year"
        ],
        "defaultValue": "Last 30 days"
      }
    ]
  },
  "spectrumcard": {
    "name": "Card",
    "icon": "Card",
    "styles": ["size"],
    "settings": [
      {
        "type": "text",
        "key": "title",
        "label": "Title"
      },
      {
        "type": "text",
        "key": "subtitle",
        "label": "Subtitle"
      },
      {
        "type": "text",
        "key": "description",
        "label": "Description"
      },
      {
        "type": "text",
        "key": "imageURL",
        "label": "Image URL"
      },
      {
        "type": "url",
        "key": "linkURL",
        "label": "Link URL"
      },
      {
        "type": "boolean",
        "key": "linkPeek",
        "label": "Open link in modal"
      },
      {
        "type": "boolean",
        "key": "horizontal",
        "label": "Horizontal"
      },
      {
        "type": "boolean",
        "label": "Show button",
        "key": "showButton"
      },
      {
        "type": "text",
        "key": "buttonText",
        "label": "Button text"
      },
      {
        "type": "event",
        "label": "Button action",
        "key": "buttonOnClick"
      }
    ]
  },
  "dynamicfilter": {
    "name": "Dynamic Filter",
    "icon": "FilterEdit",
    "showSettingsBar": true,
    "settings": [
      {
        "type": "dataProvider",
        "label": "Provider",
        "key": "dataProvider"
      },
      {
        "type": "multifield",
        "label": "Allowed filter fields",
        "key": "allowedFields",
        "placeholder": "All fields"
      },
      {
        "type": "select",
        "label": "Button size",
        "showInBar": true,
        "key": "size",
        "options": [
          {
            "label": "Small",
            "value": "S"
          },
          {
            "label": "Medium",
            "value": "M"
          },
          {
            "label": "Large",
            "value": "L"
          },
          {
            "label": "Extra large",
            "value": "XL"
          }
        ],
        "defaultValue": "M"
      }
    ]
  },
  "tableblock": {
    "block": true,
    "name": "Table block",
    "icon": "Table",
    "styles": ["size"],
    "info": "Only the first 3 search columns will be used.",
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataSource",
        "label": "Data",
        "key": "dataSource"
      },
      {
        "type": "searchfield",
        "label": "Search Columns",
        "key": "searchColumns",
        "placeholder": "Choose search columns"
      },
      {
        "type": "filter",
        "label": "Filtering",
        "key": "filter"
      },
      {
        "type": "field",
        "label": "Sort Column",
        "key": "sortColumn"
      },
      {
        "type": "select",
        "label": "Sort Order",
        "key": "sortOrder",
        "options": ["Ascending", "Descending"],
        "defaultValue": "Descending"
      },
      {
        "type": "select",
        "label": "Size",
        "key": "size",
        "defaultValue": "spectrum--medium",
        "options": [
          {
            "label": "Medium",
            "value": "spectrum--medium"
          },
          {
            "label": "Large",
            "value": "spectrum--large"
          }
        ]
      },
      {
        "type": "boolean",
        "label": "Paginate",
        "key": "paginate",
        "defaultValue": true
      },
      {
        "section": true,
        "name": "Table",
        "settings": [
          {
            "type": "number",
            "label": "Row Count",
            "key": "rowCount",
            "defaultValue": 8
          },
          {
            "type": "multifield",
            "label": "Table Columns",
            "key": "tableColumns",
            "dependsOn": "dataSource",
            "placeholder": "All columns"
          },
          {
            "type": "boolean",
            "label": "Quiet table variant",
            "key": "quiet"
          },
          {
            "type": "boolean",
            "label": "Show auto columns",
            "key": "showAutoColumns"
          },
          {
            "type": "boolean",
            "label": "Link table rows",
            "key": "linkRows"
          },
          {
            "type": "boolean",
            "label": "Open link in modal",
            "key": "linkPeek"
          },
          {
            "type": "url",
            "label": "Link screen",
            "key": "linkURL"
          }
        ]
      },
      {
        "section": true,
        "name": "Title button",
        "settings": [
          {
            "type": "boolean",
            "key": "showTitleButton",
            "label": "Show link button",
            "defaultValue": false
          },
          {
            "type": "boolean",
            "label": "Open link in modal",
            "key": "titleButtonPeek"
          },
          {
            "type": "text",
            "key": "titleButtonText",
            "label": "Button text"
          },
          {
            "type": "url",
            "label": "Button link",
            "key": "titleButtonURL"
          }
        ]
      },
      {
        "section": true,
        "name": "Advanced",
        "settings": [
          {
            "type": "field",
            "label": "ID column for linking (appended to URL)",
            "key": "linkColumn",
            "placeholder": "Default"
          }
        ]
      }
    ]
  },
  "cardsblock": {
    "block": true,
    "name": "Cards block",
    "icon": "Table",
    "styles": ["size"],
    "info": "Only the first 3 search columns will be used.",
    "settings": [
      {
        "type": "text",
        "label": "Title",
        "key": "title"
      },
      {
        "type": "dataSource",
        "label": "Data",
        "key": "dataSource"
      },
      {
        "type": "searchfield",
        "label": "Search Columns",
        "key": "searchColumns",
        "placeholder": "Choose search columns"
      },
      {
        "type": "filter",
        "label": "Filtering",
        "key": "filter"
      },
      {
        "type": "field",
        "label": "Sort Column",
        "key": "sortColumn"
      },
      {
        "type": "select",
        "label": "Sort Order",
        "key": "sortOrder",
        "options": ["Ascending", "Descending"],
        "defaultValue": "Descending"
      },
      {
        "type": "number",
        "label": "Limit",
        "key": "limit",
        "defaultValue": 8
      },
      {
        "type": "boolean",
        "label": "Paginate",
        "key": "paginate"
      },
      {
        "section": true,
        "name": "Cards",
        "settings": [
          {
            "type": "text",
            "key": "cardTitle",
            "label": "Title",
            "nested": true
          },
          {
            "type": "text",
            "key": "cardSubtitle",
            "label": "Subtitle",
            "nested": true
          },
          {
            "type": "text",
            "key": "cardDescription",
            "label": "Description",
            "nested": true

          },
          {
            "type": "text",
            "key": "cardImageURL",
            "label": "Image URL",
            "nested": true
          },
          {
            "type": "boolean",
            "key": "linkCardTitle",
            "label": "Link card title"
          },
          {
            "type": "boolean",
            "key": "cardPeek",
            "label": "Open link in modal"
          },
          {
            "type": "url",
            "label": "Link screen",
            "key": "cardURL",
            "nested": true
          },
          {
            "type": "boolean",
            "key": "cardHorizontal",
            "label": "Horizontal"
          },
          {
            "type": "boolean",
            "label": "Show button",
            "key": "showCardButton"
          },
          {
            "type": "text",
            "key": "cardButtonText",
            "label": "Button text",
            "nested": true
          },
          {
            "type": "event",
            "label": "Button action",
            "key": "cardButtonOnClick",
            "nested": true
          }
        ]
      },
      {
        "section": true,
        "name": "Title button",
        "settings": [
          {
            "type": "boolean",
            "key": "showTitleButton",
            "label": "Show link button"
          },
          {
            "type": "boolean",
            "label": "Open link in modal",
            "key": "titleButtonPeek"
          },
          {
            "type": "text",
            "key": "titleButtonText",
            "label": "Button text"
          },
          {
            "type": "url",
            "label": "Button link",
            "key": "titleButtonURL"
          }
        ]
      },
      {
        "section": true,
        "name": "Advanced",
        "settings": [
          {
            "type": "field",
            "label": "ID column for linking (appended to URL)",
            "key": "linkColumn",
            "placeholder": "Default"
          }
        ]
      }
    ],
    "context": {
      "type": "schema",
      "suffix": "repeater"
    }
  },
  "repeaterblock": {
    "name": "Repeater block",
    "icon": "ViewList",
    "illegalChildren": ["section"],
    "hasChildren": true,
    "showSettingsBar": true,
    "settings": [
      {
        "type": "dataSource",
        "label": "Data",
        "key": "dataSource"
      },
      {
        "type": "filter",
        "label": "Filtering",
        "key": "filter"
      },
      {
        "type": "field",
        "label": "Sort Column",
        "key": "sortColumn"
      },
      {
        "type": "select",
        "label": "Sort Order",
        "key": "sortOrder",
        "options": ["Ascending", "Descending"],
        "defaultValue": "Descending"
      },
      {
        "type": "number",
        "label": "Limit",
        "key": "limit",
        "defaultValue": 10
      },
      {
        "type": "boolean",
        "label": "Paginate",
        "key": "paginate"
      },
      {
        "section": true,
        "name": "Layout settings",
        "settings": [
          {
            "type": "text",
            "label": "Empty Text",
            "key": "noRowsMessage",
            "defaultValue": "No rows found"
          },
          {
            "type": "select",
            "label": "Direction",
            "key": "direction",
            "showInBar": true,
            "barStyle": "buttons",
            "options": [
              {
                "label": "Column",
                "value": "column",
                "barIcon": "ViewRow",
                "barTitle": "Column layout"
              },
              {
                "label": "Row",
                "value": "row",
                "barIcon": "ViewColumn",
                "barTitle": "Row layout"
              }
            ],
            "defaultValue": "column"
          },
          {
            "type": "select",
            "label": "Horiz. Align",
            "key": "hAlign",
            "showInBar": true,
            "barStyle": "buttons",
            "options": [
              {
                "label": "Left",
                "value": "left",
                "barIcon": "AlignLeft",
                "barTitle": "Align left"
              },
              {
                "label": "Center",
                "value": "center",
                "barIcon": "AlignCenter",
                "barTitle": "Align center"
              },
              {
                "label": "Right",
                "value": "right",
                "barIcon": "AlignRight",
                "barTitle": "Align right"
              },
              {
                "label": "Stretch",
                "value": "stretch",
                "barIcon": "MoveLeftRight",
                "barTitle": "Align stretched horizontally"
              }
            ],
            "defaultValue": "stretch"
          },
          {
            "type": "select",
            "label": "Vert. Align",
            "key": "vAlign",
            "showInBar": true,
            "barStyle": "buttons",
            "options": [
              {
                "label": "Top",
                "value": "top",
                "barIcon": "AlignTop",
                "barTitle": "Align top"
              },
              {
                "label": "Middle",
                "value": "middle",
                "barIcon": "AlignMiddle",
                "barTitle": "Align middle"
              },
              {
                "label": "Bottom",
                "value": "bottom",
                "barIcon": "AlignBottom",
                "barTitle": "Align bottom"
              },
              {
                "label": "Stretch",
                "value": "stretch",
                "barIcon": "MoveUpDown",
                "barTitle": "Align stretched vertically"
              }
            ],
            "defaultValue": "top"
          },
          {
            "type": "select",
            "label": "Gap",
            "key": "gap",
            "showInBar": true,
            "barStyle": "picker",
            "options": [
              {
                "label": "None",
                "value": "N"
              },
              {
                "label": "Small",
                "value": "S"
              },
              {
                "label": "Medium",
                "value": "M"
              },
              {
                "label": "Large",
                "value": "L"
              }
            ],
            "defaultValue": "M"
          }
        ]
      }
    ],
    "context": [
      {
        "type": "static",
        "suffix": "provider",
        "values":  [
          {
            "label": "Rows",
            "key": "rows"
          },
	  {
            "label": "Extra Info",
            "key": "info"
          },
          {
            "label": "Rows Length",
            "key": "rowsLength"
          },
          {
            "label": "Schema",
            "key": "schema"
          },
          {
            "label": "Page Number",
            "key": "pageNumber"
          }
        ]
      },
      {
        "type": "static",
        "suffix": "repeater",
        "values":  [
          {
            "label": "Row Index",
            "key": "index"
          }
         ]
      },
      {
        "type": "schema",
        "suffix": "repeater"
      }
    ]
  },
  "s3upload": {
    "name": "S3 File Upload",
    "info": "This component can't be used with S3 datasources that use custom endpoints.",
    "icon": "UploadToCloud",
    "styles": ["size"],
    "editable": true,
    "settings": [
      {
        "type": "field/attachment",
        "label": "Field",
        "key": "field"
      },
      {
        "type": "text",
        "label": "Label",
        "key": "label"
      },
      {
        "type": "dataSource/s3",
        "label": "S3 Datasource",
        "key": "datasourceId"
      },
      {
        "type": "text",
        "label": "Bucket",
        "key": "bucket"
      },
      {
        "type": "text",
        "label": "File Name",
        "key": "key"
      },
      {
        "type": "boolean",
        "label": "Disabled",
        "key": "disabled",
        "defaultValue": false
      },
      {
        "type": "validation/attachment",
        "label": "Validation",
        "key": "validation"
      }
    ]
  },
  "markdownviewer": {
    "name": "Markdown Viewer",
    "icon": "TaskList",
    "styles": ["size"],
    "editable": true,
    "settings": [
      {
        "type": "text",
        "label": "Markdown",
        "key": "value"
      }
    ]
  }
}