npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

html-improved

v0.2.4

Published

Adds improvements to html templates

Downloads

22

Readme

html-improved Build Status npm package

Html template engine, inspired by jade

Adds improvements to html templates

Sample Project

html-improved-sample

Reference

Includes

Includes allow you to insert the contents of one HTML file into another.

<html>
    <head>
        ...
    </head>
    <body>
        <include file="./includes/sidebar.html" />
        <include file="./includes/footer.html" />
    </body>
</html>

Including Plain Text

Including files that are not HTML (.html, .html, .xhtml, .xml) just includes the raw text.

<html>
    <head>
        <include file="./style.css" />
    </head>
    <body>
        ...
    </body>
</html>

Template inheritance

Html Improved supports template inheritance via the <block/> and <extends/> keywords.

A block is simply a "block" of HTML that may be replaced within a child template, this process is recursive.

Html Improved blocks can provide default content if desired, however optional as shown below by block scripts, block content, and block foot.

<!-- layout.html -->
<html>
    <head>
        <block name="scripts">
            <script src="./jquery.js"></script>
        </block>
    </head>
    <body>
        <block name="content" />
        <div id="footer">
            <block name="footer">
                <p>some footer content</p>
            </block>
        </div>
    </body>
</html>

Now to extend the layout, simply create a new file and use the <extends/> tag as shown below, giving the path (with the extension). You may now define one or more blocks that will override the parent block content, note that here the foot block is not redefined and will output "some footer content".

<!-- page-a.html -->
<extends file="./layout.html" />

<block name="scripts">
    <script src="./jquery.js"></script>
    <script src="./pets.js"></script>
</block>

<block name="content">
    <h1>title</h1>
</block>

It's also possible to override a block to provide additional blocks, as shown in the following example where content now exposes a sidebar and primary block for overriding, or the child template could override content all together.

<!-- sub-layout.html -->
<extends file="./layout.html" />

<block name="content">
    <block name="sidebar">
        <div id="sidebar">
            <p>nothing</p>
        </div>
    </block>
    <div class="primary">
        <block name="primary">
            <p>nothing</p>
        </block>
    </div>
</block>
<!-- page-b.html -->
<extends file="./sub-layout.html" />

<block name="sidebar">
    <ul>...</ul>
</block>

Block append / prepend

Html Improved allows you to replace (default), prepend, or append blocks.

Suppose for example you have default scripts in a "head" block that you wish to utilize on every page, you might do this:

<!-- layout.html -->
<html>
    <head>
        <block name="scripts">
            <script src="./jquery.js"></script>
        </block>
    </head>
    <body>
        ...
    </body>
</html>

Now suppose you have a page of your application for a JavaScript game, you want some game related scripts as well as these defaults, you can simply append the block:

<!-- page.html -->
<extends file="./layout.html" />

<block name="scripts" append>
    <script src="./vendor/three.js"></script>
    <script src="./game.js"></script>
</block>

Variables

Html Improved makes it possible to define variables that can be used in your templates, using <vars/> tag.

<vars
    pageTitle="On Dogs: Man's Best Friend"
    page-author="Alex"
/>

<html>
    <head>
        <title>#{pageTitle}</title>
    </head>
    <body>
        #{pageAuthor}
    </body>
</html>

<vars
    pageAuthor="Alex Rodin"
/>

note that pageAuthor and page-author forms define the same variable (pageAuthor).

Whenever you define a variable, all previous definitions of this variable will be overwritten.

Conditional

Html Improved has syntax for conditional rendering of html blocks through tag <if />.

<vars
    description="foo bar baz"
    authorised="false"
/>

<div id="user">
    <if cond="description">
        <h2>Description</h2>
        <p class="description">#{description}</p>
    </if>
    <if cond="!description">
        <h2>Description</h2>
        <p class="description">Has no description</p>
    </if>
    <if cond="authorised">
        <p>No content provided</p>
    </if>
</div>

<!-- will output -->
<div id="user">
    <h2>Description</h2>
    <p class="description">foo bar baz</p>
</div>

String Escaped

To escape safely strings, just use the operator #{ and }.

<vars
    theGreat="<span>escape!</span>"
/>

<p>This will be safe: #{theGreat}</p>

will output

<p>This will be safe: &lt;span&gt;escape!&lt;/span&gt;</p>

String Unescaped

You don't have to play it safe. You can buffer unescaped values into your templates using !{ and } operator.

<vars
    riskyBusiness="<em>Some of the girls are wearing my mother's clothing.</em>"
/>
<div class="quote">
    <p>Joel: !{riskyBusiness}</p>
</div>

will output

<div class="quote">
  <p>Joel: <em>Some of the girls are wearing my mother's clothing.</em></p>
</div>

Iteration

Html Improved supports one primary method of iteration, <each />.

Html Improved iteration syntax makes it easier to iterate over arrays and objects within a template:

<vars
    objectVar="{attr1:'One', attr2:'Two'}"
    arrayVar="[{name:'Alex'}, {name:'Jhon'}, {name:'Gabriel'}, {name:'Darwin'}]"
    innerVar="[[1,2,3],[4,5,6],[7,8,9,10],[11]]"
    />

<ul>
    <each in="[5,4,3,2,1,0]">
        <li>
            #{$key} - #{$value}
        </li>
    </each>
</ul>

<ul>
    <each in="objectVar">
        <li>
            #{$key} - #{$value}
        </li>
    </each>
</ul>

<ul>
    <each var="value" in="objectVar">
        <li>
            #{$key} - #{value}
        </li>
    </each>
</ul>

<ul>
    <each var="key, value" in="objectVar">
        <li>
            #{key} - #{value}
        </li>
    </each>
</ul>


<ul>
    <each in="arrayVar">
        <li>
            #{$key} - #{$value.name}
        </li>
    </each>
</ul>

<ul>
    <each var="value" in="arrayVar">
        <li>
            #{$key} - #{value.name}
        </li>
    </each>
</ul>

<ul>
    <each var="key, value" in="arrayVar">
        <li>
            #{key} - #{value.name}
        </li>
    </each>
</ul>


<each var="key, value" in="innerVar">
    <each var="subKey, subValue" in="value">
        <p>
            #{key} - #{subKey} - #{subValue}
        </p>
    </each>
</each>

Mixins

Mixins allow you to create reusable blocks of HTML.

<!-- Declaration -->
<mixin name="list">
    <ul>
        <li>foo</li>
        <li>bar</li>
        <li>baz</li>
    </ul>
</mixin>

<!-- Use -->
<list />

<!-- Will output -->
<ul>
    <li>foo</li>
    <li>bar</li>
    <li>baz</li>
</ul>

They can take required arguments:

<!-- Declaration -->
<mixin name="pet" params="name">
    <li>#{name}</li>
</mixin>

<!-- Use -->
<ul>
    <pet name="cat"/>
    <pet name="dog"/>
    <pet name="pig"/>
</ul>


<!-- Will output -->
<ul>
    <li>cat</li>
    <li>dog</li>
    <li>pig</li>
</ul>

Mixin content

Mixins can also take a block of HTML to act as the content:

<!-- Declaration -->
<mixin name="article" params="title, authorName">
    <div class="article">
        <div class="article-wrapper">
            <h1>#{title}</h1>
            <span>#{authorName}</span>
            <if cond="$content">
                !{$content}
            </if>
            <if cond="!$content">
                <p>No content!</p>
            </if>
        </div>
    </div>
</mixin>

<!-- Use -->
<article title="Hello world" author-name="John Doe" />
<article title="Hello world" author-name="John Doe">
    <p>This is my</p>
    <p>Amazing article</p>
</article>


<!-- Will output -->
<div class="article">
    <div class="article-wrapper">
        <h1>Hello world</h1>
        <span>John Doe</span>
        <p>No content!</p>
    </div>
</div>
<div class="article">
    <div class="article-wrapper">
        <h1>Hello world</h1>
        <span>John Doe</span>
        <p>This is my</p>
        <p>Amazing article</p>
    </div>
</div>

Mixin Attributes

Mixins also get an implicit attributes argument taken from the attributes passed to the mixin and variables.

<!-- Declaration -->
<mixin name="link" params="href, name">
    <a class="#{klass}" href="#{basePath}/#{href}">#{name}</a>
</mixin>


<!-- Use -->
<link href="foo.html" name="bar" klass="btn"/>

<vars
    basePath="/my/base/path"
/>


<!-- Will output -->
<a href="/my/base/path/foo.html" class="btn">bar</a>