diff options
Diffstat (limited to 'shardweb/lib/shard_web.ex')
-rw-r--r-- | shardweb/lib/shard_web.ex | 67 |
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 |