View Source Routex.Extension.Cldr (Routex v1.1.0)
Adapter for projects using :ex_cldr. It generates the configuration
for Routex.Extension.Alternatives
.
Ejecting the CLDR extension
Using the Cldr adapter provides the advantage of keeping your localized routes in sync with the configuration of Cldr. The disadvantage is a lack of flexibility. If you ever need more flexibility, you can eject the Cldr extension.
Interpolating Locale Data
Interpolation is provided by Routex.Extension.Interpolation
, which
is able to use any Routex.Attr
for interpolation into your routes.
See it's documentation for additional options.
When using this Cldr extension, the following interpolations are supported as they
are set as Routex.Attr
:
locale
will interpolate the Cldr locale namelocale_display
will interpolate the Cldr locale display namelanguage
will interpolate the Cldr language nameterritory
will interpolate the Cldr territory code
Some examples:
preprocess_using ExampleWeb.RoutexBackend do
scope "/#{territory}/territory/" do
get "/locale/pages/:page/#{locale}/", PageController, :show
get "/language/#{language}/pages/:page", PageController, :show
end
end
Configuration
defmodule ExampleWeb.RoutexBackend do
use Routex.Backend,
extensions: [
Routex.Extension.AttrGetters, # required
+ Routex.Extension.Cldr,
+ Routex.Extension.Alternatives,
+ Routex.Extension.Interpolation, # when using routes with interpolation
+ Routex.Extension.Translations, # when using translated routes
+ Routex.Extension.VerifiedRoutes
],
+ cldr_backend: MyApp.Cldr,
+ translations_backend: MyApp.Gettext, # when using translated routes
+ translations_domain: "routes", # when using translated routes
+ alternatives_prefix: false, # when using routes with interpolation
+ verified_sigil_routex: "~q", # consider using ~p, see `Routex.Extension.VerifiedRoutes`
defmodule ExampleWeb.Router
# require your Cldr backend module before `use`ing the router.
+ require ExampleWeb.Cldr
use ExampleWeb, :router
import ExampleWeb.UserAuth
When your application does not compile after adding this extension, force a
recompile using mix compile --force
.
Pseudo result
This extension injects :alternatives
into your configuration.
See the documentation of Routex.Extension.Alternatives
to see
more options and the pseudo result.
Eject the Cldr adapter
This extension abstracts away the configuration of Routex.Extension.Alternatives
. You may want
to customize things beyond what Routex.Extension.Cldr
provides. When you eject, you copy
the generated configuration into the Routex backend.
In other words, instead of relying on the preconfigured “black box” provided by this extension, you
now have full access to—and responsibility for—the configuration of Routex.Extension.Alternatives
.
Copy the generated configuration into your Routex backend**
Call the config/0
function on you backend (e.g. ExampleWeb.RoutexBackend.config()
)
in IEX. Copy the alternatives: %{...}
section to your Routex backend.
defmodule ExampleWeb.RoutexBackend do
use Routex.Backend,
extensions: [...],
+ alternatives: %{...}
Remove references to Cldr
defmodule ExampleWeb.RoutexBackend do
use Routex.Backend,
extensions: [
- Routex.Extension.Cldr,
],
- cldr_backend: MyApp.Cldr,
defmodule ExampleWeb.Router
- require ExampleWeb.Cldr
use ExampleWeb, :router
import ExampleWeb.UserAuth
Routex.Attrs
Requires
- none
Sets
- language
- locale
- locale_display
- territory
Summary
Functions
Callback implementation for Routex.Extension.configure/2
.
Functions
Callback implementation for Routex.Extension.configure/2
.