Releases: stephannv/blueprint
v1.0.0
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
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 & 3")
span escape_once("<< Accept & Checkout")
span { escape_once("<script>alert('content')</script>") }
end
end
puts ExamplePage.new.to_s
Output:
1 < 2 & 3
<span><< Accept & Checkout</span>
<span><script>alert('content')</script></span>
Change attribute value escaper
Before attribute values were escaped using HTML.escape
, now the escape is done using .gsub('"', """)
.
class ExamplePage
include Blueprint::HTML
def blueprint
input(value: %(>'test'<">))
# Before <input value=">'test'<">">
# After <input value=">'test'<">">
end
end
Full Changelog: v0.10.0...v0.11.0
v0.10.0
What's Changed
- feat: Loose #plain/#comment argument type by @stephannv in #78
Now you can pass any object that respondsto_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
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
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
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
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
Fix Crystal version string requirement.
Full Changelog: v0.5.0...v0.5.1
v0.5.0
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
Full details: https://blueprint.gunbolt.org/changelogs/v0.4.0/
What's Changed
- feat: Support SVG rendering by @stephannv in #42
Full Changelog: v0.3.0...v0.4.0