Skip to content

Releases: stephannv/blueprint

v1.0.0

25 Jan 14:36
dcadb6b
Compare
Choose a tag to compare

New versioning strategy

Blueprint don't follow semantic versioning (SemVer). Instead, it will follow something like BreakVer or PrideVer.

  • Major: Big changes and/or big features
  • Minor: Small changes that can break old code but the effort to fix it is minimal
  • Patch: Non-breaking changes

Performance Improvement

Blueprint::HTML 0.11.0

Blueprint::HTML 0.11.0 755.39k (  1.32µs) (± 0.80%)  2.69kB/op   6.75× slower
                   ECR   5.10M (196.14ns) (± 0.51%)  1.51kB/op        fastest

Blueprint::HTML 1.0.0

Blueprint::HTML 0.11.0 934.07k (  1.07µs) (± 0.51%)  2.69kB/op   5.45× slower
                   ECR   5.09M (196.31ns) (± 0.37%)  1.51kB/op        fastest

#render accepts new argument types

Now it's possible to render many types with render:

# Blueprint classes
render Card # same as `render Card.new`

# Procs
render -> { 1 + 2 }

# Strings
render "hello"

# Any object that responds to_s
render MyObject.new

Breaking changes!

Rename #envelope to #around_render

The #envelope method was renamed to #around_render:
Old:

class Layout
  include Blueprint::HTML

  def envelope(&)
    html do
      body { yield }
    end
  end
end

New:

class Layout
  include Blueprint::HTML

  def around_render(&)
    html do
      body { yield }
    end
  end
end

Restrict #plain argument type

Before you could pass anything to #plain, now it accepts only String. You
can use #render to render other type of objects.

# before
plain some_object

# now
render some_object

Remove capability to pass element content via argument.

Before you could write:

h1 "Hello"
# Or
h1 { "Hello" }

Now the content are passed only via block:

h1 { "Hello" }

Remove Form builder

Form builder was removed from Blueprint core. It's possible that will become a
separate shard. You are using form builder, you extract the code from
here.

Remove Style variants

Style variants was removed from Blueprint core. It's possible that will become a
separate shard. You are using style variants, you extract the code from
here.

Remove component registrar

The register_component macro was removed from Blueprint core. If you are
using this macro, you extract the code from
here

Remove #tokens

The #tokens method was removed. You can replace it with plain Crystal:

# with #tokens method
div class: tokens("x", admin?: "is-admin")

# with plain crystal
div class: ["x", ("is-admin" if admin?)]

If you need, yout can get the #tokens code from
here.

v0.11.0

14 Oct 17:01
3ae768b
Compare
Choose a tag to compare

What's Changed

Add escape_once helper

It escapes HTML without affecting existing escaped entities

class ExamplePage
  include Blueprint::HTML

  def blueprint
    plain escape_once("1 < 2 &amp; 3")

    span escape_once("&lt;&lt; Accept & Checkout")

    span { escape_once("<script>alert('content')</script>") }
  end
end

puts ExamplePage.new.to_s

Output:

1 &lt; 2 &amp; 3

<span>&lt;&lt; Accept &amp; Checkout</span>

<span>&lt;script&gt;alert(&#39;content&#39;)&lt;/script&gt;</span>

Change attribute value escaper

Before attribute values were escaped using HTML.escape, now the escape is done using .gsub('"', "&quot;").

class ExamplePage
  include Blueprint::HTML

  def blueprint
    input(value: %(>'test'<">))
    # Before <input value="&gt;&#39;test&#39;&lt;&quot;&gt;">
    # After <input value=">'test'<&quot;>">
  end
end

Full Changelog: v0.10.0...v0.11.0

v0.10.0

11 Oct 14:25
ba01afa
Compare
Choose a tag to compare

What's Changed

  • feat: Loose #plain/#comment argument type by @stephannv in #78
    Now you can pass any object that responds to_s to #plain/#comment methods.
class ExamplePage
  include Blueprint::HTML

  def blueprint
    # before:
    plain custom_object.to_s
    comment other_object.to_s

    # after:
    plain custom_object
    comment other_object
  end
end

Full Changelog: v0.9.0...v0.10.0

v0.9.0 - Form Builder

21 Sep 13:29
3cbbb17
Compare
Choose a tag to compare

Using #form_builder you can access some utility methods to build labels and inputs:

class ExamplePage
  include Blueprint::HTML

  def blueprint
    form_builder action: "/sign-in", method: :post do |form|
      form.label :email
      form.email_input :email

      form.label :password
      form.password_input :password
    end
  end
end

puts ExamplePage.new.to_s
# <form action="/sign-in" method="post">
#   <label for="email">Email</label>
#   <input type="email" id="email" name="email">
#
#   <label for="password">Password</label>
#   <input type="password" id="password" name="password">
# </form>

More examples at docs: https://stephannv.github.io/blueprint-docs/handbook/forms/

New docs, style builder, tokens, safe rendering and breaking changes

14 Sep 18:17
c9e86bf
Compare
Choose a tag to compare

Overhauled docs

The Blueprint Docs was revised.

Style Variants (Experimental)

Simplify the management of CSS class combinations:

class AlertComponent
  include Blueprint::HTML

  style_builder do
    base "alert"

    variants do
      type {
        info "alert-info"
        danger "alert-danger"
      }

      size {
        xs "text-xs p-2"
        md "text-md p-4"
        lg "text-lg p-6"
      }

      closable {
        yes "alert-closable"
      }

      special {
        yes "alert-special"
        no "alert-default"
      }
    end

    defaults type: :info, size: :md
  end

  def blueprint
    div(class: build_style(type: :danger, size: :lg, closable: true)) do
      "My styled alert component"
    end
  end
end

puts AlertComponent.build_style(type: :info, size: :xs, special: false)
# "alert alert-info text-xs p-2 alert-default"

puts AlertComponent.new.to_s
# <div class="alert alert-danger text-lg p-6 alert-closable">
#  My styled alert component
# </div>

Tokens (Experimental)

Allows to build classes based on conditionals.

class UserComponent
  include Blueprint::HTML

  def blueprint
    h1 class: tokens(admin?: "is-admin", moderator?: "is-moderator") do
      "Jane Doe"
    end
  end

  def admin?
    false
  end

  def moderator?
    true
  end
end

puts UserComponent.new.to_s

# <h1 class="is-moderator">
#   Jane Doe
# </h1>

Add #safe helper

The #safe method wraps the given object in a Blueprint::SafeValue, indicating to Blueprint that the content should be rendered without escaping.

BREAKING: Change #to_html to #to_s

Instead of MyComponent.new.to_html you should use MyComponent.new.to_s.

BREAKING: Remove some utils methods

The methods #plain(&) and #comment(&) were removed, but you still can use the #plain(content : String) and #comment(content : String).

BREAKING: Remove #unsafe_raw

#unsafe_raw was removed in favor of #raw.

# BEFORE
unsafe_raw "<script>My Script</script>"

# AFTER
raw safe("<script>My Script</script>")

BREAKING: Remove Blueprint::RawHTML

The Blueprint::RawHTML included in 0.7.0 was removed. A module focused on performance will be planned in the future.

Include Blueprint::HTML::ComponenentRegistrar by default

You don't need to require and include Blueprint::HTML::ComponenentRegistrar, it is already included when you include Blueprint::HTML.

v0.7.0

09 Sep 20:39
Compare
Choose a tag to compare

What's Changed

  • Allow passing comment via argument
comment "Cool comment here"
  • Allow rendering unsafe content using unsafe_raw
unsafe_raw "<script>alert('Danger!')</script>"
  • Add RawHtml to priorize performance over safety
require "blueprint/raw_html"

class MyHTML
  include Blueprint::RawHTML

  def blueprint
    div "<script>alert('Danger!')</script>" # this will not be escaped
  end
end
  • Code refactoring to improve performance
  • Fix safety when passing content to elements via argument

Full Changelog: v0.6.0...v0.7.0

v0.6.0

08 Sep 21:44
8c87877
Compare
Choose a tag to compare

What's Changed

  • feat: Allow passing element content without using block by @stephannv in #53
h1 { "Hello World!" }
# or just
h1 "Hello World!"

Full Changelog: v0.5.1...v0.6.0

v0.5.1

08 Sep 20:57
Compare
Choose a tag to compare

Fix Crystal version string requirement.

Full Changelog: v0.5.0...v0.5.1

v0.5.0

08 Sep 20:24
997fefd
Compare
Choose a tag to compare

What's Changed

Performance improvements: Increased speed execution by 15%.

v0.5.0 364.46k (  2.74µs) (± 0.52%)  7.95kB/op  fastest
v0.4.0 317.83k (  3.15µs) (± 0.76%)  8.99kB/op  1.15× slower
  • fix: Ignore nil elements from array attribute parsing by @stephannv in #48
  • perf: Use String::Builder to improve render times by @stephannv in #51

Full Changelog: v0.4.0...v0.5.0

v0.4.0 - SVG support

25 Apr 20:57
7efdac6
Compare
Choose a tag to compare
v0.4.0 - SVG support Pre-release
Pre-release

Full details: https://blueprint.gunbolt.org/changelogs/v0.4.0/

What's Changed

Full Changelog: v0.3.0...v0.4.0