Merge branch 'develop'
This commit is contained in:
commit
f69b79fd16
@ -1,2 +1,2 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
__version__ = '6.21.4'
|
__version__ = '6.21.5'
|
||||||
|
@ -356,18 +356,20 @@ class JournalEntry(AccountsController):
|
|||||||
def set_print_format_fields(self):
|
def set_print_format_fields(self):
|
||||||
total_amount = 0.0
|
total_amount = 0.0
|
||||||
bank_account_currency = None
|
bank_account_currency = None
|
||||||
self.pay_to_recd_from = None
|
pay_to_recd_from = None
|
||||||
for d in self.get('accounts'):
|
for d in self.get('accounts'):
|
||||||
if d.party_type and d.party:
|
if d.party_type and d.party:
|
||||||
if not self.pay_to_recd_from:
|
if not pay_to_recd_from:
|
||||||
self.pay_to_recd_from = frappe.db.get_value(d.party_type, d.party,
|
pay_to_recd_from = frappe.db.get_value(d.party_type, d.party,
|
||||||
"customer_name" if d.party_type=="Customer" else "supplier_name")
|
"customer_name" if d.party_type=="Customer" else "supplier_name")
|
||||||
|
|
||||||
elif frappe.db.get_value("Account", d.account, "account_type") in ["Bank", "Cash"]:
|
elif frappe.db.get_value("Account", d.account, "account_type") in ["Bank", "Cash"]:
|
||||||
total_amount += (d.debit_in_account_currency or d.credit_in_account_currency)
|
total_amount += (d.debit_in_account_currency or d.credit_in_account_currency)
|
||||||
bank_account_currency = d.account_currency
|
bank_account_currency = d.account_currency
|
||||||
|
|
||||||
if not self.pay_to_recd_from:
|
if pay_to_recd_from:
|
||||||
|
self.pay_to_recd_from = pay_to_recd_from
|
||||||
|
else:
|
||||||
total_amount = 0
|
total_amount = 0
|
||||||
|
|
||||||
self.set_total_amount(total_amount, bank_account_currency)
|
self.set_total_amount(total_amount, bank_account_currency)
|
||||||
|
@ -7,7 +7,7 @@ app_publisher = "Frappe Technologies Pvt. Ltd."
|
|||||||
app_description = """ERP made simple"""
|
app_description = """ERP made simple"""
|
||||||
app_icon = "icon-th"
|
app_icon = "icon-th"
|
||||||
app_color = "#e74c3c"
|
app_color = "#e74c3c"
|
||||||
app_version = "6.21.4"
|
app_version = "6.21.5"
|
||||||
app_email = "info@erpnext.com"
|
app_email = "info@erpnext.com"
|
||||||
app_license = "GNU General Public License (v3)"
|
app_license = "GNU General Public License (v3)"
|
||||||
source_link = "https://github.com/frappe/erpnext"
|
source_link = "https://github.com/frappe/erpnext"
|
||||||
|
@ -238,6 +238,10 @@ erpnext.pos.PointOfSale = Class.extend({
|
|||||||
},
|
},
|
||||||
refresh_fields: function() {
|
refresh_fields: function() {
|
||||||
this.party_field.set_input(this.frm.doc[this.party.toLowerCase()]);
|
this.party_field.set_input(this.frm.doc[this.party.toLowerCase()]);
|
||||||
|
this.party_field.frm = this.frm;
|
||||||
|
this.party_field.doctype = this.frm.doctype;
|
||||||
|
this.party_field.docname = this.frm.docname;
|
||||||
|
|
||||||
this.wrapper.find('input.discount-percentage').val(this.frm.doc.additional_discount_percentage);
|
this.wrapper.find('input.discount-percentage').val(this.frm.doc.additional_discount_percentage);
|
||||||
this.wrapper.find('input.discount-amount').val(this.frm.doc.discount_amount);
|
this.wrapper.find('input.discount-amount').val(this.frm.doc.discount_amount);
|
||||||
|
|
||||||
|
@ -14,14 +14,12 @@ def execute(filters=None):
|
|||||||
iwb_map = get_item_warehouse_map(filters)
|
iwb_map = get_item_warehouse_map(filters)
|
||||||
|
|
||||||
data = []
|
data = []
|
||||||
for company in sorted(iwb_map):
|
for (company, item, warehouse) in sorted(iwb_map):
|
||||||
for item in sorted(iwb_map[company]):
|
qty_dict = iwb_map[(company, item, warehouse)]
|
||||||
for wh in sorted(iwb_map[company][item]):
|
|
||||||
qty_dict = iwb_map[company][item][wh]
|
|
||||||
data.append([item, item_map[item]["item_name"],
|
data.append([item, item_map[item]["item_name"],
|
||||||
item_map[item]["item_group"],
|
item_map[item]["item_group"],
|
||||||
item_map[item]["brand"],
|
item_map[item]["brand"],
|
||||||
item_map[item]["description"], wh,
|
item_map[item]["description"], warehouse,
|
||||||
item_map[item]["stock_uom"], qty_dict.opening_qty,
|
item_map[item]["stock_uom"], qty_dict.opening_qty,
|
||||||
qty_dict.opening_val, qty_dict.in_qty,
|
qty_dict.opening_val, qty_dict.in_qty,
|
||||||
qty_dict.in_val, qty_dict.out_qty,
|
qty_dict.in_val, qty_dict.out_qty,
|
||||||
@ -63,7 +61,7 @@ def get_conditions(filters):
|
|||||||
frappe.throw(_("'From Date' is required"))
|
frappe.throw(_("'From Date' is required"))
|
||||||
|
|
||||||
if filters.get("to_date"):
|
if filters.get("to_date"):
|
||||||
conditions += " and posting_date <= '%s'" % filters["to_date"]
|
conditions += " and posting_date <= '%s'" % frappe.db.escape(filters["to_date"])
|
||||||
else:
|
else:
|
||||||
frappe.throw(_("'To Date' is required"))
|
frappe.throw(_("'To Date' is required"))
|
||||||
|
|
||||||
@ -77,24 +75,29 @@ def get_stock_ledger_entries(filters):
|
|||||||
conditions = get_conditions(filters)
|
conditions = get_conditions(filters)
|
||||||
return frappe.db.sql("""select item_code, warehouse, posting_date, actual_qty, valuation_rate,
|
return frappe.db.sql("""select item_code, warehouse, posting_date, actual_qty, valuation_rate,
|
||||||
company, voucher_type, qty_after_transaction, stock_value_difference
|
company, voucher_type, qty_after_transaction, stock_value_difference
|
||||||
from `tabStock Ledger Entry`
|
from `tabStock Ledger Entry` force index (posting_sort_index)
|
||||||
where docstatus < 2 %s order by posting_date, posting_time, name""" %
|
where docstatus < 2 %s order by posting_date, posting_time, name""" %
|
||||||
conditions, as_dict=1)
|
conditions, as_dict=1)
|
||||||
|
|
||||||
def get_item_warehouse_map(filters):
|
def get_item_warehouse_map(filters):
|
||||||
sle = get_stock_ledger_entries(filters)
|
|
||||||
iwb_map = {}
|
iwb_map = {}
|
||||||
|
from_date = getdate(filters["from_date"])
|
||||||
|
to_date = getdate(filters["to_date"])
|
||||||
|
|
||||||
|
sle = get_stock_ledger_entries(filters)
|
||||||
|
|
||||||
for d in sle:
|
for d in sle:
|
||||||
iwb_map.setdefault(d.company, {}).setdefault(d.item_code, {}).\
|
key = (d.company, d.item_code, d.warehouse)
|
||||||
setdefault(d.warehouse, frappe._dict({\
|
if key not in iwb_map:
|
||||||
|
iwb_map[key] = frappe._dict({
|
||||||
"opening_qty": 0.0, "opening_val": 0.0,
|
"opening_qty": 0.0, "opening_val": 0.0,
|
||||||
"in_qty": 0.0, "in_val": 0.0,
|
"in_qty": 0.0, "in_val": 0.0,
|
||||||
"out_qty": 0.0, "out_val": 0.0,
|
"out_qty": 0.0, "out_val": 0.0,
|
||||||
"bal_qty": 0.0, "bal_val": 0.0,
|
"bal_qty": 0.0, "bal_val": 0.0,
|
||||||
"val_rate": 0.0, "uom": None
|
"val_rate": 0.0, "uom": None
|
||||||
}))
|
})
|
||||||
qty_dict = iwb_map[d.company][d.item_code][d.warehouse]
|
|
||||||
|
qty_dict = iwb_map[(d.company, d.item_code, d.warehouse)]
|
||||||
|
|
||||||
if d.voucher_type == "Stock Reconciliation":
|
if d.voucher_type == "Stock Reconciliation":
|
||||||
qty_diff = flt(d.qty_after_transaction) - qty_dict.bal_qty
|
qty_diff = flt(d.qty_after_transaction) - qty_dict.bal_qty
|
||||||
@ -103,10 +106,11 @@ def get_item_warehouse_map(filters):
|
|||||||
|
|
||||||
value_diff = flt(d.stock_value_difference)
|
value_diff = flt(d.stock_value_difference)
|
||||||
|
|
||||||
if d.posting_date < getdate(filters["from_date"]):
|
if d.posting_date < from_date:
|
||||||
qty_dict.opening_qty += qty_diff
|
qty_dict.opening_qty += qty_diff
|
||||||
qty_dict.opening_val += value_diff
|
qty_dict.opening_val += value_diff
|
||||||
elif d.posting_date >= getdate(filters["from_date"]) and d.posting_date <= getdate(filters["to_date"]):
|
|
||||||
|
elif d.posting_date >= from_date and d.posting_date <= to_date:
|
||||||
if qty_diff > 0:
|
if qty_diff > 0:
|
||||||
qty_dict.in_qty += qty_diff
|
qty_dict.in_qty += qty_diff
|
||||||
qty_dict.in_val += value_diff
|
qty_dict.in_val += value_diff
|
||||||
|
2
setup.py
2
setup.py
@ -1,7 +1,7 @@
|
|||||||
from setuptools import setup, find_packages
|
from setuptools import setup, find_packages
|
||||||
from pip.req import parse_requirements
|
from pip.req import parse_requirements
|
||||||
|
|
||||||
version = "6.21.4"
|
version = "6.21.5"
|
||||||
requirements = parse_requirements("requirements.txt", session="")
|
requirements = parse_requirements("requirements.txt", session="")
|
||||||
|
|
||||||
setup(
|
setup(
|
||||||
|
Loading…
x
Reference in New Issue
Block a user