freedive/lib/liliform/media.ex

84 lines
1.5 KiB
Elixir
Raw Normal View History

2024-05-14 21:58:42 +02:00
defmodule Liliform.Media do
use Liliform.Component
@doc """
Renders a media object.
"""
attr :class, :string, default: "", doc: "additional classes"
attr :rest, :global
slot :inner_block, required: true
def media(assigns) do
assigns =
assigns
|> set_bulma_classes()
~H"""
<article class={["media", @class]} {@rest}>
<%= render_slot(@inner_block) %>
</article>
"""
end
@doc """
Renders a media-left.
"""
attr :class, :string, default: "", doc: "additional classes"
2024-05-14 21:58:42 +02:00
attr :rest, :global
slot :inner_block, required: true
def media_left(assigns) do
assigns =
assigns
|> set_bulma_classes()
~H"""
<figure class={["media-left", @class]} {@rest}>
2024-05-14 21:58:42 +02:00
<%= render_slot(@inner_block) %>
</figure>
"""
end
@doc """
Renders a media-content.
"""
attr :class, :string, default: "", doc: "additional classes"
2024-05-14 21:58:42 +02:00
attr :rest, :global
slot :inner_block, required: true
def media_content(assigns) do
assigns =
assigns
|> set_bulma_classes()
~H"""
<div class={["media-content", @class]} {@rest}>
2024-05-14 21:58:42 +02:00
<%= render_slot(@inner_block) %>
</div>
"""
end
@doc """
Renders a media-right.
"""
attr :class, :string, default: "", doc: "additional classes"
2024-05-14 21:58:42 +02:00
attr :rest, :global
slot :inner_block, required: true
def media_right(assigns) do
assigns =
assigns
|> set_bulma_classes()
~H"""
<div class={["media-right", @class]} {@rest}>
2024-05-14 21:58:42 +02:00
<%= render_slot(@inner_block) %>
</div>
"""
end
end