diff --git a/lib/planner_web.ex b/lib/planner_web.ex
index 4b94e96..bb60531 100644
--- a/lib/planner_web.ex
+++ b/lib/planner_web.ex
@@ -38,6 +38,9 @@ defmodule PlannerWeb do
import Phoenix.Controller, only: [get_flash: 1, get_flash: 2, view_module: 1]
import Phoenix.LiveView.Helpers
+ # Internal View Utils
+ import PlannerWeb.Util
+
# Include shared imports and aliases for views
unquote(view_helpers())
end
diff --git a/lib/planner_web/templates/task/index.html.eex b/lib/planner_web/templates/task/index.html.eex
index 135a8f7..3970948 100644
--- a/lib/planner_web/templates/task/index.html.eex
+++ b/lib/planner_web/templates/task/index.html.eex
@@ -19,7 +19,7 @@
<% end %>
<%= link to: Routes.task_path(@conn, :show, task.id), class: "has-text-black" do %>
- <%= task.value %>
+ <%= md_to_html task.value %>
<% end %>
diff --git a/lib/planner_web/templates/task/show.html.eex b/lib/planner_web/templates/task/show.html.eex
index e156f00..547b111 100644
--- a/lib/planner_web/templates/task/show.html.eex
+++ b/lib/planner_web/templates/task/show.html.eex
@@ -6,9 +6,9 @@
<% end %>
-
- <%= @task.value %>
-
+
+ <%= md_to_html @task.value %>
+
updated: <%= @task.updated_at %>
diff --git a/lib/planner_web/views/util.ex b/lib/planner_web/views/util.ex
new file mode 100644
index 0000000..28e68a9
--- /dev/null
+++ b/lib/planner_web/views/util.ex
@@ -0,0 +1,10 @@
+defmodule PlannerWeb.Util do
+ import Phoenix.HTML
+ alias Earmark.Options
+
+ def md_to_html(md_text) do
+ md_text
+ |> Earmark.as_html!(%Options{smartypants: false})
+ |> raw
+ end
+end
diff --git a/mix.exs b/mix.exs
index be22b76..571bc29 100644
--- a/mix.exs
+++ b/mix.exs
@@ -36,6 +36,7 @@ defmodule Planner.MixProject do
{:bcrypt_elixir, "~> 2.0"},
{:phoenix, "~> 1.5.1"},
{:phoenix_ecto, "~> 4.1"},
+ {:earmark, "~> 1.4.5"},
{:ecto_sql, "~> 3.4"},
{:postgrex, ">= 0.0.0"},
{:phoenix_html, "~> 2.11"},
diff --git a/mix.lock b/mix.lock
index 3ff8eaf..7413638 100644
--- a/mix.lock
+++ b/mix.lock
@@ -6,6 +6,7 @@
"cowlib": {:hex, :cowlib, "2.9.1", "61a6c7c50cf07fdd24b2f45b89500bb93b6686579b069a89f88cb211e1125c78", [:rebar3], [], "hexpm", "e4175dc240a70d996156160891e1c62238ede1729e45740bdd38064dad476170"},
"db_connection": {:hex, :db_connection, "2.2.2", "3bbca41b199e1598245b716248964926303b5d4609ff065125ce98bcd368939e", [:mix], [{:connection, "~> 1.0.2", [hex: :connection, repo: "hexpm", optional: false]}], "hexpm", "642af240d8a8affb93b4ba5a6fcd2bbcbdc327e1a524b825d383711536f8070c"},
"decimal": {:hex, :decimal, "1.8.1", "a4ef3f5f3428bdbc0d35374029ffcf4ede8533536fa79896dd450168d9acdf3c", [:mix], [], "hexpm", "3cb154b00225ac687f6cbd4acc4b7960027c757a5152b369923ead9ddbca7aec"},
+ "earmark": {:hex, :earmark, "1.4.5", "62ffd3bd7722fb7a7b1ecd2419ea0b458c356e7168c1f5d65caf09b4fbdd13c8", [:mix], [], "hexpm", "b7d0e6263d83dc27141a523467799a685965bf8b13b6743413f19a7079843f4f"},
"ecto": {:hex, :ecto, "3.4.4", "a2c881e80dc756d648197ae0d936216c0308370332c5e77a2325a10293eef845", [:mix], [{:decimal, "~> 1.6 or ~> 2.0", [hex: :decimal, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "cc4bd3ad62abc3b21fb629f0f7a3dab23a192fca837d257dd08449fba7373561"},
"ecto_sql": {:hex, :ecto_sql, "3.4.4", "d28bac2d420f708993baed522054870086fd45016a9d09bb2cd521b9c48d32ea", [:mix], [{:db_connection, "~> 2.2", [hex: :db_connection, repo: "hexpm", optional: false]}, {:ecto, "~> 3.4.3", [hex: :ecto, repo: "hexpm", optional: false]}, {:myxql, "~> 0.3.0 or ~> 0.4.0", [hex: :myxql, repo: "hexpm", optional: true]}, {:postgrex, "~> 0.15.0", [hex: :postgrex, repo: "hexpm", optional: true]}, {:tds, "~> 2.1.0", [hex: :tds, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "edb49af715dd72f213b66adfd0f668a43c17ed510b5d9ac7528569b23af57fe8"},
"elixir_make": {:hex, :elixir_make, "0.6.0", "38349f3e29aff4864352084fc736fa7fa0f2995a819a737554f7ebd28b85aaab", [:mix], [], "hexpm", "d522695b93b7f0b4c0fcb2dfe73a6b905b1c301226a5a55cb42e5b14d509e050"},