Skip to content

Latest commit

 

History

History
98 lines (77 loc) · 2.51 KB

readme.md

File metadata and controls

98 lines (77 loc) · 2.51 KB

Project Structure

Setup

Run the following commands:

  1. cd components
  2. npm install or yarn install
  3. yarn start

Directories

  1. components/src/components - contains a stenciljs-bootstraped project
    • components/src/components/components - contains a set of web components used when rendering
    • components/src/components/utils - utility functions

Docs

Rendering a component

<jsc-app></jsc-app> is the main entry point for rendering a component. A component is rendered by providing a list of objects conforming to a speficic standard.

Here's an example of how we can render a Navbar component:

[
  {
    "component":"Navbar",
    "sections":{
      "links":[
        {
          "component":"NavLink",
          "props":{
            "label":"Home"
          }
        },
        {
          "component":"NavLink",
          "props":{
            "label":"About"
          }
        }
      ]
    },
    "props":{
      "title": "Jaseci App"
    }
  }
]

Guide

The above code will generate the following markup.

<jsc-nav-bar label="Jaseci App">
  <div slot="links">
    <jsc-nav-link label="Home"></jsc-nav-link>
    <jsc-nav-link label="About"></jsc-nav-link>
  </div>
</jsc-nav-bar>
  • component is used to determine which html element to generate.
  • sections are array of components to be rendered as a child of component, each slot has a name to determine where it will be rendered
  • props are attributes that will be attached to the generated element

The generated navbar might look like this: Jaseci Navbar

Utils

  • renderComponentTree
    • The renderComponentTree functions accepts an array of JaseciComponent and converts it to a string of custom html elements.
  • renderComponent
    • renderComponent accepts a single Jaseci Component component and generates and converts it to a custom html element