Merge branch 'develop' into dev-serial-no-statuses
This commit is contained in:
		
						commit
						786d7bd3d4
					
				| @ -5,7 +5,7 @@ import frappe | ||||
| from erpnext.hooks import regional_overrides | ||||
| from frappe.utils import getdate | ||||
| 
 | ||||
| __version__ = '12.1.3' | ||||
| __version__ = '12.1.4' | ||||
| 
 | ||||
| def get_default_company(user=None): | ||||
| 	'''Get default company for user''' | ||||
|  | ||||
| @ -9,12 +9,11 @@ def get_data(): | ||||
| 		'non_standard_fieldnames': { | ||||
| 			'Customer': 'default_bank_account', | ||||
| 			'Supplier': 'default_bank_account', | ||||
| 			'Journal Entry': 'bank_account_no' | ||||
| 		}, | ||||
| 		'transactions': [ | ||||
| 			{ | ||||
| 				'label': _('Payments'), | ||||
| 				'items': ['Payment Entry', 'Payment Request', 'Payment Order'] | ||||
| 				'items': ['Payment Entry', 'Payment Request', 'Payment Order', 'Payroll Entry'] | ||||
| 			}, | ||||
| 			{ | ||||
| 				'label': _('Party'), | ||||
|  | ||||
| @ -7,7 +7,7 @@ frappe.provide("erpnext.journal_entry"); | ||||
| 
 | ||||
| frappe.ui.form.on("Journal Entry", { | ||||
| 	setup: function(frm) { | ||||
| 		frm.add_fetch("bank_account_no", "account", "account"); | ||||
| 		frm.add_fetch("bank_account", "account", "account"); | ||||
| 	}, | ||||
| 
 | ||||
| 	refresh: function(frm) { | ||||
|  | ||||
| @ -10,7 +10,7 @@ | ||||
|   "account_type", | ||||
|   "balance", | ||||
|   "col_break1", | ||||
|   "bank_account_no", | ||||
|   "bank_account", | ||||
|   "party_type", | ||||
|   "party", | ||||
|   "party_balance", | ||||
| @ -89,12 +89,6 @@ | ||||
|    "fieldname": "col_break1", | ||||
|    "fieldtype": "Column Break" | ||||
|   }, | ||||
|   { | ||||
|    "fieldname": "bank_account_no", | ||||
|    "fieldtype": "Link", | ||||
|    "label": "Bank Account No", | ||||
|    "options": "Bank Account" | ||||
|   }, | ||||
|   { | ||||
|    "fieldname": "party_type", | ||||
|    "fieldtype": "Link", | ||||
| @ -266,11 +260,17 @@ | ||||
|   { | ||||
|    "fieldname": "dimension_col_break", | ||||
|    "fieldtype": "Column Break" | ||||
|   }, | ||||
|   { | ||||
|    "fieldname": "bank_account", | ||||
|    "fieldtype": "Link", | ||||
|    "label": "Bank Account", | ||||
|    "options": "Bank Account" | ||||
|   } | ||||
|  ], | ||||
|  "idx": 1, | ||||
|  "istable": 1, | ||||
|  "modified": "2019-07-16 17:12:08.238334", | ||||
|  "modified": "2019-09-12 12:16:17.588399", | ||||
|  "modified_by": "Administrator", | ||||
|  "module": "Accounts", | ||||
|  "name": "Journal Entry Account", | ||||
|  | ||||
| @ -12,7 +12,7 @@ from frappe.utils import (add_days, getdate, formatdate, date_diff, | ||||
| from frappe.contacts.doctype.address.address import (get_address_display, | ||||
| 	get_default_address, get_company_address) | ||||
| from frappe.contacts.doctype.contact.contact import get_contact_details, get_default_contact | ||||
| from erpnext.exceptions import PartyFrozen, PartyDisabled, InvalidAccountCurrency | ||||
| from erpnext.exceptions import PartyFrozen, InvalidAccountCurrency | ||||
| from erpnext.accounts.utils import get_fiscal_year | ||||
| from erpnext import get_company_currency | ||||
| 
 | ||||
| @ -446,9 +446,7 @@ def validate_party_frozen_disabled(party_type, party_name): | ||||
| 	if party_type and party_name: | ||||
| 		if party_type in ("Customer", "Supplier"): | ||||
| 			party = frappe.get_cached_value(party_type, party_name, ["is_frozen", "disabled"], as_dict=True) | ||||
| 			if party.disabled: | ||||
| 				frappe.throw(_("{0} {1} is disabled").format(party_type, party_name), PartyDisabled) | ||||
| 			elif party.get("is_frozen"): | ||||
| 			if party.get("is_frozen"): | ||||
| 				frozen_accounts_modifier = frappe.db.get_single_value( 'Accounts Settings', 'frozen_accounts_modifier') | ||||
| 				if not frozen_accounts_modifier in frappe.get_roles(): | ||||
| 					frappe.throw(_("{0} {1} is frozen").format(party_type, party_name), PartyFrozen) | ||||
|  | ||||
| @ -446,6 +446,10 @@ class ReceivablePayableReport(object): | ||||
| 
 | ||||
| 		row.age = (getdate(self.age_as_on) - getdate(entry_date)).days or 0 | ||||
| 		index = None | ||||
| 
 | ||||
| 		if not (self.filters.range1 and self.filters.range2 and self.filters.range3 and self.filters.range4): | ||||
| 			self.filters.range1, self.filters.range2, self.filters.range3, self.filters.range4 = 30, 60, 90, 120 | ||||
| 
 | ||||
| 		for i, days in enumerate([self.filters.range1, self.filters.range2, self.filters.range3, self.filters.range4]): | ||||
| 			if row.age <= days: | ||||
| 				index = i | ||||
|  | ||||
| @ -17,7 +17,7 @@ def _execute(filters=None, additional_table_columns=None, additional_query_colum | ||||
| 	filters.update({"from_date": filters.get("date_range") and filters.get("date_range")[0], "to_date": filters.get("date_range") and filters.get("date_range")[1]}) | ||||
| 	columns = get_columns(additional_table_columns) | ||||
| 
 | ||||
| 	company_currency = erpnext.get_company_currency(filters.get('company')) | ||||
| 	company_currency = frappe.get_cached_value('Company',  filters.get("company"),  "default_currency") | ||||
| 
 | ||||
| 	item_list = get_items(filters, additional_query_columns) | ||||
| 	if item_list: | ||||
|  | ||||
| @ -4,11 +4,14 @@ | ||||
| from __future__ import unicode_literals | ||||
| import frappe | ||||
| from frappe import _ | ||||
| from erpnext.accounts.report.accounts_receivable.accounts_receivable import get_ageing_data | ||||
| from erpnext.accounts.report.accounts_receivable.accounts_receivable import ReceivablePayableReport | ||||
| from frappe.utils import getdate, flt | ||||
| 
 | ||||
| 
 | ||||
| def execute(filters=None): | ||||
| 	if not filters: filters = {} | ||||
| 	if not filters: | ||||
| 		filters = {} | ||||
| 
 | ||||
| 	validate_filters(filters) | ||||
| 
 | ||||
| 	columns = get_columns(filters) | ||||
| @ -24,13 +27,23 @@ def execute(filters=None): | ||||
| 		else: | ||||
| 			payment_amount = flt(d.credit) or -1 * flt(d.debit) | ||||
| 
 | ||||
| 		row = [d.voucher_type, d.voucher_no, d.party_type, d.party, d.posting_date, d.against_voucher, | ||||
| 			invoice.posting_date, invoice.due_date, d.debit, d.credit, d.remarks] | ||||
| 		d.update({ | ||||
| 			"range1": 0, | ||||
| 			"range2": 0, | ||||
| 			"range3": 0, | ||||
| 			"range4": 0, | ||||
| 			"outstanding": payment_amount | ||||
| 		}) | ||||
| 
 | ||||
| 		if d.against_voucher: | ||||
| 			row += get_ageing_data(30, 60, 90, 120, d.posting_date, invoice.posting_date, payment_amount) | ||||
| 		else: | ||||
| 			row += ["", "", "", "", ""] | ||||
| 			ReceivablePayableReport(filters).get_ageing_data(invoice.posting_date, d) | ||||
| 
 | ||||
| 		row = [ | ||||
| 			d.voucher_type, d.voucher_no, d.party_type, d.party, d.posting_date, d.against_voucher, | ||||
| 			invoice.posting_date, invoice.due_date, d.debit, d.credit, d.remarks,  | ||||
| 			d.age, d.range1, d.range2, d.range3, d.range4 | ||||
| 		] | ||||
| 
 | ||||
| 		if invoice.due_date: | ||||
| 			row.append((getdate(d.posting_date) - getdate(invoice.due_date)).days or 0) | ||||
| 
 | ||||
|  | ||||
| @ -68,7 +68,8 @@ def _execute(filters, additional_table_columns=None, additional_query_columns=No | ||||
| 		total_tax = 0 | ||||
| 		for tax_acc in tax_accounts: | ||||
| 			if tax_acc not in income_accounts: | ||||
| 				tax_amount = flt(invoice_tax_map.get(inv.name, {}).get(tax_acc)) | ||||
| 				tax_amount_precision = get_field_precision(frappe.get_meta("Sales Taxes and Charges").get_field("tax_amount"), currency=company_currency) or 2 | ||||
| 				tax_amount = flt(invoice_tax_map.get(inv.name, {}).get(tax_acc), tax_amount_precision) | ||||
| 				total_tax += tax_amount | ||||
| 				row.append(tax_amount) | ||||
| 
 | ||||
|  | ||||
| @ -6,8 +6,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",   | ||||
|  "letter_head": "Capital Traders",  | ||||
|  "modified": "2018-12-12 05:10:02.987274",  | ||||
|  "modified": "2019-02-12 05:10:02.987274",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Accounts",  | ||||
|  "name": "Supplier Ledger Summary",  | ||||
|  | ||||
| @ -6,8 +6,7 @@ | ||||
|  "doctype": "Report", | ||||
|  "idx": 0, | ||||
|  "is_standard": "Yes", | ||||
|  "letter_head": "Gadgets International", | ||||
|  "modified": "2018-08-21 11:25:00.551823", | ||||
|  "modified": "2018-09-21 11:25:00.551823", | ||||
|  "modified_by": "Administrator", | ||||
|  "module": "Accounts", | ||||
|  "name": "TDS Computation Summary", | ||||
|  | ||||
| @ -6,8 +6,7 @@ | ||||
|  "doctype": "Report", | ||||
|  "idx": 0, | ||||
|  "is_standard": "Yes", | ||||
|  "letter_head": "Gadgets International", | ||||
|  "modified": "2018-08-21 11:33:40.804532", | ||||
|  "modified": "2019-09-24 13:46:16.473711", | ||||
|  "modified_by": "Administrator", | ||||
|  "module": "Accounts", | ||||
|  "name": "TDS Payable Monthly", | ||||
|  | ||||
| @ -57,7 +57,7 @@ def calculate_next_due_date(periodicity, start_date = None, end_date = None, las | ||||
| 	if not start_date and not last_completion_date: | ||||
| 		start_date = frappe.utils.now() | ||||
| 
 | ||||
| 	if last_completion_date and (last_completion_date > start_date or not start_date): | ||||
| 	if last_completion_date and ((start_date and last_completion_date > start_date) or not start_date): | ||||
| 		start_date = last_completion_date | ||||
| 	if periodicity == 'Daily': | ||||
| 		next_due_date = add_days(start_date, 1) | ||||
| @ -71,10 +71,11 @@ def calculate_next_due_date(periodicity, start_date = None, end_date = None, las | ||||
| 		next_due_date = add_years(start_date, 2) | ||||
| 	if periodicity == 'Quarterly': | ||||
| 		next_due_date = add_months(start_date, 3) | ||||
| 	if end_date and (start_date >= end_date or last_completion_date >= end_date or next_due_date): | ||||
| 	if end_date and ((start_date and start_date >= end_date) or (last_completion_date and last_completion_date >= end_date) or next_due_date): | ||||
| 		next_due_date = "" | ||||
| 	return next_due_date | ||||
| 
 | ||||
| 
 | ||||
| def update_maintenance_log(asset_maintenance, item_code, item_name, task): | ||||
| 	asset_maintenance_log = frappe.get_value("Asset Maintenance Log", {"asset_maintenance": asset_maintenance, | ||||
| 		"task": task.maintenance_task, "maintenance_status": ('in',['Planned','Overdue'])}) | ||||
|  | ||||
| @ -10,7 +10,8 @@ frappe.ui.form.on("Purchase Order", { | ||||
| 		frm.custom_make_buttons = { | ||||
| 			'Purchase Receipt': 'Receipt', | ||||
| 			'Purchase Invoice': 'Invoice', | ||||
| 			'Stock Entry': 'Material to Supplier' | ||||
| 			'Stock Entry': 'Material to Supplier', | ||||
| 			'Payment Entry': 'Payment' | ||||
| 		} | ||||
| 
 | ||||
| 		frm.set_query("reserve_warehouse", "supplied_items", function() { | ||||
| @ -196,10 +197,10 @@ erpnext.buying.PurchaseOrderController = erpnext.buying.BuyingController.extend( | ||||
| 		if(items.length >= 1){ | ||||
| 			me.raw_material_data = []; | ||||
| 			me.show_dialog = 1; | ||||
| 			let title = ""; | ||||
| 			let title = __('Transfer Material to Supplier'); | ||||
| 			let fields = [ | ||||
| 			{fieldtype:'Section Break', label: __('Raw Materials')}, | ||||
| 			{fieldname: 'sub_con_rm_items', fieldtype: 'Table', | ||||
| 			{fieldname: 'sub_con_rm_items', fieldtype: 'Table', label: __('Items'), | ||||
| 				fields: [ | ||||
| 					{ | ||||
| 						fieldtype:'Data', | ||||
| @ -271,7 +272,7 @@ erpnext.buying.PurchaseOrderController = erpnext.buying.BuyingController.extend( | ||||
| 						'item_code': item.main_item_code, | ||||
| 						'rm_item_code': item.rm_item_code, | ||||
| 						'item_name': item.rm_item_code, | ||||
| 						'qty': item.required_qty, | ||||
| 						'qty': item.required_qty - item.supplied_qty, | ||||
| 						'warehouse':item.reserve_warehouse, | ||||
| 						'rate':item.rate, | ||||
| 						'amount':item.amount, | ||||
|  | ||||
| @ -5,7 +5,6 @@ from __future__ import unicode_literals | ||||
| 
 | ||||
| import frappe, unittest | ||||
| from erpnext.accounts.party import get_due_date | ||||
| from erpnext.exceptions import PartyDisabled | ||||
| from frappe.test_runner import make_test_records | ||||
| 
 | ||||
| test_dependencies = ['Payment Term', 'Payment Terms Template'] | ||||
| @ -71,7 +70,7 @@ class TestSupplier(unittest.TestCase): | ||||
| 
 | ||||
|         po = create_purchase_order(do_not_save=True) | ||||
| 
 | ||||
|         self.assertRaises(PartyDisabled, po.save) | ||||
|         self.assertRaises(frappe.ValidationError, po.save) | ||||
| 
 | ||||
|         frappe.db.set_value("Supplier", "_Test Supplier", "disabled", 0) | ||||
| 
 | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "",  | ||||
|  "modified": "2017-04-17 00:20:27.248275",  | ||||
|  "modified": "2019-04-17 00:20:27.248275",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "CRM",  | ||||
|  "name": "Campaign Efficiency",  | ||||
|  | ||||
| @ -6,8 +6,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "",  | ||||
|  "modified": "2018-09-17 14:40:52.035394",  | ||||
|  "modified": "2019-09-19 14:40:52.035394",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "CRM",  | ||||
|  "name": "Lead Conversion Time",  | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Shishuvan Secondary School",  | ||||
|  "modified": "2018-02-08 15:11:35.339434",  | ||||
|  "modified": "2019-02-08 15:11:35.339434",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Education",  | ||||
|  "name": "Final Assessment Grades",  | ||||
|  | ||||
| @ -5,4 +5,3 @@ import frappe | ||||
| class PartyFrozen(frappe.ValidationError): pass | ||||
| class InvalidAccountCurrency(frappe.ValidationError): pass | ||||
| class InvalidCurrency(frappe.ValidationError): pass | ||||
| class PartyDisabled(frappe.ValidationError):pass | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -37,8 +37,9 @@ | ||||
|   "cost_center", | ||||
|   "account", | ||||
|   "payment_account", | ||||
|   "section_break2", | ||||
|   "amended_from", | ||||
|   "column_break_33", | ||||
|   "bank_account", | ||||
|   "salary_slips_created", | ||||
|   "salary_slips_submitted" | ||||
|  ], | ||||
| @ -206,15 +207,12 @@ | ||||
|   { | ||||
|    "allow_on_submit": 1, | ||||
|    "description": "Select Payment Account to make Bank Entry", | ||||
|    "fetch_from": "bank_account.account", | ||||
|    "fieldname": "payment_account", | ||||
|    "fieldtype": "Link", | ||||
|    "label": "Payment Account", | ||||
|    "options": "Account" | ||||
|   }, | ||||
|   { | ||||
|    "fieldname": "section_break2", | ||||
|    "fieldtype": "Section Break" | ||||
|   }, | ||||
|   { | ||||
|    "fieldname": "amended_from", | ||||
|    "fieldtype": "Link", | ||||
| @ -248,11 +246,21 @@ | ||||
|   { | ||||
|    "fieldname": "dimension_col_break", | ||||
|    "fieldtype": "Column Break" | ||||
|   }, | ||||
|   { | ||||
|    "fieldname": "bank_account", | ||||
|    "fieldtype": "Link", | ||||
|    "label": "Bank Account", | ||||
|    "options": "Bank Account" | ||||
|   }, | ||||
|   { | ||||
|    "fieldname": "column_break_33", | ||||
|    "fieldtype": "Column Break" | ||||
|   } | ||||
|  ], | ||||
|  "icon": "fa fa-cog", | ||||
|  "is_submittable": 1, | ||||
|  "modified": "2019-05-25 22:47:49.977955", | ||||
|  "modified": "2019-09-12 15:46:31.436381", | ||||
|  "modified_by": "Administrator", | ||||
|  "module": "HR", | ||||
|  "name": "Payroll Entry", | ||||
|  | ||||
| @ -39,7 +39,7 @@ class PayrollEntry(Document): | ||||
| 			and for which salary structure exists | ||||
| 		""" | ||||
| 		cond = self.get_filter_condition() | ||||
| 		cond += self.get_joining_releiving_condition() | ||||
| 		cond += self.get_joining_relieving_condition() | ||||
| 
 | ||||
| 		condition = '' | ||||
| 		if self.payroll_frequency: | ||||
| @ -93,7 +93,7 @@ class PayrollEntry(Document): | ||||
| 
 | ||||
| 		return cond | ||||
| 
 | ||||
| 	def get_joining_releiving_condition(self): | ||||
| 	def get_joining_relieving_condition(self): | ||||
| 		cond = """ | ||||
| 			and ifnull(t1.date_of_joining, '0000-00-00') <= '%(end_date)s' | ||||
| 			and ifnull(t1.relieving_date, '2199-12-31') >= '%(start_date)s' | ||||
| @ -341,6 +341,7 @@ class PayrollEntry(Document): | ||||
| 		journal_entry.set("accounts", [ | ||||
| 			{ | ||||
| 				"account": self.payment_account, | ||||
| 				"bank_account": self.bank_account, | ||||
| 				"credit_in_account_currency": payment_amount | ||||
| 			}, | ||||
| 			{ | ||||
|  | ||||
| @ -60,8 +60,8 @@ def get_data(args): | ||||
| 			existing_attendance = {} | ||||
| 			if existing_attendance_records \ | ||||
| 				and tuple([getdate(date), employee.name]) in existing_attendance_records \ | ||||
| 				and getdate(employee.date_of_joining) >= getdate(date) \ | ||||
| 				and getdate(employee.relieving_date) <= getdate(date): | ||||
| 				and getdate(employee.date_of_joining) <= getdate(date) \ | ||||
| 				and getdate(employee.relieving_date) >= getdate(date): | ||||
| 					existing_attendance = existing_attendance_records[tuple([getdate(date), employee.name])] | ||||
| 			row = [ | ||||
| 				existing_attendance and existing_attendance.name or "", | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report", | ||||
|  "idx": 0, | ||||
|  "is_standard": "Yes", | ||||
|  "letter_head": "Gadgets International", | ||||
|  "modified": "2019-03-26 16:57:52.558895", | ||||
|  "modified": "2019-04-26 16:57:52.558895", | ||||
|  "modified_by": "Administrator", | ||||
|  "module": "HR", | ||||
|  "name": "Bank Remittance", | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report", | ||||
|  "idx": 0, | ||||
|  "is_standard": "Yes", | ||||
|  "letter_head": "sapcon-old", | ||||
|  "modified": "2019-09-05 11:18:06.209397", | ||||
|  "modified": "2019-09-06 11:18:06.209397", | ||||
|  "modified_by": "Administrator", | ||||
|  "module": "HR", | ||||
|  "name": "Employee Leave Balance Summary", | ||||
|  | ||||
| @ -105,7 +105,6 @@ class JobCard(Document): | ||||
| 		for_quantity, time_in_mins = 0, 0 | ||||
| 		from_time_list, to_time_list = [], [] | ||||
| 
 | ||||
| 
 | ||||
| 		for d in frappe.get_all('Job Card', | ||||
| 			filters = {'docstatus': 1, 'operation_id': self.operation_id}): | ||||
| 			doc = frappe.get_doc('Job Card', d.name) | ||||
| @ -125,8 +124,8 @@ class JobCard(Document): | ||||
| 				if data.name == self.operation_id: | ||||
| 					data.completed_qty = for_quantity | ||||
| 					data.actual_operation_time = time_in_mins | ||||
| 					data.actual_start_time = min(from_time_list) | ||||
| 					data.actual_end_time = max(to_time_list) | ||||
| 					data.actual_start_time = min(from_time_list) if from_time_list else None | ||||
| 					data.actual_end_time = max(to_time_list) if to_time_list else None | ||||
| 
 | ||||
| 			wo.flags.ignore_validate_update_after_submit = True | ||||
| 			wo.update_operation_status() | ||||
|  | ||||
| @ -6,8 +6,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Gadgets International",  | ||||
|  "modified": "2018-05-28 16:22:24.040106",  | ||||
|  "modified": "2018-06-28 16:22:24.040106",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Manufacturing",  | ||||
|  "name": "BOM Variance Report",  | ||||
|  | ||||
| @ -635,4 +635,5 @@ erpnext.patches.v12_0.remove_bank_remittance_custom_fields | ||||
| erpnext.patches.v12_0.generate_leave_ledger_entries | ||||
| erpnext.patches.v12_0.move_credit_limit_to_customer_credit_limit | ||||
| erpnext.patches.v12_0.add_variant_of_in_item_attribute_table | ||||
| erpnext.patches.v12_0.rename_bank_account_field_in_journal_entry_account | ||||
| erpnext.patches.v12_0.create_default_energy_point_rules | ||||
| @ -0,0 +1,17 @@ | ||||
| # Copyright (c) 2019, Frappe and Contributors | ||||
| # License: GNU General Public License v3. See license.txt | ||||
| 
 | ||||
| from __future__ import unicode_literals | ||||
| import frappe | ||||
| from frappe.model.utils.rename_field import rename_field | ||||
| 
 | ||||
| def execute(): | ||||
| 	''' Change the fieldname from bank_account_no to bank_account ''' | ||||
| 	if not frappe.get_meta("Journal Entry Account").has_field("bank_account"): | ||||
| 		frappe.reload_doc("Accounts", "doctype", "Journal Entry Account") | ||||
| 		update_journal_entry_account_fieldname() | ||||
| 
 | ||||
| def update_journal_entry_account_fieldname(): | ||||
| 	''' maps data from old field to the new field ''' | ||||
| 	if frappe.db.has_column('Journal Entry Account', 'bank_account_no'): | ||||
| 		rename_field("Journal Entry Account", "bank_account_no", "bank_account") | ||||
| @ -2,6 +2,7 @@ frappe.provide('frappe.ui.form'); | ||||
| 
 | ||||
| frappe.ui.form.CustomerQuickEntryForm = frappe.ui.form.QuickEntryForm.extend({ | ||||
| 	init: function(doctype, after_insert) { | ||||
| 		this.skip_redirect_on_error = true; | ||||
| 		this._super(doctype, after_insert); | ||||
| 	}, | ||||
| 
 | ||||
| @ -37,8 +38,7 @@ frappe.ui.form.CustomerQuickEntryForm = frappe.ui.form.QuickEntryForm.extend({ | ||||
| 		{ | ||||
| 			label: __("Address Line 1"), | ||||
| 			fieldname: "address_line1", | ||||
| 			fieldtype: "Data", | ||||
| 			reqd: 1 | ||||
| 			fieldtype: "Data" | ||||
| 		}, | ||||
| 		{ | ||||
| 			label: __("Address Line 2"), | ||||
| @ -56,8 +56,7 @@ frappe.ui.form.CustomerQuickEntryForm = frappe.ui.form.QuickEntryForm.extend({ | ||||
| 		{ | ||||
| 			label: __("City"), | ||||
| 			fieldname: "city", | ||||
| 			fieldtype: "Data", | ||||
| 			reqd: 1, | ||||
| 			fieldtype: "Data" | ||||
| 		}, | ||||
| 		{ | ||||
| 			label: __("State"), | ||||
| @ -68,8 +67,7 @@ frappe.ui.form.CustomerQuickEntryForm = frappe.ui.form.QuickEntryForm.extend({ | ||||
| 			label: __("Country"), | ||||
| 			fieldname: "country", | ||||
| 			fieldtype: "Link", | ||||
| 			options: "Country", | ||||
| 			reqd: 1 | ||||
| 			options: "Country" | ||||
| 		}, | ||||
| 		{ | ||||
| 			label: __("Customer POS Id"), | ||||
|  | ||||
| @ -6,8 +6,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Standard",  | ||||
|  "modified": "2018-04-26 12:59:38.603649",  | ||||
|  "modified": "2019-04-26 12:59:38.603649",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Regional",  | ||||
|  "name": "HSN-wise-summary of outward supplies",  | ||||
|  | ||||
| @ -357,6 +357,16 @@ def make_contact(args, is_primary_contact=1): | ||||
| 	return contact | ||||
| 
 | ||||
| def make_address(args, is_primary_address=1): | ||||
| 	reqd_fields = [] | ||||
| 	for field in ['city', 'country']: | ||||
| 		if not args.get(field): | ||||
| 			reqd_fields.append( '<li>' + field.title() + '</li>') | ||||
| 
 | ||||
| 	if reqd_fields: | ||||
| 		msg = _("Following fields are mandatory to create address:") | ||||
| 		frappe.throw("{0} <br><br> <ul>{1}</ul>".format(msg, '\n'.join(reqd_fields)), | ||||
| 			title = _("Missing Values Required")) | ||||
| 
 | ||||
| 	address = frappe.get_doc({ | ||||
| 		'doctype': 'Address', | ||||
| 		'address_title': args.get('name'), | ||||
|  | ||||
| @ -8,7 +8,7 @@ import unittest | ||||
| 
 | ||||
| from erpnext.accounts.party import get_due_date | ||||
| from frappe.test_runner import make_test_records | ||||
| from erpnext.exceptions import PartyFrozen, PartyDisabled | ||||
| from erpnext.exceptions import PartyFrozen | ||||
| from frappe.utils import flt | ||||
| from erpnext.selling.doctype.customer.customer import get_credit_limit, get_customer_outstanding | ||||
| from erpnext.tests.utils import create_test_contact_and_address | ||||
| @ -178,7 +178,7 @@ class TestCustomer(unittest.TestCase): | ||||
| 
 | ||||
| 		so = make_sales_order(do_not_save=True) | ||||
| 
 | ||||
| 		self.assertRaises(PartyDisabled, so.save) | ||||
| 		self.assertRaises(frappe.ValidationError, so.save) | ||||
| 
 | ||||
| 		frappe.db.set_value("Customer", "_Test Customer", "disabled", 0) | ||||
| 
 | ||||
|  | ||||
| @ -11,7 +11,8 @@ frappe.ui.form.on("Sales Order", { | ||||
| 			'Sales Invoice': 'Invoice', | ||||
| 			'Material Request': 'Material Request', | ||||
| 			'Purchase Order': 'Purchase Order', | ||||
| 			'Project': 'Project' | ||||
| 			'Project': 'Project', | ||||
| 			'Payment Entry': "Payment" | ||||
| 		} | ||||
| 		frm.add_fetch('customer', 'tax_id', 'tax_id'); | ||||
| 
 | ||||
|  | ||||
| @ -60,7 +60,7 @@ def get_details(filters): | ||||
| 	conditions = "" | ||||
| 
 | ||||
| 	if filters.get("customer"): | ||||
| 		conditions += " AND c.name = " + filters.get("customer") | ||||
| 		conditions += " AND c.name = '" + filters.get("customer") + "'" | ||||
| 
 | ||||
| 	return frappe.db.sql("""SELECT | ||||
| 			c.name, c.customer_name, | ||||
| @ -69,6 +69,6 @@ def get_details(filters): | ||||
| 		FROM `tabCustomer` c, `tabCustomer Credit Limit` ccl | ||||
| 		WHERE | ||||
| 			c.name = ccl.parent | ||||
| 			AND ccl.company = %s | ||||
| 			{0} | ||||
| 	""".format(conditions), (filters.get("company")), as_dict=1) #nosec | ||||
| 			AND ccl.company = '{0}' | ||||
| 			{1} | ||||
| 	""".format( filters.get("company"),conditions), as_dict=1) #nosec | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Delta9",  | ||||
|  "modified": "2019-06-12 03:25:36.263179",  | ||||
|  "modified": "2019-06-14 03:25:36.263179",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Selling",  | ||||
|  "name": "Customer-wise Item Price",  | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Gadgets International",  | ||||
|  "modified": "2019-03-15 15:22:15.012318",  | ||||
|  "modified": "2019-04-15 15:22:15.012318",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Selling",  | ||||
|  "name": "Sales Partner Commission Summary",  | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Gadgets International",  | ||||
|  "modified": "2019-03-25 18:22:37.323995",  | ||||
|  "modified": "2019-04-25 18:22:37.323995",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Selling",  | ||||
|  "name": "Sales Partner Target Variance based on Item Group",  | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Gadgets International",  | ||||
|  "modified": "2019-03-25 18:15:09.920739",  | ||||
|  "modified": "2019-04-25 18:15:09.920739",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Selling",  | ||||
|  "name": "Sales Partner Transaction Summary",  | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Gadgets International",  | ||||
|  "modified": "2019-03-25 22:16:49.040998",  | ||||
|  "modified": "2019-04-25 22:16:49.040998",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Selling",  | ||||
|  "name": "Sales Person Target Variance Based On Item Group",  | ||||
|  | ||||
| @ -7,8 +7,7 @@ | ||||
|  "doctype": "Report",  | ||||
|  "idx": 0,  | ||||
|  "is_standard": "Yes",  | ||||
|  "letter_head": "Gadgets International",  | ||||
|  "modified": "2019-03-25 22:20:59.033199",  | ||||
|  "modified": "2019-04-25 22:20:59.033199",  | ||||
|  "modified_by": "Administrator",  | ||||
|  "module": "Selling",  | ||||
|  "name": "Territory Target Variance Based On Item Group",  | ||||
|  | ||||
| @ -234,7 +234,7 @@ erpnext.selling.SellingController = erpnext.TransactionController.extend({ | ||||
| 					args: { | ||||
| 						item_code: item.item_code, | ||||
| 						warehouse: item.warehouse, | ||||
| 						has_batch_no: has_batch_no, | ||||
| 						has_batch_no: has_batch_no || 0, | ||||
| 						stock_qty: item.stock_qty, | ||||
| 						serial_no: item.serial_no || "", | ||||
| 					}, | ||||
|  | ||||
| @ -15,12 +15,17 @@ class LandedCostVoucher(Document): | ||||
| 		for pr in self.get("purchase_receipts"): | ||||
| 			if pr.receipt_document_type and pr.receipt_document: | ||||
| 				pr_items = frappe.db.sql("""select pr_item.item_code, pr_item.description, | ||||
| 					pr_item.qty, pr_item.base_rate, pr_item.base_amount, pr_item.name, pr_item.cost_center | ||||
| 					pr_item.qty, pr_item.base_rate, pr_item.base_amount, pr_item.name, | ||||
| 					pr_item.cost_center, pr_item.asset | ||||
| 					from `tab{doctype} Item` pr_item where parent = %s | ||||
| 					and exists(select name from tabItem where name = pr_item.item_code and is_stock_item = 1) | ||||
| 					and exists(select name from tabItem | ||||
| 						where name = pr_item.item_code and (is_stock_item = 1 or is_fixed_asset=1)) | ||||
| 					""".format(doctype=pr.receipt_document_type), pr.receipt_document, as_dict=True) | ||||
| 
 | ||||
| 				for d in pr_items: | ||||
| 					if d.asset and frappe.db.get_value("Asset", d.asset, 'docstatus') == 1: | ||||
| 						continue | ||||
| 
 | ||||
| 					item = self.append("items") | ||||
| 					item.item_code = d.item_code | ||||
| 					item.description = d.description | ||||
|  | ||||
| @ -20,7 +20,7 @@ def get_product_bundle_items(item_code): | ||||
| 
 | ||||
| def get_packing_item_details(item, company): | ||||
| 	return frappe.db.sql(""" | ||||
| 		select i.item_name, i.description, i.stock_uom, id.default_warehouse | ||||
| 		select i.item_name, i.is_stock_item, i.description, i.stock_uom, id.default_warehouse | ||||
| 		from `tabItem` i LEFT JOIN `tabItem Default` id ON id.parent=i.name and id.company=%s | ||||
| 		where i.name = %s""", | ||||
| 		(company, item), as_dict = 1)[0] | ||||
| @ -53,7 +53,7 @@ def update_packing_list_item(doc, packing_item_code, qty, main_item_row, descrip | ||||
| 	if description and not pi.description: | ||||
| 		pi.description = description | ||||
| 	if not pi.warehouse: | ||||
| 		pi.warehouse = (main_item_row.warehouse if ((doc.get('is_pos') | ||||
| 		pi.warehouse = (main_item_row.warehouse if ((doc.get('is_pos') or item.is_stock_item \ | ||||
| 			or not item.default_warehouse) and main_item_row.warehouse) else item.default_warehouse) | ||||
| 
 | ||||
| 	if not pi.batch_no: | ||||
|  | ||||
| @ -15,6 +15,7 @@ from frappe.desk.notifications import clear_doctype_notifications | ||||
| from frappe.model.mapper import get_mapped_doc | ||||
| from erpnext.buying.utils import check_on_hold_or_closed_status | ||||
| from erpnext.assets.doctype.asset.asset import get_asset_account, is_cwip_accounting_disabled | ||||
| from erpnext.assets.doctype.asset_category.asset_category import get_asset_category_account | ||||
| from six import iteritems | ||||
| 
 | ||||
| form_grid_templates = { | ||||
| @ -278,8 +279,7 @@ class PurchaseReceipt(BuyingController): | ||||
| 					d.rejected_warehouse not in warehouse_with_no_account: | ||||
| 						warehouse_with_no_account.append(d.warehouse) | ||||
| 
 | ||||
| 		if not is_cwip_accounting_disabled(): | ||||
| 			self.get_asset_gl_entry(gl_entries) | ||||
| 		self.get_asset_gl_entry(gl_entries, expenses_included_in_valuation) | ||||
| 		# Cost center-wise amount breakup for other charges included for valuation | ||||
| 		valuation_tax = {} | ||||
| 		for tax in self.get("taxes"): | ||||
| @ -333,15 +333,24 @@ class PurchaseReceipt(BuyingController): | ||||
| 
 | ||||
| 		return process_gl_map(gl_entries) | ||||
| 
 | ||||
| 	def get_asset_gl_entry(self, gl_entries): | ||||
| 	def get_asset_gl_entry(self, gl_entries, expenses_included_in_valuation=None): | ||||
| 		arbnb_account, cwip_account = None, None | ||||
| 
 | ||||
| 		cwip_disabled = is_cwip_accounting_disabled() | ||||
| 
 | ||||
| 		if not expenses_included_in_valuation: | ||||
| 			expenses_included_in_valuation = self.get_company_default("expenses_included_in_valuation") | ||||
| 
 | ||||
| 		for d in self.get("items"): | ||||
| 			if d.is_fixed_asset: | ||||
| 			if d.is_fixed_asset and not (arbnb_account and cwip_account): | ||||
| 				arbnb_account = self.get_company_default("asset_received_but_not_billed") | ||||
| 
 | ||||
| 				# CWIP entry | ||||
| 				cwip_account = get_asset_account("capital_work_in_progress_account", d.asset, | ||||
| 					company = self.company) | ||||
| 
 | ||||
| 			if d.is_fixed_asset and not cwip_disabled: | ||||
| 
 | ||||
| 				asset_amount = flt(d.net_amount) + flt(d.item_tax_amount/self.conversion_rate) | ||||
| 				base_asset_amount = flt(d.base_net_amount + d.item_tax_amount) | ||||
| 
 | ||||
| @ -368,6 +377,36 @@ class PurchaseReceipt(BuyingController): | ||||
| 						if asset_rbnb_currency == self.company_currency else asset_amount) | ||||
| 				}, item=d)) | ||||
| 
 | ||||
| 			if d.is_fixed_asset and flt(d.landed_cost_voucher_amount): | ||||
| 				asset_account = (get_asset_category_account(d.asset, 'fixed_asset_account', | ||||
| 					company = self.company) if cwip_disabled else cwip_account) | ||||
| 
 | ||||
| 				gl_entries.append(self.get_gl_dict({ | ||||
| 					"account": expenses_included_in_valuation, | ||||
| 					"against": asset_account, | ||||
| 					"cost_center": d.cost_center, | ||||
| 					"remarks": self.get("remarks") or _("Accounting Entry for Stock"), | ||||
| 					"credit": flt(d.landed_cost_voucher_amount), | ||||
| 					"project": d.project | ||||
| 				}, item=d)) | ||||
| 
 | ||||
| 				gl_entries.append(self.get_gl_dict({ | ||||
| 					"account": asset_account, | ||||
| 					"against": expenses_included_in_valuation, | ||||
| 					"cost_center": d.cost_center, | ||||
| 					"remarks": self.get("remarks") or _("Accounting Entry for Stock"), | ||||
| 					"debit": flt(d.landed_cost_voucher_amount), | ||||
| 					"project": d.project | ||||
| 				}, item=d)) | ||||
| 
 | ||||
| 				if d.asset: | ||||
| 					doc = frappe.get_doc("Asset", d.asset) | ||||
| 					frappe.db.set_value("Asset", d.asset, "gross_purchase_amount", | ||||
| 						doc.gross_purchase_amount + flt(d.landed_cost_voucher_amount)) | ||||
| 
 | ||||
| 					frappe.db.set_value("Asset", d.asset, "purchase_receipt_amount", | ||||
| 						doc.purchase_receipt_amount + flt(d.landed_cost_voucher_amount)) | ||||
| 
 | ||||
| 		return gl_entries | ||||
| 
 | ||||
| 	def update_status(self, status): | ||||
|  | ||||
| @ -254,7 +254,7 @@ class StockEntry(StockController): | ||||
| 		target_mandatory = ["Material Receipt", "Material Transfer", "Send to Subcontractor", | ||||
| 			"Material Transfer for Manufacture", "Send to Warehouse", "Receive at Warehouse"] | ||||
| 
 | ||||
| 		validate_for_manufacture_repack = any([d.bom_no for d in self.get("items")]) | ||||
| 		validate_for_manufacture = any([d.bom_no for d in self.get("items")]) | ||||
| 
 | ||||
| 		if self.purpose in source_mandatory and self.purpose not in target_mandatory: | ||||
| 			self.to_warehouse = None | ||||
| @ -285,8 +285,8 @@ class StockEntry(StockController): | ||||
| 				else: | ||||
| 					frappe.throw(_("Target warehouse is mandatory for row {0}").format(d.idx)) | ||||
| 
 | ||||
| 			if self.purpose in ["Manufacture", "Repack"]: | ||||
| 				if validate_for_manufacture_repack: | ||||
| 			if self.purpose == "Manufacture": | ||||
| 				if validate_for_manufacture: | ||||
| 					if d.bom_no: | ||||
| 						d.s_warehouse = None | ||||
| 
 | ||||
|  | ||||
| @ -808,7 +808,7 @@ def get_serial_no_details(item_code, warehouse, stock_qty, serial_no): | ||||
| 	return {'serial_no': serial_no} | ||||
| 
 | ||||
| @frappe.whitelist() | ||||
| def get_bin_details_and_serial_nos(item_code, warehouse, has_batch_no, stock_qty=None, serial_no=None): | ||||
| def get_bin_details_and_serial_nos(item_code, warehouse, has_batch_no=None, stock_qty=None, serial_no=None): | ||||
| 	bin_details_and_serial_nos = {} | ||||
| 	bin_details_and_serial_nos.update(get_bin_details(item_code, warehouse)) | ||||
| 	if flt(stock_qty) > 0: | ||||
|  | ||||
| @ -0,0 +1,34 @@ | ||||
| { | ||||
|  "add_total_row": 0, | ||||
|  "creation": "2019-09-16 14:10:33.102865", | ||||
|  "disable_prepared_report": 0, | ||||
|  "disabled": 0, | ||||
|  "docstatus": 0, | ||||
|  "doctype": "Report", | ||||
|  "idx": 0, | ||||
|  "is_standard": "Yes", | ||||
|  "modified": "2019-09-21 15:19:55.710578", | ||||
|  "modified_by": "Administrator", | ||||
|  "module": "Stock", | ||||
|  "name": "Purchase Order Items To Be Received or Billed", | ||||
|  "owner": "Administrator", | ||||
|  "prepared_report": 0, | ||||
|  "query": "SELECT\n\t`poi_pri`.`purchase_order` as \"Purchase Order:Link/Purchase Order:120\",\n\t`poi_pri`.`status` as \"Status:Data:120\",\n\t`poi_pri`.`transaction_date` as \"Date:Date:100\",\n\t`poi_pri`.`schedule_date` as \"Reqd by Date:Date:110\",\n\t`poi_pri`.`supplier` as \"Supplier:Link/Supplier:120\",\n\t`poi_pri`.`supplier_name` as \"Supplier Name::150\",\n\t`poi_pri`.`item_code` as \"Item Code:Link/Item:120\",\n\t`poi_pri`.`qty` as \"Qty:Float:100\",\n\t`poi_pri`.`base_amount` as  \"Base Amount:Currency:100\",\n\t`poi_pri`.`received_qty` as \"Received Qty:Float:100\",\n\t`poi_pri`.`received_amount` as \"Received Qty Amount:Currency:100\",\n\t`poi_pri`.`qty_to_receive` as \"Qty to Receive:Float:100\",\n\t`poi_pri`.`amount_to_be_received` as \"Amount to Receive:Currency:100\",\n\t`poi_pri`.`billed_amount` as  \"Billed Amount:Currency:100\",\n\t`poi_pri`.`amount_to_be_billed` as  \"Amount To Be Billed:Currency:100\",\n\tSUM(`pii`.`qty`) AS \"Billed Qty:Float:100\",\n\t`poi_pri`.qty - SUM(`pii`.`qty`) AS \"Qty To Be Billed:Float:100\",\n\t`poi_pri`.`warehouse` as \"Warehouse:Link/Warehouse:150\",\n\t`poi_pri`.`item_name` as \"Item Name::150\",\n\t`poi_pri`.`description` as \"Description::200\",\n\t`poi_pri`.`brand` as \"Brand::100\",\n\t`poi_pri`.`project` as \"Project\",\n\t`poi_pri`.`company` as \"Company:Link/Company:\"\nFROM\n\t(SELECT\n\t\t`po`.`name` AS 'purchase_order',\n\t\t`po`.`status`,\n\t\t`po`.`company`,\n\t\t`poi`.`warehouse`,\n\t\t`poi`.`brand`,\n\t\t`poi`.`description`,\n\t\t`po`.`transaction_date`,\n\t\t`poi`.`schedule_date`,\n\t\t`po`.`supplier`,\n\t\t`po`.`supplier_name`,\n\t\t`poi`.`project`,\n\t\t`poi`.`item_code`,\n\t\t`poi`.`item_name`,\n\t\t`poi`.`qty`,\n\t\t`poi`.`base_amount`,\n\t\t`poi`.`received_qty`,\n\t\t(`poi`.billed_amt * ifnull(`po`.conversion_rate, 1)) as billed_amount,\n\t\t(`poi`.base_amount - (`poi`.billed_amt * ifnull(`po`.conversion_rate, 1))) as amount_to_be_billed,\n\t\t`poi`.`qty` - IFNULL(`poi`.`received_qty`, 0) AS 'qty_to_receive',\n\t\t(`poi`.`qty` - IFNULL(`poi`.`received_qty`, 0)) * `poi`.`rate` AS 'amount_to_be_received',\n\t\tSUM(`pri`.`amount`) AS 'received_amount',\n\t\t`poi`.`name` AS 'poi_name',\n\t\t`pri`.`name` AS 'pri_name'\n\tFROM\n\t\t`tabPurchase Order` po\n\t\tLEFT JOIN `tabPurchase Order Item` poi\n\t\tON `poi`.`parent` = `po`.`name`\n\t\tLEFT JOIN `tabPurchase Receipt Item` pri\n\t\tON `pri`.`purchase_order_item` = `poi`.`name`\n\t\t\tAND `pri`.`docstatus`=1\n\tWHERE\n\t\t`po`.`status` not in ('Stopped', 'Closed')\n\t\tAND `po`.`docstatus` = 1\n\t\tAND IFNULL(`poi`.`received_qty`, 0) < IFNULL(`poi`.`qty`, 0)\n\tGROUP BY `poi`.`name`\n\tORDER BY `po`.`transaction_date` ASC\n\t) poi_pri\n\tLEFT JOIN `tabPurchase Invoice Item` pii\n\tON `pii`.`po_detail` = `poi_pri`.`poi_name`\n\t\tAND `pii`.`docstatus`=1\nGROUP BY `poi_pri`.`poi_name`", | ||||
|  "ref_doctype": "Purchase Order", | ||||
|  "report_name": "Purchase Order Items To Be Received or Billed1", | ||||
|  "report_type": "Query Report", | ||||
|  "roles": [ | ||||
|   { | ||||
|    "role": "Purchase Manager" | ||||
|   }, | ||||
|   { | ||||
|    "role": "Purchase User" | ||||
|   }, | ||||
|   { | ||||
|    "role": "Stock User" | ||||
|   }, | ||||
|   { | ||||
|    "role": "Stock Manager" | ||||
|   } | ||||
|  ] | ||||
| } | ||||
| @ -15,8 +15,8 @@ def execute(filters=None): | ||||
| 
 | ||||
| def get_columns(): | ||||
| 	columns = [ | ||||
| 		_("Company") + ":Link/Item:250", | ||||
| 		_("Warehouse") + ":Link/Item:150", | ||||
| 		_("Company") + ":Link/Company:250", | ||||
| 		_("Warehouse") + ":Link/Warehouse:150", | ||||
| 		_("Item") + ":Link/Item:150", | ||||
| 		_("Description") + "::300", | ||||
| 		_("Current Qty") + ":Float:100", | ||||
| @ -30,7 +30,7 @@ def get_total_stock(filters): | ||||
| 
 | ||||
| 	if filters.get("group_by") == "Warehouse": | ||||
| 		if filters.get("company"): | ||||
| 			conditions += " AND warehouse.company = %s" % frappe.db.escape(filters.get("company"), percent=False) | ||||
| 			conditions += " AND warehouse.company = '%s'" % frappe.db.escape(filters.get("company"), percent=False) | ||||
| 
 | ||||
| 		conditions += " GROUP BY ledger.warehouse, item.item_code" | ||||
| 		columns += "'' as company, ledger.warehouse" | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user