aboutsummaryrefslogtreecommitdiff
path: root/shardweb/lib/shard_web.ex
diff options
context:
space:
mode:
Diffstat (limited to 'shardweb/lib/shard_web.ex')
-rw-r--r--shardweb/lib/shard_web.ex67
1 files changed, 67 insertions, 0 deletions
diff --git a/shardweb/lib/shard_web.ex b/shardweb/lib/shard_web.ex
new file mode 100644
index 0000000..5192806
--- /dev/null
+++ b/shardweb/lib/shard_web.ex
@@ -0,0 +1,67 @@
+defmodule ShardWeb do
+ @moduledoc """
+ The entrypoint for defining your web interface, such
+ as controllers, views, channels and so on.
+
+ This can be used in your application as:
+
+ use ShardWeb, :controller
+ use ShardWeb, :view
+
+ The definitions below will be executed for every view,
+ controller, etc, so keep them short and clean, focused
+ on imports, uses and aliases.
+
+ Do NOT define functions inside the quoted expressions
+ below. Instead, define any helper function in modules
+ and import those modules here.
+ """
+
+ def controller do
+ quote do
+ use Phoenix.Controller, namespace: ShardWeb
+ import Plug.Conn
+ import ShardWeb.Router.Helpers
+ import ShardWeb.Gettext
+ end
+ end
+
+ def view do
+ quote do
+ use Phoenix.View, root: "lib/shard_web/templates",
+ namespace: ShardWeb
+
+ # Import convenience functions from controllers
+ import Phoenix.Controller, only: [get_flash: 2, view_module: 1]
+
+ # Use all HTML functionality (forms, tags, etc)
+ use Phoenix.HTML
+
+ import ShardWeb.Router.Helpers
+ import ShardWeb.ErrorHelpers
+ import ShardWeb.Gettext
+ end
+ end
+
+ def router do
+ quote do
+ use Phoenix.Router
+ import Plug.Conn
+ import Phoenix.Controller
+ end
+ end
+
+ def channel do
+ quote do
+ use Phoenix.Channel
+ import ShardWeb.Gettext
+ end
+ end
+
+ @doc """
+ When used, dispatch to the appropriate controller/view/etc.
+ """
+ defmacro __using__(which) when is_atom(which) do
+ apply(__MODULE__, which, [])
+ end
+end