0.6.2 • Published 8 months ago
@titsoft/layout-m v0.6.2
layout-m
 layout-m is a custom element for grouping template instances
- to layout them
- to let its children to be part of its parent layout with level-upattribute
Templates follow the rules from @titsoft/dry-html
Example
<template id="a-card">
  <div class="card">
    <img src="https://placehold.jp/200x200.png" alt="Avatar">
    <div class="container">
        <p><b>{t-name}</b></p> 
        <p>{t-job}</p> 
    </div>
  </div>
</template>
 <!-- Declaration via
  - a template attribute
  - a (json) source attribute either
     - a file or url to be fetched, eg: ./data.json or https://my-api/my-data
     - an id referencing an application/json script, eg: #data
  - an optional root attribute which offsets the array
  - any t-* that needs a non root path
-->
  <layout-m
    template="a-card"
    source="https://my-api/my-data"
    root="records"
    t-id="job.id"
  ></layout-m>with such a json input
  {
    "records": [
      {
        "name": "Leila Sunflower",
        "job": {
          "id": 1,
          "name": "Soil Mender"
        }
      },
      {
        "name": "John Green",
        "job": {
          "id": 2,
          "name": "Industry Mender"
        }
      }
    ]
  }level-up attribute
Boolean level-up attribute allows to replace a transient layout-m custom-element by its children allowing to layout those children with former layout-m siblings
 <layout-m
    template="a-template"
    source="#data"
    level-up
 ></layout-m>