Subversion Repositories SmartDukaan

Rev

Rev 12865 | Rev 20025 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
4503 mandeep.dh 1
'''
2
Created on 29-Jul-2011
3
 
4
@author: Chandranshu
5
'''
6
from elixir.entity import Entity
7
from elixir.fields import Field
8
from elixir.options import using_options, using_table_options
9
from elixir.relationships import OneToMany
10
from shop2020.purchase.main.model.LineItem import LineItem
11
from shop2020.thriftpy.purchase.ttypes import PurchaseOrder as TPurchaseOrder, \
9925 amar.kumar 12
    POStatus
4503 mandeep.dh 13
from shop2020.utils.Utils import to_java_date
6821 amar.kumar 14
from sqlalchemy.types import Integer, String, Float, DateTime, Enum
4503 mandeep.dh 15
import datetime
16
import time
17
 
18
 
19
 
20
 
21
class PurchaseOrder(Entity):
22
    '''
23
    classdocs
24
    '''
25
    id = Field(Integer, primary_key=True, autoincrement=True)
26
    poNumber = Field(String(20))
27
    supplierId = Field(Integer)
9925 amar.kumar 28
    warehouseId = Field(Integer)
29
    shippingWarehouseId = Field(Integer) 
4503 mandeep.dh 30
    status = Field(Integer)
31
    createdAt = Field(DateTime)
32
    updatedAt = Field(DateTime)
33
    totalCost = Field(Float)
34
    freightCharges = Field(Float)
35
    realizedCost = Field(Float)
36
    realizedFreightCharges = Field(Float)
6821 amar.kumar 37
    type = Field(Enum('REAL', 'VIRTUAL'), default = 'REAL', server_default='REAL')
9416 amar.kumar 38
    taxType = Field(Integer)
4503 mandeep.dh 39
    lineitems = OneToMany("LineItem")
40
    purchases = OneToMany("Purchase")
41
    using_options(shortnames=True)
42
    using_table_options(mysql_engine="InnoDB")
43
 
44
    def __init__(self, t_purchase_order):
45
        '''
46
        Constructor
47
        '''
48
        #Generate the poNumber
49
        self.supplierId = t_purchase_order.supplierId
50
        self.warehouseId = t_purchase_order.warehouseId
9925 amar.kumar 51
        if t_purchase_order.shippingWarehouseId:
52
            self.shippingWarehouseId = t_purchase_order.shippingWarehouseId
53
        else:
54
            self.shippingWarehouseId = t_purchase_order.warehouseId
4503 mandeep.dh 55
 
56
        #TODO: This should be INIT. Category manager should review and mark it as ready.
57
        self.status = POStatus.READY
58
        self.createdAt = datetime.datetime.now()
59
        self.totalCost = t_purchase_order.totalCost
60
        self.freightCharges = t_purchase_order.freightCharges or 0
61
        self.realizedCost = 0
62
        self.realizedFreightCharges = 0
6762 amar.kumar 63
        if t_purchase_order.lineitems:
6857 amar.kumar 64
            for t_lineitem in t_purchase_order.lineitems:
12866 manish.sha 65
                if t_lineitem.quantity == 0:            
12864 manish.sha 66
                    t_purchase_order.lineitems.pop(t_purchase_order.lineitems.index(t_lineitem))
6762 amar.kumar 67
            self.lineitems = [LineItem(self, t_lineitem) for t_lineitem in t_purchase_order.lineitems]
6821 amar.kumar 68
            self.totalCost = sum([t_lineitem.quantity * t_lineitem.unitPrice for t_lineitem in t_purchase_order.lineitems])
69
        self.type = t_purchase_order.type
9416 amar.kumar 70
        self.poNumber = t_purchase_order.poNumber
71
        self.taxType = t_purchase_order.taxType        
4503 mandeep.dh 72
 
73
    def to_thrift_object(self):
74
        t_purchase_order = TPurchaseOrder()
75
        t_purchase_order.id = self.id
76
        t_purchase_order.poNumber = self.poNumber
77
        t_purchase_order.supplierId = self.supplierId
7410 amar.kumar 78
        t_purchase_order.warehouseId = self.warehouseId
9925 amar.kumar 79
        t_purchase_order.shippingWarehouseId = self.shippingWarehouseId
4503 mandeep.dh 80
        t_purchase_order.status = self.status
81
        t_purchase_order.createdAt = to_java_date(self.createdAt)
82
        if self.updatedAt:
83
            t_purchase_order.updatedAt = to_java_date(self.updatedAt)
84
        t_purchase_order.totalCost = self.totalCost
85
        t_purchase_order.freightCharges = self.freightCharges
86
        t_purchase_order.realizedCost = self.realizedCost
87
        t_purchase_order.realizedFreightCharges = self.realizedFreightCharges
88
 
89
        t_purchase_order.lineitems = [lineitem.to_thrift_object() for lineitem in self.lineitems]
9416 amar.kumar 90
        t_purchase_order.taxType = self.taxType
4503 mandeep.dh 91
        return t_purchase_order
92
 
93
    def set_po_number(self):
94
        self.poNumber = "SORL/" + time.strftime("%m-%y") + "/" + str(self.id)