A reusable Django application to control the currency rate and favorite language code, inspired by etsy
Project description
A reusable Django application to control the currency rate and favorite language code, inspired by etsy.
First you need to request an app id at open exchange rates to import currency rates.
Installation
To install it, simply
pip install django-metasettings
Add ‘metasettings’ to your INSTALLED_APPS
INSTALLED_APPS = ( 'metasettings', )
If you want to install the dashboard to allow your users to select a language and a currency you will have to install urls from metasettings like so
# urls.py from django.conf.urls import patterns, include urlpatterns = patterns( '', (r'^', include('metasettings.urls')) )
You can add your proper stylesheet to this dashboard view and have this kind of result:
Usage
To import current currency rates, run
$ python manage.py sync_rates --app_id=openexchangesratesappid
To import currency rates in a date range, run
$ python manage.py sync_rates --app_id=openexchangesratesappid --date_start=2011-10-01 --date_end=2013-10-01
It will import for each months between the two dates the currency rates.
The OpenExchangeRates app id can also be stored in the OPENEXCHANGERATES_APP_ID Django setting.
If you can to convert an amount from on currency to another:
from metasettings.models import convert_amount
convert_amount('EUR', 'USD', 15) # ~20 euros
By default it will return a full decimal, if you want a converted integer:
from metasettings.models import convert_amount
convert_amount('EUR', 'USD', 15, ceil=True) # ~20 euros
To retrieve the currency with a client IP Address:
from metasettings.models import get_currency_from_ip_address
get_currency_from_ip_address('78.192.244.8') # EUR
We are using GeoIP which gives you the ability to retrieve the country and then we are linking the country to an existing currency.
So don’t forget to import a fresh GeoIP database and be sure to have GEOIP_PATH in your settings.
We recommend to use django-geoip-utils which provides some helpers to manipulate GeoIP API.
CurrencyField
A currency field for Django models that provides all ISO 4217 currencies as choices.
CurrencyField is based on Django’s CharField, providing choices corresponding to the official ISO 4217 list of currencies (with a default max_length of 3).
Consider the following model using a CurrencyField:
from django.db import models
from metasettings.fields import CurrencyField
class Project(models.Model):
name = models.CharField(max_length=100)
currency = CurrencyField()
Any Project instance will have a currency attribute that you can use to get details of the project’s currency:
>>> project = Project(name='My project', currency='EUR')
>>> project.currency
Currency(code='EUR')
>>> project.currency.label
'Euro'
>>> project.currency.symbol
'€'
>>> project = Project(name='My project', currency='USD')
>>> project.currency
Currency(code='USD')
>>> project.currency.label
'United States Dollar'
>>> project.currency.symbol
'$'
>>> project.currency.trigram
'USD'
This object (project.currency in the example) is a Currency instance, which is described below.
Use blank_label to set the label for the initial blank choice shown in forms:
currency = CurrencyField(blank_label='(select currency)')
Roadmap
see issues
This application only includes major currencies, don’t hesitate to send patch or improvements.
Inspirations
The CurrencyField is heavily inspired from CountryField of the great django-countries
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file django-metasettings-0.3.8.tar.gz
.
File metadata
- Download URL: django-metasettings-0.3.8.tar.gz
- Upload date:
- Size: 23.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.6.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c221fbcfd2a9a43b406be6f9169214d574d35e0705a5ce93ad8f04fdfe35746d |
|
MD5 | 8869326ca94fadc61825e35df9d585c5 |
|
BLAKE2b-256 | 096d75d42e910ff6656caae2e24a304dd46978ae36fd5b7554080c9f4d3137fe |