Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@thi.ng/hiccup-html

Package Overview
Dependencies
Maintainers
1
Versions
134
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@thi.ng/hiccup-html

100+ type-checked HTML5 element functions for @thi.ng/hiccup related infrastructure

  • 0.3.15
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
280
increased by723.53%
Maintainers
1
Weekly downloads
 
Created
Source

hiccup-html

npm version npm downloads Twitter Follow

This project is part of the @thi.ng/umbrella monorepo.

About

100+ type-checked HTML5 element functions for @thi.ng/hiccup related infrastructure.

The following type-checked factory functions are provided so far and in most cases include specialized type definitions for element-specific attributes, incl. enumerated attrib values (where applicable/useful) and all 420+ CSS property names (for use with the style attrib). See type definitions in api.ts and defElement() below for more details.

Supported elements

Head / metadata

Source

base, head, link, linkCSS, meta, metaReferrer, metaRefresh, metaRobots, metaUTF8, metaViewport, metaXUA, script, style, title

Sections

Source

address, article, aside, body, footer, h1..h6, header, hgroup, html, main, nav, noscript, section

Text content

Source

blockquote, div, figure, figcaption, hr, iframe, para, pre

Lists

Source

datalist, dd, dl, dt, li, ol, ul

Tables

Source

caption, col, colgroup, table, tbody, td, tfoot, th, thead, tr

Inline

Source

abbr, anchor, br, cite, code, data, del, em, i, ins, kbd, mark, quote, small, span, strong, sub, sup, time

Forms / inputs

Source

button, checkbox, fieldset, form, inputColor, inputFile, inputNumber, inputPass, inputRange, inputSearch, inputText, label, legend, meter, option, optGroup, progress, radio, select, textArea

Media

Source

audio, canvas, img, picture, source, video

Compatibility

The hiccup syntax is (by design) merely a convention and specific feature support and interpretation is down to the actual tooling used.

Whilst not a direct aspect or feature of this package, the type definitions for element attributes defined here allow certain constructs which are only supported by some hiccup consumers. OTOH not all of the constructs are meaningful in the different usage contexts and for most there're compatible alternative ways of expressing the same data.

The table below provides an overview of the current syntax feature support by the relevant packages consuming hiccup:

FeatureExample and HTML equivalent/resulthiccuphdomrdom
Emmet style tags["div#id.foo", {}]
<div id="id" class="foo">
class attrib as object["a.bar.baz", { class: { foo: true, bar: false }}]
<a class="baz foo">
style attrib as object["div", { style: { color: "red" }}]
<div style="color:red;">
Attrib array values["img", { srcset: ["1.jpg", "2.jpg"] }]
<img srcset="1.jpg, 2.jpg">
Data attribs as object["a", { data: { foo: 42 }}]
<a data-foo="42">
Function attrib values (1)["a", { id: () => "epoch-" + Date.now() }]
<a id="epoch-1593024083666">
IDeref attrib values (2)["div", { id: { deref() { return "foo"; }}}]
<div id="foo">

All other features not explicitly mentioned are supported by all three packages.

(1) Excluding event listener attribs, these are always function values of course, but will NOT be evaluated to obtain final attrib value

(2) The IDeref interface is implemented by various data structures in the thi.ng/umbrella eco system (most relevant: @thi.ng/rstream, @thi.ng/atom).

Status

ALPHA - bleeding edge / work-in-progress

Search or submit any issues for this package

The current aim is not necessarily to have wrappers for each possible HTML5 element, but certainly to support the most commonly used ones. PRs welcome!

Installation

yarn add @thi.ng/hiccup-html
// ES module
<script type="module" src="https://unpkg.com/@thi.ng/hiccup-html?module" crossorigin></script>

// UMD
<script src="https://unpkg.com/@thi.ng/hiccup-html/lib/index.umd.js" crossorigin></script>

Package sizes (gzipped, pre-treeshake): ESM: 1.45 KB / CJS: 1.86 KB / UMD: 1.76 KB

Dependencies

Usage examples

Several demos in this repo's /examples directory are using this package.

A selection:

ScreenshotDescriptionLive demoSource
Probabilistic color theme generatorDemoSource
Parser grammar livecoding editor/playground & codegenDemoSource
Interactive pixel sorting tool using thi.ng/color & thi.ng/pixelDemoSource

API

Generated API docs

import { div, label, option, select } from "@thi.ng/hiccup-html";
import { $compile } from "@thi.ng/rdom";

const choices = [
    ["#f00", "Red"],
    ["#ff0", "Yellow"],
    ["#0f0", "Green"],
    ["#0ff", "Cyan"],
    ["#00f", "Blue"],
    ["#f0f", "Magenta"],
];

$compile(
    div(
        null,
        label({ for: "colors" }, "Fave color: "),
        select(
            {
                id: "colors",
                onchange: (e) => alert((<HTMLSelectElement>e.target).value),
            },
            option(null, "Please choose..."),
            ...choices.map((x) => option({ value: x[0] }, x[1]))
        )
    )
).mount(document.body);

defElement

All element functions are created via the higher-order function defElement which produces the typed, variadic factories. defElement takes an element name and optional set of default attributes. It also uses generics to enforce types for the element's attributes (default: Attribs and/or children/body (default: any).

Define element with defaults:

import { defElement } from "@thi.ng/hiccup-html";

const el = defElement("tag")

Define with custom attribs & no children allowed:

import { Attribs, AttribVal, defElement } from "@thi.ng/hiccup-html";

// extend global HTML default attribs
interface MyAttribs extends Attribs {
    class: AttribVal<string>;
    width: AttribVal<number>;
    height: AttribVal<number>;
}

// provide type constraints and default attribs
const el = defElement<Partial<MyAttribs>, never>(
    "tag",
    { width: 100, height: 100 }
);

// or create new versions of existing elements with more limited
// user customization options...
const div = defElement<Partial<Pick<Attribs, "class" | "style">>>("div");

The Attribs interface provides a common, fully typed base definition of HTML attributes (incl. event listeners and enumerated attrib options) and can be found in api.ts.

The AttribVal type wrapper is used to allow for reactive attribute values (in @thi.ng/rdom) and IDeref instances when later providing attribute values to an element.

Element creation

The function returned by defElement has the following signatures:

(attribs?: Nullable<T>, ...body: B[]) => [string, Nullable<T>, ...B[]];

(emmet: string, attribs?: Nullable<T>, ...body: B[]) => [string, Nullable<T>, ...B[]];

The result of either form is a simple tuple, defining an HTML element in @thi.ng/hiccup syntax.

If the second call signature is used, the initial emmet-style string will be appended to the tag name and merely acts as syntax sugar for providing an element ID and/or CSS classes.

const el = defElement<any>("a");
CallResult
el()["a", null]
el(null)["a", null]
el(null, "body")["a", null, "body"]
el({ c: 2 })["a", { c: 2 }]
el({ c: 2 }, "body")["a", { c: 2 }, "body"]
el("#id.foo")["a#id.foo", null]
el("#id.foo", { c: 2 })["a#id.foo", { c: 2 }]
el("#id.foo", { c: 2 }, "body")["a#id.foo", { c: 2 }, "body"]
el("#id.foo", null, "body")["a#id.foo", null, "body"]
// with default attribs
const el = defElement<any>("a", { b: 1 });
CallResult
el()["a", { b: 1 }]
el(null)["a", { b: 1 }]
el(null, "body")["a", { b: 1 }, "body"]
el({ c: 2 })["a", { b: 1, c: 2 }]
el({ c: 2 }, "body")["a", { b: 1, c: 2 }, "body"]
el("#id.foo")["a#id.foo", { b: 1 }]
el("#id.foo", { c: 2 })["a#id.foo", { b: 1, c: 2 }]
el("#id.foo", { c: 2 }, "body")["a#id.foo", { b: 1, c: 2 }, "body"]
el("#id.foo", null, "body")["a#id.foo", { b: 1 }, "body"]

Authors

Karsten Schmidt

If this project contributes to an academic publication, please cite it as:

@misc{thing-hiccup-html,
  title = "@thi.ng/hiccup-html",
  author = "Karsten Schmidt",
  note = "https://thi.ng/hiccup-html",
  year = 2020
}

License

© 2020 - 2021 Karsten Schmidt // Apache Software License 2.0

Keywords

FAQs

Package last updated on 03 Mar 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc