46 lines
1.1 KiB
Elixir
46 lines
1.1 KiB
Elixir
defmodule OutlookWeb.HtmlDocComponent do
|
|
|
|
use Phoenix.Component
|
|
# use OutlookWeb, :html
|
|
import OutlookWeb.CoreComponents
|
|
import Phoenix.HTML
|
|
|
|
alias Phoenix.LiveView.JS
|
|
|
|
attr :tree, :list, required: true
|
|
|
|
def render_doc(assigns) do
|
|
~H"""
|
|
<%= for node <- @tree do %>
|
|
<.dnode node={node} />
|
|
<% end %>
|
|
"""
|
|
end
|
|
|
|
def dnode(%{node: %{status: status}} = assigns) do
|
|
~H"""
|
|
<.dynamic_tag name="span" class="tunit" nid={@node.nid} {Map.get(@node.eph, :attributes, %{})}>
|
|
<%= @node.content |> raw %>
|
|
</.dynamic_tag>
|
|
"""
|
|
end
|
|
|
|
def dnode(assigns) when assigns.node.type == :element do
|
|
~H"""
|
|
<.dynamic_tag name={@node.name} nid={@node.nid} {Map.get(@node.eph, :attributes, %{})}>
|
|
<%= for child_node <- @node.content do %>
|
|
<.dnode node={child_node} />
|
|
<% end %>
|
|
</.dynamic_tag>
|
|
"""
|
|
end
|
|
|
|
def dnode(assigns) when assigns.node.type == :text do
|
|
~H"<%= @node.content %>"
|
|
end
|
|
|
|
def dnode(assigns) when assigns.node.type == :comment do
|
|
~H"<!--<%= @node.content |> raw %>-->"
|
|
end
|
|
end
|