add some new settings
This commit is contained in:
parent
2a9bf4dc2b
commit
5ee299ac8c
20
common.py
Normal file
20
common.py
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import decimal
|
||||||
|
|
||||||
|
|
||||||
|
def remove_exponent(d):
|
||||||
|
return d.quantize(decimal.Decimal(1)) if d == d.to_integral() else d.normalize()
|
||||||
|
|
||||||
|
|
||||||
|
def round_to(number, increment, up_threshold=0.95):
|
||||||
|
""" round number to nearest multiple of increment """
|
||||||
|
ratio = number/increment
|
||||||
|
whole = ratio.to_integral(rounding=decimal.ROUND_DOWN)
|
||||||
|
dec = ratio - whole
|
||||||
|
if dec >= up_threshold:
|
||||||
|
whole += 1
|
||||||
|
return whole * increment
|
||||||
|
|
||||||
|
|
||||||
|
def to_lb(weight_kg):
|
||||||
|
return remove_exponent(round_to(weight_kg * decimal.Decimal("2.2046"),
|
||||||
|
decimal.Decimal("0.125")))
|
@ -1,13 +1,9 @@
|
|||||||
import decimal
|
|
||||||
from django import template
|
from django import template
|
||||||
from django.template.defaultfilters import stringfilter
|
from django.template.defaultfilters import stringfilter
|
||||||
from lifting.utils import round_to
|
from common import to_lb
|
||||||
|
|
||||||
register = template.Library()
|
register = template.Library()
|
||||||
|
|
||||||
def remove_exponent(d):
|
|
||||||
return d.quantize(decimal.Decimal(1)) if d == d.to_integral() else d.normalize()
|
|
||||||
|
|
||||||
|
|
||||||
class MassNode(template.Node):
|
class MassNode(template.Node):
|
||||||
def __init__(self, weight):
|
def __init__(self, weight):
|
||||||
@ -17,8 +13,7 @@ class MassNode(template.Node):
|
|||||||
try:
|
try:
|
||||||
weight_kg = self.weight.resolve(context)
|
weight_kg = self.weight.resolve(context)
|
||||||
if context['user'].profile.lifting_units == 'i':
|
if context['user'].profile.lifting_units == 'i':
|
||||||
return remove_exponent(round_to(weight_kg * decimal.Decimal("2.2046"),
|
return to_lb(weight_kg)
|
||||||
decimal.Decimal("0.125")))
|
|
||||||
else:
|
else:
|
||||||
return remove_exponent(weight_kg)
|
return remove_exponent(weight_kg)
|
||||||
except template.VariableDoesNotExist:
|
except template.VariableDoesNotExist:
|
||||||
@ -26,7 +21,7 @@ class MassNode(template.Node):
|
|||||||
|
|
||||||
class MassLabelNode(template.Node):
|
class MassLabelNode(template.Node):
|
||||||
def render(self, context):
|
def render(self, context):
|
||||||
return {'i': 'lbs', 'm': 'kg'}[context['user'].profile.lifting_units]
|
return {'i': 'lb', 'm': 'kg'}[context['user'].profile.lifting_units]
|
||||||
|
|
||||||
|
|
||||||
@register.tag
|
@register.tag
|
||||||
|
@ -1,11 +0,0 @@
|
|||||||
import decimal
|
|
||||||
|
|
||||||
|
|
||||||
def round_to(number, increment, up_threshold=0.95):
|
|
||||||
""" round number to nearest multiple of increment """
|
|
||||||
ratio = number/increment
|
|
||||||
whole = ratio.to_integral(rounding=decimal.ROUND_DOWN)
|
|
||||||
dec = ratio - whole
|
|
||||||
if dec >= up_threshold:
|
|
||||||
whole += 1
|
|
||||||
return whole * increment
|
|
41
profiles/migrations/0002_auto_20150410_1627.py
Normal file
41
profiles/migrations/0002_auto_20150410_1627.py
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from django.db import models, migrations
|
||||||
|
from django.conf import settings
|
||||||
|
import django.contrib.postgres.fields
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||||
|
('profiles', '0001_initial'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Bar',
|
||||||
|
fields=[
|
||||||
|
('id', models.AutoField(auto_created=True, serialize=False, verbose_name='ID', primary_key=True)),
|
||||||
|
('name', models.CharField(max_length=100)),
|
||||||
|
('weight_kg', models.DecimalField(max_digits=7, decimal_places=3)),
|
||||||
|
('user', models.OneToOneField(related_name='bar', to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='profile',
|
||||||
|
name='plate_pairs',
|
||||||
|
field=django.contrib.postgres.fields.ArrayField(default=['45', '45', '25', '10', '5', '5', '2.5', '1.25'], base_field=models.DecimalField(max_digits=7, decimal_places=3), size=None),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='profile',
|
||||||
|
name='lifting_units',
|
||||||
|
field=models.CharField(default='i', choices=[('m', 'Metric (kg)'), ('i', 'Imperial (lb)')], max_length=1),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='profile',
|
||||||
|
name='user',
|
||||||
|
field=models.OneToOneField(related_name='profile', to=settings.AUTH_USER_MODEL),
|
||||||
|
),
|
||||||
|
]
|
@ -1,12 +1,31 @@
|
|||||||
from django.db import models
|
from django.db import models
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
|
from django.contrib.postgres.fields import ArrayField
|
||||||
|
from common import to_lb
|
||||||
|
|
||||||
UNITS = (
|
UNITS = (
|
||||||
('m', 'Metric (kg)'),
|
('m', 'Metric (kg)'),
|
||||||
('i', 'Imperial (lbs)'),
|
('i', 'Imperial (lb)'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
class Profile(models.Model):
|
class Profile(models.Model):
|
||||||
user = models.OneToOneField(User, related_name='profile')
|
user = models.OneToOneField(User, related_name='profile')
|
||||||
|
|
||||||
lifting_units = models.CharField(max_length=1, choices=UNITS)
|
lifting_units = models.CharField(max_length=1, choices=UNITS, default='i')
|
||||||
|
plate_pairs = ArrayField(models.DecimalField(max_digits=7, decimal_places=3),
|
||||||
|
default=['45','45','25','10','5','5','2.5','1.25'])
|
||||||
|
|
||||||
|
|
||||||
|
class Bar(models.Model):
|
||||||
|
user = models.OneToOneField(User, related_name='bar')
|
||||||
|
|
||||||
|
name = models.CharField(max_length=100)
|
||||||
|
weight_kg = models.DecimalField(max_digits=7, decimal_places=3)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return '{} ({}lb / {}kg)'.format(self.name, self.weight_kg, self.weight_lb)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def weight_lb(self):
|
||||||
|
return to_lb(self.weight_kg)
|
||||||
|
Loading…
Reference in New Issue
Block a user