204 lines
4.2 KiB
Markdown
204 lines
4.2 KiB
Markdown
# CHANGELOG
|
|
|
|
## Main
|
|
|
|
Nothing Yet
|
|
|
|
## 0.6.0-rc.0
|
|
|
|
- Can pass a keyword list to be evaluated at runtime as attrs/assigns to an element.
|
|
|
|
```elixir
|
|
# compile time
|
|
|
|
div class: "foo", id: bar do
|
|
# something
|
|
end
|
|
|
|
# <div class="foo" id="<%= bar %>">
|
|
# <!-- something -->
|
|
# </div>
|
|
|
|
# runtime
|
|
|
|
div some_var do
|
|
# something
|
|
end
|
|
|
|
# <div<%= PrivateTempleModule.runtime_attrs(some_var) %>>
|
|
# <!-- something -->
|
|
# </div>
|
|
```
|
|
|
|
- it now parses `case` expressions
|
|
|
|
### Breaking
|
|
|
|
#### Components
|
|
|
|
Components are now a thin layer over template partials, compiling to calls to `render/3` and `render_layout/4` under the hood.
|
|
|
|
To upgrade your components the new syntax, you can copy your component markup and paste it into the `render/1` macro inside the component module and references to `@children` can be updated to `@inner_content`.
|
|
|
|
Components can are also referenced differently than before when using them. Before, one would simply call `flex` to render a component named `Flex`. Now, one must use the keyword `c` to render a component, passing the keyword the component module along with any assigns.
|
|
|
|
##### Before
|
|
|
|
```elixir
|
|
# definition
|
|
div class: "flex #{@class}" do
|
|
@children
|
|
end
|
|
|
|
# usage
|
|
|
|
flex class: "justify-between" do
|
|
for item <- @items do
|
|
div do
|
|
item.name
|
|
end
|
|
end
|
|
end
|
|
```
|
|
|
|
##### After
|
|
|
|
```elixir
|
|
# definition
|
|
defmodule MyAppWeb.Component.Flex do
|
|
use Temple.Component
|
|
|
|
render do
|
|
div class: "flex #{@class}" do
|
|
@inner_content
|
|
end
|
|
end
|
|
end
|
|
|
|
# usage
|
|
alias MyApp.Component.Flex # probably located in my_app_web.ex
|
|
|
|
c Flex, class: "justify-between" do
|
|
for item <- @items do
|
|
div do
|
|
item.name
|
|
end
|
|
end
|
|
end
|
|
```
|
|
|
|
### Bugs
|
|
|
|
- Did not correctly parse expressions with do blocks where the expression had two or more arguments before the block
|
|
|
|
## 0.6.0-alpha.4
|
|
|
|
- Fix a bug where lists would not properly compile
|
|
|
|
## 0.6.0-alpha.3
|
|
|
|
- Compile functions/macros that take blocks that are not if/unless/for
|
|
|
|
## 0.6.0-alpha.2
|
|
|
|
### Component API
|
|
|
|
Please see the README for more details regarding the Component API
|
|
|
|
## 0.6.0-alpha.1
|
|
|
|
### Generators
|
|
|
|
You can now use `mix temple.gen.live Context Schema table_name col:type` in the same way you can with Phoenix.
|
|
|
|
### Other
|
|
|
|
- Make a note in the README to set the filetype for Live temple templates to `lexs`. You should be able to set this extension to use Elixir for syntax highlighting in your editor. In vim, you can add the following to your `.vimrc`
|
|
|
|
```vim
|
|
augroup elixir
|
|
autocmd!
|
|
|
|
autocmd BufRead,BufNewFile *.lexs set filetype=elixir
|
|
augroup END
|
|
```
|
|
|
|
## 0.6.0-alpha.0
|
|
|
|
### Breaking!
|
|
|
|
This version is the start of a complete rewrite of Temple.
|
|
|
|
- Compiles to EEx at build time.
|
|
- Compatible with `Phoenix.LiveView`
|
|
- All modules other than `Temple` are removed
|
|
- `mix temple.convert` Mix task removed
|
|
|
|
## 0.5.0
|
|
|
|
- Introduce `@assigns` assign
|
|
- Join markup with a newline instead of empty string
|
|
|
|
## 0.4.4
|
|
|
|
- Removes unnecessary plug dependency.
|
|
- Bumps some other dependencies.
|
|
|
|
## 0.4.3
|
|
|
|
- Compiles when Phoenix is not included in the host application.
|
|
|
|
## 0.4.2
|
|
|
|
- temple.convert task no longer fails when parsing HTML fragments.
|
|
|
|
## 0.4.1
|
|
|
|
- Only use Floki in dev and test environments
|
|
|
|
## 0.4.0
|
|
|
|
- `Temple.Svg` module
|
|
- `mix temple.convert` Mix task
|
|
- (dev) rename `mix update_mdn_docs` to `mix temple.update_mdn_docs` and don't ship it to hex
|
|
|
|
### Breaking
|
|
|
|
- Rename `Temple.Tags` to `Temple.Html`
|
|
|
|
## v0.3.1
|
|
|
|
- `Temple.Form.phx_label`, `Temple.Form.submit`, `Temple.Link.phx_button`, `Temple.Link.phx_link` now correctly parse blocks. Before this, they would escape anything passed to the block instead of accepting it as raw HTML.
|
|
|
|
## v0.3.0
|
|
|
|
- `Temple.Tags.html` now prepends the doctype, making it valid HTML
|
|
- `Temple.Elements` module
|
|
|
|
### Breaking
|
|
|
|
- `Temple.Tags.html` no longer accepts content as the first argument. A legal `html` tag must contain only a single `head` and a single `body`.
|
|
|
|
## 0.2.0
|
|
|
|
- Wrap `radio_buttton/4` from Phoenix.HTML.Form
|
|
|
|
## 0.1.2
|
|
|
|
### Bugfixes
|
|
|
|
- Allow components to be used correctly when their module was `require`d instead of `import`ed
|
|
|
|
## 0.1.1
|
|
|
|
### Bugfixes
|
|
|
|
- Escape content passed to 1-arity tag macros
|
|
|
|
### Development
|
|
|
|
- Upgrade various optional development packages
|
|
|
|
## 0.1.0
|
|
|
|
- Initial Release
|