Most of the new features and requirements for v1.7 are optional and many folks will simpy be able to bump their mix.exs
version and compile without issue, though a few warnings will be reported.
Before upgrading Phoenix itself to v1.7, we recommend first updating some Phoenix dependencies in mix.exs
: phoenix_view
(add it if missing), phoenix_live_view
(if you were explictly using LiveView before), and phoenix_live_dashboard
.
def deps do
[
{:phoenix_view, "~> 2.0"},
{:phoenix_live_view, "~> 0.18.18"},
{:phoenix_live_dashboard, "~> 0.7.2"},
...
]
end
If you are currently using Phoenix LiveView v0.17 or earlier, please read and follow the LiveView CHANGELOG before continuing.
With dependencies updated, updating to Phoenix v1.7 should be as simple as bumping its requirement:
def deps do
[
{:phoenix, "~> 1.7.0"},
...
]
end
These are longer necessary on Elixir v1.11+:
def project do
[
- compilers: [:phoenix, :gettext] ++ Mix.compilers(),
]
end
To support the latest Phoenix.LiveView HTML formatter and declarative assigns macros, update your .formatter.exs
as follows with the Phoenix.LiveView.HTMLFormatter
plugin:
[
import_deps: [:ecto, :ecto_sql, :phoenix],
subdirectories: ["priv/*/migrations"],
plugins: [Phoenix.LiveView.HTMLFormatter],
inputs: ["*.{heex,ex,exs}", "{config,lib,test}/**/*.{heex,ex,exs}", "priv/*/seeds.exs"]
]
The remaining updates are optional and only necessary if you intend to make use of the new verified routes, or phx.gen.html|live|auth
generators in an existing application. The generators follow new conventions and make use of the new function component approach to building templates. While these changes are a big step forward for new applications, it probably makes sense to maintain your current application conventions and skip these steps for established, large 1.6 applications.
While not a hard requirement, Elixir v1.14.0 provides new compiler features to support proper warnings for the new Phoenix.VerifiedRoutes
feature as well as Phoenix LiveView 0.18's new declarative assigns.
You can read more about verified routes here
Add the following lines to your lib/app_web.ex
:
+ def static_paths, do: ~w(assets fonts images favicon.ico robots.txt)
def controller do
quote do
use Phoenix.Controller, namespace: DemoWeb
import Plug.Conn
import DemoWeb.Gettext
+ unquote(verified_routes())
end
end
defp view_helpers do
quote do
...
+ unquote(verified_routes())
end
end
+ def verified_routes do
+ quote do
+ use Phoenix.VerifiedRoutes,
+ endpoint: DemoWeb.Endpoint,
+ router: DemoWeb.Router,
+ statics: DemoWeb.static_paths()
+ end
+ end
Next, update your lib/app_web/endpoint.ex
's Plug.Static
to reference the static_paths
function:
plug Plug.Static,
at: "/",
from: :app,
gzip: false,
- only: ~w(assets fonts images favicon.ico robots.txt)
+ only: AppWeb.static_paths()
Lastly, update your test/support/conn_case.ex
to use verified routes:
using do
quote do
# The default endpoint for testing
@endpoint DemoWeb.Endpoint
+ use AppWeb, :verified_routes
# Import conveniences for testing with connections
import Plug.Conn
import Phoenix.ConnTest
import AppWeb.ConnCase
end
end
You're now set up to use ~p
throughout your web and test stack. Enjoy!
Phoenix v1.6 used Phoenix.View to render templates, Phoenix v1.7 defaults to Phoenix.Component. Phoenix.View is not deprecated and it is still supported. Old applications can depend on it as they prefer. However, if you want to migrate to Phoenix.Component, we have written helpful steps in the Phoenix.View documentation.
@TamLyNhat this happens because one of your non-Hex dependencies (such as a git dependency or an umbrella application) has a conflicting requirement on Phoenix, in a way that Hex (the package manager) only sees an empty set of available Phoenix packages. Check the
:fun_app
in your umbrella and see if it depends on Phoenix and make sure to bump it there too.Also, consider using ElixirForum for questions, the response time of the community there is likely quicker.