diff options
author | miraikumiko <miraikumiko@disroot.org> | 2025-04-21 10:26:21 +0200 |
---|---|---|
committer | miraikumiko <miraikumiko@disroot.org> | 2025-04-21 10:26:21 +0200 |
commit | fb01bbb290d37f491d603bdf015d994a39e153c7 (patch) | |
tree | fb60b98e20ae6896b08fc46fda6643d36a8a8b34 /lib/nulla_web.ex | |
download | nulla-fb01bbb290d37f491d603bdf015d994a39e153c7.tar.gz nulla-fb01bbb290d37f491d603bdf015d994a39e153c7.tar.bz2 |
Init
Diffstat (limited to 'lib/nulla_web.ex')
-rw-r--r-- | lib/nulla_web.ex | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/lib/nulla_web.ex b/lib/nulla_web.ex new file mode 100644 index 0000000..862aea6 --- /dev/null +++ b/lib/nulla_web.ex @@ -0,0 +1,116 @@ +defmodule NullaWeb do + @moduledoc """ + The entrypoint for defining your web interface, such + as controllers, components, channels, and so on. + + This can be used in your application as: + + use NullaWeb, :controller + use NullaWeb, :html + + The definitions below will be executed for every controller, + component, etc, so keep them short and clean, focused + on imports, uses and aliases. + + Do NOT define functions inside the quoted expressions + below. Instead, define additional modules and import + those modules here. + """ + + def static_paths, do: ~w(assets fonts images favicon.ico robots.txt) + + def router do + quote do + use Phoenix.Router, helpers: false + + # Import common connection and controller functions to use in pipelines + import Plug.Conn + import Phoenix.Controller + import Phoenix.LiveView.Router + end + end + + def channel do + quote do + use Phoenix.Channel + end + end + + def controller do + quote do + use Phoenix.Controller, + formats: [:html, :json], + layouts: [html: NullaWeb.Layouts] + + use Gettext, backend: NullaWeb.Gettext + + import Plug.Conn + + unquote(verified_routes()) + end + end + + def live_view do + quote do + use Phoenix.LiveView, + layout: {NullaWeb.Layouts, :app} + + unquote(html_helpers()) + end + end + + def live_component do + quote do + use Phoenix.LiveComponent + + unquote(html_helpers()) + end + end + + def html do + quote do + use Phoenix.Component + + # Import convenience functions from controllers + import Phoenix.Controller, + only: [get_csrf_token: 0, view_module: 1, view_template: 1] + + # Include general helpers for rendering HTML + unquote(html_helpers()) + end + end + + defp html_helpers do + quote do + # Translation + use Gettext, backend: NullaWeb.Gettext + + # HTML escaping functionality + import Phoenix.HTML + # Core UI components + import NullaWeb.CoreComponents + + # Shortcut for generating JS commands + alias Phoenix.LiveView.JS + + # Routes generation with the ~p sigil + unquote(verified_routes()) + end + end + + def verified_routes do + quote do + use Phoenix.VerifiedRoutes, + endpoint: NullaWeb.Endpoint, + router: NullaWeb.Router, + statics: NullaWeb.static_paths() + end + end + + @doc """ + When used, dispatch to the appropriate controller/live_view/etc. + """ + defmacro __using__(which) when is_atom(which) do + apply(__MODULE__, which, []) + end +end |