Merge branch 'master' into edge
This commit is contained in:
commit
8c14789537
@ -326,7 +326,7 @@ class DocType(BuyingController):
|
|||||||
against_accounts.append(stock_not_billed_account)
|
against_accounts.append(stock_not_billed_account)
|
||||||
|
|
||||||
elif not item.expense_head:
|
elif not item.expense_head:
|
||||||
msgprint(_("""Expense account is mandatory for item: """) + item.item_code,
|
msgprint(_("""Expense account is mandatory for item: """) + (item.item_code or item.item_name),
|
||||||
raise_exception=1)
|
raise_exception=1)
|
||||||
|
|
||||||
elif item.expense_head not in against_accounts:
|
elif item.expense_head not in against_accounts:
|
||||||
|
@ -566,7 +566,7 @@ class DocType(SellingController):
|
|||||||
|
|
||||||
def check_value(self, ref_dt, ref_dn, ref_item_dn, val, item_code):
|
def check_value(self, ref_dt, ref_dn, ref_item_dn, val, item_code):
|
||||||
ref_val = webnotes.conn.get_value(ref_dt + " Item", ref_item_dn, "export_rate")
|
ref_val = webnotes.conn.get_value(ref_dt + " Item", ref_item_dn, "export_rate")
|
||||||
if flt(ref_val) != flt(val):
|
if flt(ref_val, 2) != flt(val, 2):
|
||||||
msgprint(_("Rate is not matching with ") + ref_dt + ": " + ref_dn +
|
msgprint(_("Rate is not matching with ") + ref_dt + ": " + ref_dn +
|
||||||
_(" for item: ") + item_code, raise_exception=True)
|
_(" for item: ") + item_code, raise_exception=True)
|
||||||
|
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
import webnotes
|
import webnotes
|
||||||
from webnotes.utils import flt
|
from webnotes.utils import flt
|
||||||
|
from webnotes import msgprint, _
|
||||||
|
|
||||||
def execute(filters=None):
|
def execute(filters=None):
|
||||||
if not filters: filters = {}
|
if not filters: filters = {}
|
||||||
@ -24,6 +25,11 @@ def execute(filters=None):
|
|||||||
invoice_list = get_invoices(filters)
|
invoice_list = get_invoices(filters)
|
||||||
columns, expense_accounts, tax_accounts = get_columns(invoice_list)
|
columns, expense_accounts, tax_accounts = get_columns(invoice_list)
|
||||||
|
|
||||||
|
|
||||||
|
if not invoice_list:
|
||||||
|
msgprint(_("No record found"))
|
||||||
|
return columns, invoice_list
|
||||||
|
|
||||||
invoice_expense_map = get_invoice_expense_map(invoice_list)
|
invoice_expense_map = get_invoice_expense_map(invoice_list)
|
||||||
invoice_tax_map = get_invoice_tax_map(invoice_list)
|
invoice_tax_map = get_invoice_tax_map(invoice_list)
|
||||||
invoice_po_pr_map = get_invoice_po_pr_map(invoice_list)
|
invoice_po_pr_map = get_invoice_po_pr_map(invoice_list)
|
||||||
@ -64,17 +70,18 @@ def get_columns(invoice_list):
|
|||||||
"Project:Link/Project:80", "Bill No::120", "Bill Date:Date:80", "Remarks::150",
|
"Project:Link/Project:80", "Bill No::120", "Bill Date:Date:80", "Remarks::150",
|
||||||
"Purchase Order:Link/Purchase Order:100", "Purchase Receipt:Link/Purchase Receipt:100"
|
"Purchase Order:Link/Purchase Order:100", "Purchase Receipt:Link/Purchase Receipt:100"
|
||||||
]
|
]
|
||||||
|
expense_accounts = tax_accounts = []
|
||||||
expense_accounts = webnotes.conn.sql_list("""select distinct expense_head
|
if invoice_list:
|
||||||
from `tabPurchase Invoice Item` where docstatus = 1 and ifnull(expense_head, '') != ''
|
expense_accounts = webnotes.conn.sql_list("""select distinct expense_head
|
||||||
and parent in (%s) order by expense_head""" %
|
from `tabPurchase Invoice Item` where docstatus = 1 and ifnull(expense_head, '') != ''
|
||||||
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
and parent in (%s) order by expense_head""" %
|
||||||
|
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
||||||
|
|
||||||
tax_accounts = webnotes.conn.sql_list("""select distinct account_head
|
tax_accounts = webnotes.conn.sql_list("""select distinct account_head
|
||||||
from `tabPurchase Taxes and Charges` where parenttype = 'Purchase Invoice'
|
from `tabPurchase Taxes and Charges` where parenttype = 'Purchase Invoice'
|
||||||
and docstatus = 1 and ifnull(account_head, '') != '' and parent in (%s)
|
and docstatus = 1 and ifnull(account_head, '') != '' and parent in (%s)
|
||||||
order by account_head""" %
|
order by account_head""" %
|
||||||
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
||||||
|
|
||||||
columns = columns + [(account + ":Currency:120") for account in expense_accounts] + \
|
columns = columns + [(account + ":Currency:120") for account in expense_accounts] + \
|
||||||
["Net Total:Currency:120"] + [(account + ":Currency:120") for account in tax_accounts] + \
|
["Net Total:Currency:120"] + [(account + ":Currency:120") for account in tax_accounts] + \
|
||||||
@ -86,7 +93,7 @@ def get_conditions(filters):
|
|||||||
conditions = ""
|
conditions = ""
|
||||||
|
|
||||||
if filters.get("company"): conditions += " and company=%(company)s"
|
if filters.get("company"): conditions += " and company=%(company)s"
|
||||||
if filters.get("account"): conditions += " and account = %(account)s"
|
if filters.get("account"): conditions += " and credit_to = %(account)s"
|
||||||
|
|
||||||
if filters.get("from_date"): conditions += " and posting_date>=%(from_date)s"
|
if filters.get("from_date"): conditions += " and posting_date>=%(from_date)s"
|
||||||
if filters.get("to_date"): conditions += " and posting_date<=%(to_date)s"
|
if filters.get("to_date"): conditions += " and posting_date<=%(to_date)s"
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
import webnotes
|
import webnotes
|
||||||
from webnotes.utils import flt
|
from webnotes.utils import flt
|
||||||
|
from webnotes import msgprint, _
|
||||||
|
|
||||||
def execute(filters=None):
|
def execute(filters=None):
|
||||||
if not filters: filters = {}
|
if not filters: filters = {}
|
||||||
@ -24,6 +25,10 @@ def execute(filters=None):
|
|||||||
invoice_list = get_invoices(filters)
|
invoice_list = get_invoices(filters)
|
||||||
columns, income_accounts, tax_accounts = get_columns(invoice_list)
|
columns, income_accounts, tax_accounts = get_columns(invoice_list)
|
||||||
|
|
||||||
|
if not invoice_list:
|
||||||
|
msgprint(_("No record found"))
|
||||||
|
return columns, invoice_list
|
||||||
|
|
||||||
invoice_income_map = get_invoice_income_map(invoice_list)
|
invoice_income_map = get_invoice_income_map(invoice_list)
|
||||||
invoice_tax_map = get_invoice_tax_map(invoice_list)
|
invoice_tax_map = get_invoice_tax_map(invoice_list)
|
||||||
|
|
||||||
@ -69,15 +74,17 @@ def get_columns(invoice_list):
|
|||||||
"Remarks::150", "Sales Order:Link/Sales Order:100", "Delivery Note:Link/Delivery Note:100"
|
"Remarks::150", "Sales Order:Link/Sales Order:100", "Delivery Note:Link/Delivery Note:100"
|
||||||
]
|
]
|
||||||
|
|
||||||
income_accounts = webnotes.conn.sql_list("""select distinct income_account
|
income_accounts = tax_accounts = []
|
||||||
from `tabSales Invoice Item` where docstatus = 1 and parent in (%s)
|
if invoice_list:
|
||||||
order by income_account""" %
|
income_accounts = webnotes.conn.sql_list("""select distinct income_account
|
||||||
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
from `tabSales Invoice Item` where docstatus = 1 and parent in (%s)
|
||||||
|
order by income_account""" %
|
||||||
|
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
||||||
|
|
||||||
tax_accounts = webnotes.conn.sql_list("""select distinct account_head
|
tax_accounts = webnotes.conn.sql_list("""select distinct account_head
|
||||||
from `tabSales Taxes and Charges` where parenttype = 'Sales Invoice'
|
from `tabSales Taxes and Charges` where parenttype = 'Sales Invoice'
|
||||||
and docstatus = 1 and parent in (%s) order by account_head""" %
|
and docstatus = 1 and parent in (%s) order by account_head""" %
|
||||||
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
', '.join(['%s']*len(invoice_list)), tuple([inv.name for inv in invoice_list]))
|
||||||
|
|
||||||
columns = columns + [(account + ":Currency:120") for account in income_accounts] + \
|
columns = columns + [(account + ":Currency:120") for account in income_accounts] + \
|
||||||
["Net Total:Currency:120"] + [(account + ":Currency:120") for account in tax_accounts] + \
|
["Net Total:Currency:120"] + [(account + ":Currency:120") for account in tax_accounts] + \
|
||||||
@ -89,19 +96,19 @@ def get_conditions(filters):
|
|||||||
conditions = ""
|
conditions = ""
|
||||||
|
|
||||||
if filters.get("company"): conditions += " and company=%(company)s"
|
if filters.get("company"): conditions += " and company=%(company)s"
|
||||||
if filters.get("account"): conditions += " and account = %(account)s"
|
if filters.get("account"): conditions += " and debit_to = %(account)s"
|
||||||
|
|
||||||
if filters.get("from_date"): conditions += " and posting_date>=%(from_date)s"
|
if filters.get("from_date"): conditions += " and posting_date >= %(from_date)s"
|
||||||
if filters.get("to_date"): conditions += " and posting_date<=%(to_date)s"
|
if filters.get("to_date"): conditions += " and posting_date <= %(to_date)s"
|
||||||
|
|
||||||
return conditions
|
return conditions
|
||||||
|
|
||||||
def get_invoices(filters):
|
def get_invoices(filters):
|
||||||
conditions = get_conditions(filters)
|
conditions = get_conditions(filters)
|
||||||
return webnotes.conn.sql("""select name, posting_date, debit_to, project_name, customer,
|
return webnotes.conn.sql("""select name, posting_date, debit_to, project_name, customer,
|
||||||
remarks, net_total, other_charges_total, grand_total
|
remarks, net_total, other_charges_total, grand_total from `tabSales Invoice`
|
||||||
from `tabSales Invoice` where docstatus = 1 %s
|
where docstatus = 1 %s order by posting_date desc, name desc""" %
|
||||||
order by posting_date desc, name desc""" % conditions, filters, as_dict=1)
|
conditions, filters, as_dict=1)
|
||||||
|
|
||||||
def get_invoice_income_map(invoice_list):
|
def get_invoice_income_map(invoice_list):
|
||||||
income_details = webnotes.conn.sql("""select parent, income_account, sum(amount) as amount
|
income_details = webnotes.conn.sql("""select parent, income_account, sum(amount) as amount
|
||||||
|
Loading…
Reference in New Issue
Block a user