2017-12-06 21:14:14 +01:00
|
|
|
from decimal import Decimal
|
|
|
|
from django.core.validators import MinValueValidator
|
2017-11-12 21:35:59 +01:00
|
|
|
from django.db import models
|
2017-11-13 22:55:20 +01:00
|
|
|
from django.contrib.auth.models import User
|
2018-01-04 12:30:01 +01:00
|
|
|
from django.utils import timezone
|
2017-11-12 21:35:59 +01:00
|
|
|
|
2017-11-18 09:18:06 +01:00
|
|
|
|
2017-11-13 22:55:20 +01:00
|
|
|
class Option(models.Model):
|
|
|
|
name = models.CharField(max_length=200, unique=True)
|
2018-01-14 14:07:53 +01:00
|
|
|
description = models.CharField(max_length=200, unique=True)
|
2017-11-13 22:55:20 +01:00
|
|
|
value = models.IntegerField(default=5)
|
|
|
|
enabled = models.BooleanField(default=False)
|
|
|
|
|
2017-12-06 20:35:06 +01:00
|
|
|
def __str__(self):
|
2018-01-14 14:07:53 +01:00
|
|
|
return self.name
|
2017-12-06 20:35:06 +01:00
|
|
|
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
class ArticleStatus(models.Model):
|
|
|
|
name = models.CharField(max_length=50, unique=True)
|
2017-11-18 09:18:06 +01:00
|
|
|
|
2017-11-14 21:26:44 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
|
2017-12-06 18:26:57 +01:00
|
|
|
# Create your models here.
|
|
|
|
class Category(models.Model):
|
|
|
|
name = models.CharField(max_length=200, unique=True)
|
|
|
|
parent_category = models.ForeignKey('self', null=True, blank=True)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
verbose_name_plural = "Categories"
|
|
|
|
|
|
|
|
|
2017-11-13 22:55:20 +01:00
|
|
|
class Article(models.Model):
|
|
|
|
name = models.CharField(max_length=200)
|
2017-12-06 18:27:58 +01:00
|
|
|
category = models.ForeignKey(Category, null=True)
|
2017-12-06 18:28:35 +01:00
|
|
|
description = models.TextField(max_length=2000)
|
2017-11-13 22:55:20 +01:00
|
|
|
stock = models.FloatField(max_length=5)
|
2017-11-14 21:26:44 +01:00
|
|
|
status = models.ForeignKey(ArticleStatus)
|
2017-12-06 21:14:14 +01:00
|
|
|
price_in_chf = models.DecimalField(max_digits=19,
|
|
|
|
decimal_places=2,
|
|
|
|
validators=[MinValueValidator(
|
|
|
|
Decimal('0.00'))])
|
2017-11-18 09:18:06 +01:00
|
|
|
|
2017-11-14 21:26:44 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
|
|
|
class OrderStatus(models.Model):
|
|
|
|
name = models.CharField(max_length=200, unique=True)
|
2017-11-18 09:18:06 +01:00
|
|
|
|
2017-11-14 21:26:44 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
|
|
|
|
class OrderOfGoods(models.Model):
|
2017-11-14 21:26:44 +01:00
|
|
|
article = models.ForeignKey(Article)
|
2017-11-13 22:55:20 +01:00
|
|
|
amount = models.FloatField(max_length=5)
|
|
|
|
delivery_date = models.DateField()
|
|
|
|
order_date = models.DateTimeField(auto_now_add=True)
|
2017-11-14 21:26:44 +01:00
|
|
|
order_status = models.ForeignKey(OrderStatus)
|
2017-11-13 22:55:20 +01:00
|
|
|
|
2017-11-26 21:24:17 +01:00
|
|
|
class Meta:
|
|
|
|
verbose_name_plural = "Order of Goods"
|
|
|
|
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
class Picture(models.Model):
|
2018-01-14 14:07:53 +01:00
|
|
|
name = models.CharField(max_length=200)
|
|
|
|
article = models.ForeignKey(Article)
|
2017-12-06 20:32:49 +01:00
|
|
|
image = models.ImageField(upload_to="images")
|
2017-11-18 09:18:06 +01:00
|
|
|
|
2017-11-14 21:26:44 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
|
|
|
|
class Order(models.Model):
|
2017-11-14 21:26:44 +01:00
|
|
|
user = models.ForeignKey(User, on_delete=models.CASCADE)
|
2017-12-21 23:06:09 +01:00
|
|
|
article = models.ManyToManyField(Article, through='OrderPosition')
|
|
|
|
status = models.ForeignKey(OrderStatus)
|
2018-01-04 12:30:01 +01:00
|
|
|
date = models.DateTimeField(default=timezone.now)
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
|
2017-12-21 23:06:09 +01:00
|
|
|
class OrderPosition(models.Model):
|
|
|
|
article = models.ForeignKey(Article, on_delete=models.CASCADE)
|
|
|
|
order = models.ForeignKey(Order, on_delete=models.CASCADE)
|
|
|
|
amount = models.FloatField(max_length=5)
|
|
|
|
price_in_chf = models.DecimalField(max_digits=19,
|
|
|
|
decimal_places=2,
|
|
|
|
validators=[MinValueValidator(
|
|
|
|
Decimal('0.00'))])
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
|
|
|
|
class ShoppingCart(models.Model):
|
|
|
|
name = models.CharField(max_length=200)
|
2017-11-14 21:26:44 +01:00
|
|
|
user = models.ForeignKey(User, on_delete=models.CASCADE)
|
|
|
|
article = models.ManyToManyField(Article)
|
2017-11-18 09:18:06 +01:00
|
|
|
|
2017-11-14 21:26:44 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
|
|
|
|
class City(models.Model):
|
2017-11-18 09:18:06 +01:00
|
|
|
name = models.CharField(max_length=200)
|
|
|
|
zip_code = models.PositiveSmallIntegerField()
|
|
|
|
|
|
|
|
def __str__(self):
|
2017-12-12 20:32:57 +01:00
|
|
|
return '{} {}'.format(self.zip_code, self.name)
|
2017-11-13 22:55:20 +01:00
|
|
|
|
2017-11-26 21:24:17 +01:00
|
|
|
class Meta:
|
|
|
|
verbose_name_plural = "Cities"
|
2017-12-20 19:51:49 +01:00
|
|
|
ordering = ['zip_code']
|
2017-11-26 21:24:17 +01:00
|
|
|
|
2017-11-13 22:55:20 +01:00
|
|
|
|
2017-11-14 21:26:44 +01:00
|
|
|
class Salutation(models.Model):
|
2017-11-13 22:55:20 +01:00
|
|
|
name = models.CharField(max_length=20)
|
|
|
|
|
2017-11-19 22:22:40 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
2017-11-13 22:55:20 +01:00
|
|
|
|
|
|
|
class Person(models.Model):
|
2017-11-14 21:26:44 +01:00
|
|
|
salutation = models.ForeignKey(Salutation)
|
|
|
|
city = models.ForeignKey(City)
|
2017-11-13 22:55:20 +01:00
|
|
|
street_name = models.CharField(max_length=200)
|
|
|
|
street_number = models.CharField(max_length=4)
|
2017-11-14 21:26:44 +01:00
|
|
|
user = models.OneToOneField(User, on_delete=models.CASCADE)
|
2017-11-18 09:18:06 +01:00
|
|
|
|
2017-11-14 21:26:44 +01:00
|
|
|
def __str__(self):
|
2017-12-28 19:14:41 +01:00
|
|
|
return self.user.username
|