silverdr

silverdr

Changing default layout in PHX 1.7 / LiveView

In 1.6 one could use something like

pipeline :guest_layout do
	plug :put_layout, {PhxAppWeb.LayoutView, :guest}
end

inside router.ex and then pipe_through it in appropriate scope. That doesn’t seem to work anymore in 1.7? How does one change the app layout these days?

Marked As Solved

codeanpeace

codeanpeace

It looks like the function signature for put_layout/2 has changed from v1.6 to v1.7 such that the second argument now expects a keyword list that includes format :: atom() as the first item in each tuple.

put_layout/2 in v1.6:

@spec put_layout(
  Plug.Conn.t(),
  {atom(), binary() | atom()} | atom() | binary() | false
) ::
  Plug.Conn.t()

conn = put_layout conn, {AppView, "application.html"}
conn = put_layout conn, "print.html"

put_layout/2 in v1.7:

@spec put_layout(
  Plug.Conn.t(),
  [{format :: atom(), layout()}] | false
) ::
  Plug.Conn.t()

conn = put_layout(conn, html: {AppView, :application})
conn = put_layout(conn, html: :print)

Maybe try something like this:

pipeline :guest_layout do
	plug :put_layout, [html: {PhxAppWeb.LayoutView, :guest}]
end

Also Liked

josevalim

josevalim

Creator of Elixir

Excellent replies @codeanpeace.

I have pushed a commit to LiveView that improves its docs: Improve layout docs · phoenixframework/phoenix_live_view@5ef4153 · GitHub

For regular controllers (put_layout) both old and new styles should be supported, this means your code should work @silverdr. Please open up a bug report with reproduction steps if it does not.

codeanpeace

codeanpeace

You could try scopes that pipe through different Router plugs like what @silverdr was doing.

defmodule HelloWeb.Router do
  use HelloWeb, :router

  pipeline :guest_layout do
    plug :put_layout, [html: {HelloWeb.LayoutView, :guest}]
  end

  pipeline :admin_layout do
    plug :put_layout, [html: {HelloWeb.LayoutView, :admin}]
  end

  scope "/guest", HelloWeb do
    pipe_through [:guest_layout]
    live "/feed", HelloWeb.FeedLive, :index
    live "/status", HelloWeb.StatusLive, :index
    live "/status/:id", HelloWeb.StatusLive, :show
  end
  
  scope "/admin", HelloWeb do
    pipe_through [:admin_layout]
    live "/admin", HelloWeb.AdminDashboardLive, :index
    live "/admin/posts", HelloWeb.AdminPostLive, :index
  end
end

Poking around the LiveView docs, I see there’s also a live_session/3 function for grouping together live routes into a session for live redirects which happens to accept an optional layout in the form of “a tuple with the view module and template string or atom name”.

defmodule HelloWeb.Router do
  use HelloWeb, :router

  live_session :guest, layout: {HelloWeb.LayoutView, :guest} do
    live "/feed", HelloWeb.FeedLive, :index
    live "/status", HelloWeb.StatusLive, :index
    live "/status/:id", HelloWeb.StatusLive, :show
  end

  live_session :admin, layout: {HelloWeb.LayoutView, :admin} do
    live "/admin", HelloWeb.AdminDashboardLive, :index
    live "/admin/posts", HelloWeb.AdminPostLive, :index
  end
end
silverdr

silverdr

It was a combination of factors that caused some confusion. Actually the original style works. The reason for it not working was elsewhere but since LS reported that Function guest_layout/2 has no local return it looked like the old style no longer working. When I change to the new style though, the Dialyzer warning disappears, but… the pipeline becomes ineffective. IOW - this:

	pipeline :guest_layout do
		plug :put_layout, {PhxAppWeb.LayoutView, :guest}
	end

works despite the warning being emitted, while changing it to:

	pipeline :guest_layout do
		plug :put_layout, [html: {PhxAppWeb.LayoutView, :guest}]
	end

makes the warning go away together with the functionality of changing the layout. Any clues? The layout and view is a DeadView if this makes any difference.

Where Next?

Popular in Questions Top

Kurisu
For example for a current url like http://localhost:4000/cosmetic/products?_utf8=✓&query=perfume&page=2, I would like to get: ...
New
shahryarjb
Hello, I get Persian date from my client and convert it to normal calendar like this: def jalali_string_to_miladi_english_number(persi...
New
senggen
Erlang/OTP 25 [erts-13.2.2] [source] [64-bit] [smp:8:8] [ds:8:8:10] [async-threads:1] 15:22:35.803 [error] gen_event {lager_file_backend...
New
dokuzbir
I want to highlight html closing tags when i click a html tag. That works in .html files but doesnt work for html.eex templates. How can...
New
JeremM34
Hello, how can I check the Phoenix version ? Thanks !
New
Emily
I have VueJS GUIs with the project generated using Webpack. I have Elixir modules that will need to be used by the VueJS GUIs. I forese...
New
freewebwithme
Using vs code and installed ElixirLS: support and debugger. And I got an error popped up on start up says Failed to run ‘elixir’ comma...
New
nobody
Hi! In PHP: $_SERVER[‘SERVER_ADDR’] - in Elixir? Searched the docs for ip address and the web, no good results. Thanks!
New
Brian
What is the proper way to load a module from a file in to IEX? In the python world, doing something like this pretty standard: from ....
New
vonH
In asking this question I am more interested about the expressiveness of the language itself and less concerned about the availability of...
New

Other popular topics Top

lastday4you
I wanted to check elixir version in phoenix because i found that my elixir is 1.5 but when i use Enum.chunk_by it said the function is un...
New
greenz1
I have a phoenix application from which a user can download multiple(5-6) files of size 1MB. I couldn’t find anything related to sending ...
New
Patoshizzle
After calling mix ecto.create I get this error: 17:00:32.162 [error] GenServer #PID<0.412.0> terminating ** (Postgrex.Error) FATAL...
New
JeremM34
Hello, how can I check the Phoenix version ? Thanks !
New
shahryarjb
Hello, I have map which I want to convert it to string like this: the map: %{last_name: "tavakkoli", name: "shahryar"} the string I ne...
New
gausby
I asked this very same question on twitter and got some interesting feedback, but I thought it would be a good question to ask here as we...
1207 39297 209
New
AstonJ
We’ve put together this wiki for Phoenix LiveView - please feel free to add any info you feel is worth including. What is Phoenix LiveV...
New
klo
Got a question about when to concat vs. prepending items to list then reversing to achieve appending. So i know lists boil down to [1 | ...
New
hariharasudhan94
I would like to know what is the best IDE for elixir development?
New
openscript
Hello! Sorry for this astonishing simple question, but I’m really stuck. I try to set up the intellij-elixir plugin, but I don’t know ho...
New

We're in Beta

About us Mission Statement