Surface and heex

With Phoenix 1.6 out recently – and me having a nice side dish of Surface – I reckoned that it was time to test the water once more…and soon enough I had the first question:

Am I correct to understand that Surface components are not ready for .heex yet?

I should elaborate:

Did the getting started stuff - mix phx.new --live - adding the surface dependency, got puzzled by the lack of mentioning import surface on Surface compared to Surface — surface v0.5.2, decided to throw it in there for good measure uncertain what it would bring though, then started on my virgin component,

defmodule Sp31ch3rWeb.Components.Button do

  use Surface.Component

  def render(assigns) do 
    ~F"""
      <button> test </button>
   """
  end
end

only to be very disappointed when I added my “revolutionary” component to my form_component.html.heex (autogenerated by mix phx.gen.live Events Call calls subject:string... ) and had ElixrLS read me the motd

(Phoenix.LiveView.HTMLTokenizer.ParseError) invalid tag <Button>

Ups - forgot to tell form_component.ex that I was into some sorcery sh*t - better fix that

defmodule Sp31ch3rWeb.CallLive.FormComponent do
  use Sp31ch3rWeb, :live_component

  alias Sp31ch3r.Events
  alias Sp31ch3rWeb.Components.Button
....
end

Nope - still an invalid tag -that ‘’ thing of mine :cry:

Did I skip on "the mix" ?

  def project do
      ...
      compilers: [:gettext] ++ Mix.compilers() ++ [:surface],
      ...
  end

  defp deps do
      ...
      {:surface, "~> 0.5.2"},
      {:surface_formatter, "~> 0.5.0"},
      {:surface_markdown, "~> 0.2.0"},
      ...
  end

Hmmm - then I hurried down another “rabbit hole” - make the existing/working LiveViews SurfaceViews instead!

  # lib/sp31ch3r_web.ex
  def live_component do
    quote do
      # use Phoenix.LiveComponent
      use Surface.LiveComponent

      unquote(view_helpers())
    end
  end

  #live/call_live/form_component.ex
defmodule Sp31ch3rWeb.CallLive.FormComponent do
  use Sp31ch3rWeb, :live_component

  alias Sp31ch3r.Events
  alias Sp31ch3rWeb.Components.Button
  alias Surface.Components.Form

   ...
<div>
  <h2>{@title}</h2>

  <Button/>
  <Form
    for={@changeset}
    id="call-form"
 

Nahh - the motd changed - but there’s still a motd :laughing:

== Compilation error in file lib/sp31ch3r_web/live/call_live/form_component.ex ==
sp31ch3r_app  | ** (Surface.Compiler.ParseError) lib/sp31ch3r_web/live/call_live/form_component.sface:2:9: expected attribute name

which finally left me with a sense of digging my self in over my head - braking everything apart cannot possibly be what Marius’ epiphany is all about?!

Think what I’m actually saying - after some -tube’n and googl’n - is: a mix phx.gen.surface just might go ahead and make my day :laughing:

I think you will find some answers in another thread starting from this post 166

1 Like

Thank you @odix67 that I did indeed!