Skip to content

Releases: natemoo-re/ultrahtml

v1.0.2

26 Nov 23:23
50d57cf
Compare
Choose a tag to compare

Patch Changes

  • c7a1ef6: Fix edge case with <script> parsing

v1.0.1

18 Nov 23:13
a681814
Compare
Choose a tag to compare

Patch Changes

  • b136e51: Fix unhandled edge case with sanitize transformer
  • dce0b68: Fix style and script elements having their contents parsed as HTML

v1.0.0

09 Nov 19:39
b353bd0
Compare
Choose a tag to compare

Major Changes

  • 95c0f73: ultrahtml is a complete markup toolkit with a tiny footprint. Parse, transform, and render HTML on the server, in the browser, with or without a build step.

    Breaking Changes

    The signature of transform has been updated. Rather than applying sanitization and component swapping by default, these have been split out to individual ultrahtml/transformers that can be applied modularly.

    In [email protected], transform accepted an options object with sanitize and components. Other transformations would need to be applied outside of this flow.

    import { transform } from "ultrahtml";
    
    await transform(markup, {
      components: { h1: "h2" },
      sanitize: { allowElements: ["h1", "h2", "h3"] }
    });

    In [email protected], transform accepts an array of transformers to apply. The sanitize and components options can be handled with the built-in transformers named sanitize and swap.

    import { transform } from "ultrahtml";
    import swap from "ultrahtml/transformers/swap";
    import sanitize from "ultrahtml/transformers/sanitize";
    
    await transform(markup, [
      swap({ h1: "h2" }),
      sanitize({ allowElements: ["h1", "h2", "h3"] })
    ]);

    New Features

    JSX Runtime

    ultrahtml now comes with h and Fragment functions for JSX, as well as a jsx-runtime export.

    Tranformers

    Transformers are AST transformations that can be applied to any ultrahtml Node. Usually these are applied to entire documents.

    New inline transformer inlines CSS from <style> blocks directly to matching elements.

    New scope transformer scopes CSS from <style> blocks to the elements in a given document or component.

Patch Changes

  • 4699020: Update JSX runtime child handling
  • da119c1: Fix transformer definitions
  • d29a0e2: Add resolveAsset option to the inline transformer
  • 401b13a: Fix JSX runtime types
  • 44a771e: Update list of void HTML tags

v1.0.0-next.4

22 Oct 19:11
acc888a
Compare
Choose a tag to compare
v1.0.0-next.4 Pre-release
Pre-release

Patch Changes

  • d29a0e2: Add resolveAsset option to the inline transformer

v1.0.0-next.3

17 Oct 14:53
60efe5d
Compare
Choose a tag to compare
v1.0.0-next.3 Pre-release
Pre-release

Patch Changes

  • 4699020: Update JSX runtime child handling

v1.0.0-next.2

17 Oct 14:41
6c27495
Compare
Choose a tag to compare
v1.0.0-next.2 Pre-release
Pre-release

Patch Changes

v1.0.0-next.1

17 Oct 13:30
4e38d07
Compare
Choose a tag to compare
v1.0.0-next.1 Pre-release
Pre-release

Patch Changes

  • da119c1: Fix transformer definitions

v1.0.0-next.0

17 Oct 13:00
313c078
Compare
Choose a tag to compare
v1.0.0-next.0 Pre-release
Pre-release

Major Changes

  • 95c0f73: ultrahtml is a complete markup toolkit with a tiny footprint. Parse, transform, and render HTML on the server, in the browser, with or without a build step.

    Breaking Changes

    The signature of transform has been updated. Rather than applying sanitization and component swapping by default, these have been split out to individual ultrahtml/transformers that can be applied modularly.

    In [email protected], transform accepted an options object with sanitize and components. Other transformations would need to be applied outside of this flow.

    import { transform } from "ultrahtml";
    
    await transform(markup, {
      components: { h1: "h2" },
      sanitize: { allowElements: ["h1", "h2", "h3"] }
    });

    In [email protected], transform accepts an array of transformers to apply. The sanitize and components options can be handled with the built-in transformers named sanitize and swap.

    import { transform } from "ultrahtml";
    import swap from "ultrahtml/transformers/swap";
    import sanitize from "ultrahtml/transformers/sanitize";
    
    await transform(markup, [
      swap({ h1: "h2" }),
      sanitize({ allowElements: ["h1", "h2", "h3"] })
    ]);

    New Features

    JSX Runtime

    ultrahtml now comes with h and Fragment functions for JSX, as well as a jsx-runtime export.

    Tranformers

    Transformers are AST transformations that can be applied to any ultrahtml Node. Usually these are applied to entire documents.

    New inline transformer inlines CSS from <style> blocks directly to matching elements.

    New scope transformer scopes CSS from <style> blocks to the elements in a given document or component.

v0.4.0

15 Oct 20:37
3175b32
Compare
Choose a tag to compare

Minor Changes

  • 83c2e35: Improve declarations for node types

v0.3.3

14 Oct 23:41
8944814
Compare
Choose a tag to compare

Patch Changes

  • 3b8fb6e: Remove bundledDependencies field