forked from routablehq/python-quickbooks
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpayment.py
More file actions
81 lines (67 loc) · 2.76 KB
/
payment.py
File metadata and controls
81 lines (67 loc) · 2.76 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
from six import python_2_unicode_compatible
from .base import QuickbooksBaseObject, Ref, LinkedTxn, \
QuickbooksManagedObject, QuickbooksTransactionEntity
from .creditcardpayment import CreditCardPayment
from ..mixins import DeleteMixin
@python_2_unicode_compatible
class PaymentLine(QuickbooksBaseObject):
list_dict = {
"LinkedTxn": LinkedTxn,
}
def __init__(self):
super(PaymentLine, self).__init__()
self.Amount = 0
self.LinkedTxn = []
def __str__(self):
return str(self.Amount)
@python_2_unicode_compatible
class Payment(DeleteMixin, QuickbooksManagedObject, QuickbooksTransactionEntity):
"""
QBO definition: A Payment entity records a payment in QuickBooks. The payment can be
applied for a particular customer against multiple Invoices and Credit Memos. It can also
be created without any Invoice or Credit Memo, by just specifying an amount.
- A Payment can be updated as a full update or a sparse update.
- A Payment can be linked to multiple Invoices and Credit Memos
- A Payment can be created as unapplied to any Invoice or Credit Memo, in which case
it is recorded as a credit.
- If any element in any line needs to be updated, all the Lines of a Payment have to be
provided. This is true for full or sparse update. Lines can be updated only ALL or NONE.
- To remove all lines, send an empty Lines tag.
- To remove some of the lines, send all the Lines that need to be present MINUS the
lines that need to be removed.
- To add some lines, send all existing and new Lines that need to be present.
- The sequence in which the Lines are received is the sequence in which lines are preserved.
"""
class_dict = {
"ARAccountRef": Ref,
"CustomerRef": Ref,
"PaymentMethodRef": Ref,
"DepositToAccountRef": Ref,
"CurrencyRef": Ref,
"CreditCardPayment": CreditCardPayment,
}
list_dict = {
"Line": PaymentLine
}
qbo_object_name = "Payment"
def __init__(self):
super(Payment, self).__init__()
self.PaymentRefNum = None
self.TotalAmt = None
self.UnappliedAmt = None # Readonly
self.ExchangeRate = None
self.TxnDate = None
self.TxnSource = None
self.PrivateNote = None
self.TxnStatus = None
self.CreditCardPayment = None
self.ARAccountRef = None
self.CustomerRef = None
self.CurrencyRef = None # Readonly
self.PaymentMethodRef = None
self.DepositToAccountRef = None
self.Line = []
# These fields are for minor version 4
self.TransactionLocationType = None
def __str__(self):
return str(self.TotalAmt)