low-layoutdeprecated

A template layout system

Usage no npm install needed!

<script type="module">
  import lowLayout from 'https://cdn.skypack.dev/low-layout';
</script>

README

express-low-layout

Low-layout is a layout system based on Mustache and Express.

Instalation

$ npm install express-low-layout

Usage

const layout = require('low-layout')
app.use(layout)

Exemple:

install express and express-low-layout

$ npm install --save express 
$ npm install --save express-low-layout

index.js

Create a simple express app with two route: /home and /test

var express = require('express')
var layout = require('express-low-layout')
var app = express()

//set the views directory
app.set('view', './views')
app.use(layout)

//home route
app.get('/home', function (req, res) {
  //load the layout from the file home.html
  req.layout.loadTemplate('home.html')

  //send the layout html
  req.layout.render().then((html) => {
    res.send(html)
  })
})

//test route
app.get('/test', function (req, res) {
  //load the layout from the file test.html
  req.layout.loadTemplate('test.html')

  //Set the title of the block head
  req.layout.getBlock('head').data.title = 'Test page'

  //send the layout html
  req.layout.render().then((html) => {
    res.send(html)
  })
})

app.get('*', function (req, res) {
  res.redirect('/home')
})

app.listen(3000, function () {
  console.log('Example app listening on port 3000!')
})

/views/page/default.html

The template for the page For the template syntax read the mustache js documentation

<template>
    <!doctype html>
    <html lang="en">
    <!-- block head -->
    {{{blocks.head}}}
    <body>

    <header>
        <nav>
            <ul>
                <li>
                    <a href="/home">Home</a>
                </li>
                <li>
                    <a href="/test">Test</a>
                </li>
            </ul>
        </nav>
    </header>
    <main role="main">
        <!-- block content -->
        {{{blocks.content}}}
    </main>

    <footer>
        <p>footer</p>
    </footer>
    </body>
    </html>
</template>
<script>
  //Require the block dependency
  var Block = require('low-layout/block')

  //Block for the page
  class Default extends Block {
    init () {
      //set the name of the block
      //the name of the block can be define in this way or for other block it can be defined in the config
      this.name = 'page'

      //Add the head block
      this.addBlock({name: 'head', template: 'page/head.html'})

      //content block it just a block container
      //to use block with no html temple use type
      this.addBlock({name: 'content', type: 'container'})
    }

    beforeRender () {
      //Add a css in the head block
      this.layout.getBlock('head').addCss('https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css')
    }
  }

  module.exports = Default
</script>

/views/page/head.html

template for the head block define in the file views/page/default.html

<template>
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
        <meta name="description" content="">
        <meta name="author" content="">

        <title>{{title}}</title>
        {{#css}}
        <link rel="stylesheet" href="{{{.}}}">
        {{/css}}

        {{#js}}
        <script src="{{{.}}}"></script>
        {{/js}}
    </head>
</template>
<script>
  //requite the block object
  var Block = require('low-layout/block')

  //A Test class for the test page
  class Head extends Block {

    init () {
      this.data.css = []
      this.data.js = []
    }

    addCss (cssFiles) {
      if (Array.isArray(cssFiles)) {
        for (var key in cssFiles) {
          this.data.css.push(cssFiles[key])
        }
      } else if (typeof cssFiles === 'string') {
        this.data.css.push(cssFiles)
      } else {
        throw Error('Invalid addCss argument')
      }
    }

    addJs (jsFiles) {
      if (Array.isArray(jsFiles)) {
        for (var key in jsFiles) {
          this.data.js.push(jsFiles[key])
        }
      } else if (typeof jsFiles === 'string') {
        this.data.js.push(jsFiles)
      } else {
        throw Error('Invalid addJs argument')
      }
    }
  }

  module.exports = Head
</script>

/views/home.html

The template for the /home route

<template>
    <div>
        <h1>Home page</h1>
    </div>
</template>
<script>
  //requite the block object
  var Block = require('low-layout/block')

  //A Block class for the home page
  class Home extends Block {
    init () {
      this.page ='page/default.html'
        //name of the parent block of this block
        //here the block content, it is defined in the file page/default.html
      this.parent = 'content'

    }

    beforeRender() {
      //set the name of the head block
      this.layout.getBlock('head').data.title = 'Home page'
    }
  }

  module.exports = Home
</script>

/views/test.html

The template for the /test route

<template>
    <div class="test">
        <h1>Test</h1>
    </div>
</template>
<script>
  //requite the block object
  var Block = require('low-layout/block')

  //A Test class for the test page
  class Test extends Block {
    init () {
      this.page ='page/default.html'
      //name of the parent block of this block
      //here the block content, it is defined in the file page/default.html
      this.parent= 'content'
    }
  }

  module.exports = Test
</script>

Run:

$ node index.js