stage | start-date | release-date | release-versions | teams | prs | project-link | |||||
---|---|---|---|---|---|---|---|---|---|---|---|
released |
2020-12-22 00:00:00 UTC |
2021-03-22 00:00:00 UTC |
|
|
|
Deprecate the {{hasBlock}}
and {{hasBlockParams}}
properties in templates in
favor of the {{has-block}}
and {{has-block-params}}
keywords.
{{hasBlock}}
is a way to check if component has a default block provided to
it, and {{hasBlockParams}}
is a way to check if that default block has block
parameters. They are effectively aliases for calling {{has-block}}
and
{{has-block-params}}
respectively, without providing a block name or with the
block name "default"
. They are also not called, and acts like a template
fallback lookup instead.
Having two ways of accomplishing this task is confusing, and with the property
form it is not possible to check if other blocks exist, such as named blocks. As
such, this RFC proposes that we deprecate {{hasBlock}}
and
{{hasBlockParams}}
and recommend that users switch to using {{has-block}}
and {{has-block-params}}
.
Users who are currently using {{hasBlock}}
or {{hasBlockParams}}
will need
to replace all of their usages with {{has-block}}
/{{has-block-params}}
respectively. This is generally a very codemoddable change, so it should be
pretty straightforward to accomplish, and we will attempt to make a codemod to
help out with the transition.
Currently, {{hasBlock}}
and {{hasBlockParams}}
are documented in the API docs,
but {{has-block}}
and {{has-block-params}}
are not. The new keywords should
be thoroughly documented.
The {{hasBlock}}
property is true if the component was given a default block,
and false otherwise. To transition away from it, you can use the (has-block)
helper instead.
Unlike {{hasBlock}}
, the (has-block)
helper must be called, so in nested
positions you will need to add parentheses around it:
You may optionally pass a name to (has-block)
, the name of the block to check.
The name corresponding to the block that {{hasBlock}}
represents is "default".
Calling (has-block)
without any arguments is equivalent to calling
(has-block "default")
.
The {{hasBlockParams}}
property is true if the component was given a default block,
and false otherwise. To transition away from it, you can use the (has-block-params)
helper instead.
Unlike {{hasBlockParams}}
, the (has-block-params)
helper must be called, so in nested
positions you will need to add parentheses around it:
You may optionally pass a name to (has-block-params)
, the name of the block to check.
The name corresponding to the block that {{hasBlockParams}}
represents is "default".
Calling (has-block-params)
without any arguments is equivalent to calling
(has-block-params "default")
.
-
Introduces some churn.
-
(has-block)
is dasherized, which is not inline with the future of strict mode and template imports. Dasherized strings are not valid identifiers in JavaScript, so helpers and modifiers will likely switch to camel case when that transition occurs.This actually makes this deprecation even more valuable. As it stands, even if we wanted to use
{{hasBlock "name"}}
in templates, we could not, since{{hasBlock}}
already has semantics and is not callable. By deprecating this syntax, we can reclaim it in the future as a possible alias for the dasherized version.
- Keep the existing syntax as an alias for
(has-block)
/(has-block-params)
.