Exemplo n.º 1
0
class Deposit(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    date = db.Column(db.DateTime, nullable=False)
    customer_id = db.Column(db.Integer,
                            db.ForeignKey('customer.id'),
                            nullable=False)
    depositItems = db.relationship('DepositItem', backref='deposit', lazy=True)

    def __repr__(self):
        return "Gutschrift: " + str(self.id) + " - " + self.date.strftime(
            '%d.%m.%Y') + " - " + self.customer.name

    def amounts(self):
        return db.session.query(
            Fruit.name,
            func.sum(DepositItem.amount).label('amount'),
            func.sum(DepositItem.amountLiter).label('amountLiter'),
            func.sum(DepositItem.amountEuro).label('amountEuro')).join(
                DepositItem.deposit).join(DepositItem.box).join(
                    Box.content).filter(Deposit.id == self.id).group_by(
                        Fruit.name).all()

    def total(self):
        return db.session.query(
            func.sum(DepositItem.amountEuro).label('amountEuro')).join(
                DepositItem.deposit).filter(Deposit.id == self.id).first()[0]

    def type(self):
        return "Gutschrift"
Exemplo n.º 2
0
class Purchase(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    date = db.Column(db.DateTime, nullable=False)
    customer_id = db.Column(db.Integer,
                            db.ForeignKey('customer.id'),
                            nullable=False)
    purchaseItems = db.relationship('PurchaseItem',
                                    backref='purchase',
                                    lazy=True)
    purchaseCompensations = db.relationship('PurchaseCompensation',
                                            backref='purchase',
                                            lazy=True)

    def __repr__(self):
        return "Verkauf: " + str(self.id) + " - " + self.date.strftime(
            '%d.%m.%Y') + " - " + self.customer.name

    def total(self):
        art = db.session.query(
            func.sum(PurchaseItem.amount * PurchaseItem.price)).join(
                PurchaseItem.purchase).filter(
                    Purchase.id == self.id).first()[0]
        comp = db.session.query(
            func.sum(PurchaseCompensation.amount *
                     PurchaseCompensation.price)).join(
                         PurchaseCompensation.purchase).filter(
                             Purchase.id == self.id).first()[0]
        if (art == None):
            art = 0
        if (comp == None):
            comp = 0
        return art + comp

    def amounts(self):
        res = []
        fruits = Fruit.query.all()
        art = db.session.query(
            Fruit.name,
            func.sum(PurchaseItem.amount * Article.amountLiter)).join(
                PurchaseItem.purchase).join(PurchaseItem.article).join(
                    Article.fruit).filter(Purchase.id == self.id).group_by(
                        Fruit.name).all()
        comp = db.session.query(Fruit.name, PurchaseCompensation.amount).join(
            PurchaseCompensation.purchase).join(
                PurchaseCompensation.fruit).filter(
                    Purchase.id == self.id).all()
        for f in fruits:
            entry = [f.name, 0]
            for a in art:
                if (f.name == a[0]):
                    entry[1] = a[1]
            for c in comp:
                if (f.name == c[0]):
                    entry[1] -= c[1]
            res.append(entry)
        return res

    def type(self):
        return "Verkauf"
Exemplo n.º 3
0
class PurchaseCompensation(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    fruit_id = db.Column(db.Integer, db.ForeignKey('fruit.id'), nullable=False)
    amount = db.Column(db.Numeric(5, 1), nullable=False)
    price = db.Column(db.Numeric(5, 2),
                      unique=False,
                      nullable=False,
                      default=0)
    purchase_id = db.Column(db.Integer,
                            db.ForeignKey('purchase.id'),
                            nullable=False)

    def total(self):
        return self.amount * self.price
Exemplo n.º 4
0
class PurchaseItem(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    article_id = db.Column(db.Integer,
                           db.ForeignKey('article.id'),
                           nullable=False)
    amount = db.Column(db.Numeric(5, 1), nullable=False)
    price = db.Column(db.Numeric(5, 2), unique=False, nullable=True, default=0)
    purchase_id = db.Column(db.Integer,
                            db.ForeignKey('purchase.id'),
                            nullable=False)

    def amountLiter(self):
        return self.amount * self.article.amountLiter

    def total(self):
        return self.amount * self.price
Exemplo n.º 5
0
class Fruit(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(20), unique=True, nullable=False)
    ratio = db.Column(db.Numeric(5, 2), unique=False, nullable=False)
    price = db.Column(db.Numeric(5, 2), unique=False, nullable=False)
    pricePerLiter = db.Column(db.Numeric(5, 2),
                              unique=False,
                              nullable=False,
                              default=0)
    boxes = db.relationship('Box', backref='content', lazy=True)
    articles = db.relationship('Article', backref='fruit', lazy=True)
    purchaseCompensations = db.relationship('PurchaseCompensation',
                                            backref='fruit',
                                            lazy=True)

    def __repr__(self):
        return self.name
Exemplo n.º 6
0
class Box(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    number = db.Column(db.String(5), nullable=False)
    content_id = db.Column(db.Integer,
                           db.ForeignKey('fruit.id'),
                           nullable=False)
    ended = db.Column(db.DateTime, nullable=True)
    depositItems = db.relationship('DepositItem', backref='box', lazy=True)

    def __repr__(self):
        return self.number + " - Noch " + str(self.freeAmount()) + " kg frei"

    def amount(self):
        return sum(depositItem.amount for depositItem in self.depositItems)

    def freeAmount(self):
        return 300 - self.amount()
Exemplo n.º 7
0
class Article(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(20), unique=True, nullable=False)
    desc = db.Column(db.String(100), unique=False, nullable=False)
    fruit_id = db.Column(db.Integer, db.ForeignKey('fruit.id'), nullable=False)
    price = db.Column(db.Numeric(5, 2), unique=False, nullable=False)
    amountLiter = db.Column(db.Numeric(5, 2), unique=False, nullable=False)
    purchaseItems = db.relationship('PurchaseItem',
                                    backref='article',
                                    lazy=True)

    def __repr__(self):
        return self.name
Exemplo n.º 8
0
class DepositItem(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    box_id = db.Column(db.Integer, db.ForeignKey('box.id'), nullable=False)
    amount = db.Column(db.Numeric(5, 1), nullable=False)
    price = db.Column(db.Numeric(5, 2), unique=False, nullable=False)
    deposit_id = db.Column(db.Integer,
                           db.ForeignKey('deposit.id'),
                           nullable=False)
    amountLiter = db.Column(db.Numeric(5, 1), nullable=False)
    amountEuro = db.Column(db.Numeric(5, 2), nullable=False)

    def __repr__(self):
        return self.id

    def __init__(self, box, amount, deposit, amountLiter, amountEuro):
        self.box_id = box.id
        self.price = box.content.price
        self.amount = amount
        self.deposit_id = deposit.id
        self.amountLiter = amountLiter
        self.amountEuro = amountEuro
Exemplo n.º 9
0
class Customer(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50), unique=True, nullable=False)
    street = db.Column(db.String(50), unique=False, nullable=True)
    zipcode = db.Column(db.String(10), unique=False, nullable=True)
    city = db.Column(db.String(50), unique=False, nullable=True)
    email = db.Column(db.String(120), unique=False, nullable=True)
    phone = db.Column(db.String(20), unique=False, nullable=True)
    mobile = db.Column(db.String(20), unique=False, nullable=True)
    deposits = db.relationship('Deposit', backref='customer', lazy=True)
    purchases = db.relationship('Purchase', backref='customer', lazy=True)

    def __repr__(self):
        return self.name

    def amounts(self):
        pa = self.purchaseAmounts()
        da = self.depositAmounts()
        res = []
        fruits = Fruit.query.all()
        for f in fruits:
            res.append([f.name, 0, 0, f])
        for d in da:
            for r in res:
                if r[0] == d[0]:
                    r[2] += d[2]
        for p in pa:
            for r in res:
                if r[0] == p[0]:
                    r[2] -= p[1]
        return res

    def depositAmounts(self):
        res = db.session.query(
            Fruit.name,
            func.sum(DepositItem.amount).label('amount'),
            func.sum(DepositItem.amountLiter).label('amountLiter')).join(
                DepositItem.deposit).join(DepositItem.box).join(
                    Box.content).filter(
                        Deposit.customer_id == self.id).group_by(
                            Fruit.name).all()
        return res

    def purchaseAmounts(self):
        res = []
        fruits = Fruit.query.all()
        art = db.session.query(
            Fruit.name,
            func.sum(PurchaseItem.amount * Article.amountLiter),
        ).join(PurchaseItem.purchase).join(PurchaseItem.article).join(
            Article.fruit).filter(Purchase.customer_id == self.id).group_by(
                Fruit.name).all()
        comp = db.session.query(Fruit.name, PurchaseCompensation.amount).join(
            PurchaseCompensation.purchase).join(
                PurchaseCompensation.fruit).filter(
                    Purchase.customer_id == self.id).all()
        for f in fruits:
            entry = [f.name, 0]
            for a in art:
                if (f.name == a[0]):
                    entry[1] = a[1]
            for c in comp:
                if (f.name == c[0]):
                    entry[1] -= c[1]
            res.append(entry)
        return res

    def history(self):
        list = []
        p = len(self.purchases) - 1
        d = len(self.deposits) - 1
        while (p + d > -2):
            if (p < 0):
                list.append(self.deposits[d])
                d -= 1
            elif (d < 0):
                list.append(self.purchases[p])
                p -= 1
            elif (self.purchases[p].date > self.deposits[d].date):
                list.append(self.purchases[p])
                p -= 1
            else:
                list.append(self.deposits[d])
                d -= 1
        return list