An open API service indexing awesome lists of open source software.

https://github.com/elixir-cldr/cldr_currencies

Packages the currency definitions from CLDR into a set of functions to return currency data.
https://github.com/elixir-cldr/cldr_currencies

Last synced: 12 months ago
JSON representation

Packages the currency definitions from CLDR into a set of functions to return currency data.

Awesome Lists containing this project

README

          

# Cldr Currencies

Packages the currency definitions from [CLDR](http://cldr.unicode.org) into a set of functions
to return currency data.

## Installation

The package can be installed by adding `ex_cldr_currencies` to your list of dependencies in `mix.exs`:

```elixir
def deps do
[
{:ex_cldr_currencies, "~> 2.13"}
]
end
```

## Defining private use currencies

[ISO4217](https://en.wikipedia.org/wiki/ISO_4217) permits the creation of private use currencies. These are denoted by currencies that start with "X" followed by two characters. New currencies can be created with `Cldr.Currency.new/2` however in order to do so a supervisor must be started which maintains an `:ets` table that holds the custom currencies.

Since the currencies are stored in an `:ets` table they are transient and will be lost on application restart. It is the developers responsibility to define the required private use currencies on application restart.

### Starting the private use currency supervisor

The simplest way to start the private use currency supervisor is:
```elixir
iex> Cldr.Currency.start_link()
```

The preferred method however is to add the supervisor to your applications supervision tree. In your application module (ie the one that includes `use Application`):
```elixir
defmodule MyApp do
use Application

def start(_type, _args) do
# Start the service which maintains the
# :ets table that holds the private use currencies
children = [
Cldr.Currency
...
]

opts = [strategy: :one_for_one, name: MoneyTest.Supervisor]
Supervisor.start_link(children, opts)

# Load your custom currencies now that the
# Cldr.Currency genserver is running
# load_my_custom_currencies()
end
end
```