Fixed merge conflict

This commit is contained in:
Nabin Hait 2016-10-18 15:37:33 +05:30
commit fa1cdd5bf0
30 changed files with 412 additions and 377 deletions

View File

@ -10,6 +10,7 @@
"docstatus": 0, "docstatus": 0,
"doctype": "DocType", "doctype": "DocType",
"document_type": "Setup", "document_type": "Setup",
"editable_grid": 0,
"fields": [ "fields": [
{ {
"allow_on_submit": 0, "allow_on_submit": 0,
@ -249,14 +250,15 @@
"hide_toolbar": 0, "hide_toolbar": 0,
"icon": "icon-money", "icon": "icon-money",
"idx": 1, "idx": 1,
"in_create": 0, "image_view": 0,
"in_create": 1,
"in_dialog": 0, "in_dialog": 0,
"is_submittable": 0, "is_submittable": 0,
"issingle": 0, "issingle": 0,
"istable": 0, "istable": 0,
"max_attachments": 0, "max_attachments": 0,
"menu_index": 0, "menu_index": 0,
"modified": "2016-05-16 15:23:14.770933", "modified": "2016-10-18 14:22:00.207907",
"modified_by": "Administrator", "modified_by": "Administrator",
"module": "Accounts", "module": "Accounts",
"name": "Cost Center", "name": "Cost Center",
@ -368,6 +370,5 @@
"read_only_onload": 0, "read_only_onload": 0,
"search_fields": "parent_cost_center, is_group", "search_fields": "parent_cost_center, is_group",
"sort_order": "ASC", "sort_order": "ASC",
"track_seen": 0, "track_seen": 0
"version": 0
} }

View File

@ -71,7 +71,7 @@ class PurchaseInvoice(BuyingController):
frappe.throw(_("Cash or Bank Account is mandatory for making payment entry")) frappe.throw(_("Cash or Bank Account is mandatory for making payment entry"))
if flt(self.paid_amount) + flt(self.write_off_amount) \ if flt(self.paid_amount) + flt(self.write_off_amount) \
- flt(self.base_grand_total) > 1/(10**(self.precision("base_grand_total") + 1)): - flt(self.grand_total) > 1/(10**(self.precision("base_grand_total") + 1)):
frappe.throw(_("""Paid amount + Write Off Amount can not be greater than Grand Total""")) frappe.throw(_("""Paid amount + Write Off Amount can not be greater than Grand Total"""))
def create_remarks(self): def create_remarks(self):

View File

@ -1,31 +1,32 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'purchase_invoice', return {
'non_standard_fieldnames': { 'fieldname': 'purchase_invoice',
'Delivery Note': 'against_sales_invoice', 'non_standard_fieldnames': {
'Journal Entry': 'reference_name', 'Delivery Note': 'against_sales_invoice',
'Payment Entry': 'reference_name', 'Journal Entry': 'reference_name',
'Payment Request': 'reference_name', 'Payment Entry': 'reference_name',
'Landed Cost Voucher': 'receipt_document', 'Payment Request': 'reference_name',
'Purchase Invoice': 'return_against' 'Landed Cost Voucher': 'receipt_document',
}, 'Purchase Invoice': 'return_against'
'internal_links': {
'Purchase Order': ['items', 'sales_order'],
'Purchase Receipt': ['items', 'delivery_note'],
},
'transactions': [
{
'label': _('Payment'),
'items': ['Payment Entry', 'Payment Request', 'Journal Entry']
}, },
{ 'internal_links': {
'label': _('Reference'), 'Purchase Order': ['items', 'sales_order'],
'items': ['Purchase Order', 'Purchase Receipt', 'Asset', 'Landed Cost Voucher'] 'Purchase Receipt': ['items', 'delivery_note'],
}, },
{ 'transactions': [
'label': _('Returns'), {
'items': ['Purchase Invoice'] 'label': _('Payment'),
}, 'items': ['Payment Entry', 'Payment Request', 'Journal Entry']
] },
} {
'label': _('Reference'),
'items': ['Purchase Order', 'Purchase Receipt', 'Asset', 'Landed Cost Voucher']
},
{
'label': _('Returns'),
'items': ['Purchase Invoice']
},
]
}

View File

@ -1,30 +1,31 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'sales_invoice', return {
'non_standard_fieldnames': { 'fieldname': 'sales_invoice',
'Delivery Note': 'against_sales_invoice', 'non_standard_fieldnames': {
'Journal Entry': 'reference_name', 'Delivery Note': 'against_sales_invoice',
'Payment Entry': 'reference_name', 'Journal Entry': 'reference_name',
'Payment Request': 'reference_name', 'Payment Entry': 'reference_name',
'Sales Invoice': 'return_against' 'Payment Request': 'reference_name',
}, 'Sales Invoice': 'return_against'
'internal_links': {
'Sales Order': ['items', 'sales_order'],
'Delivery Note': ['items', 'delivery_note'],
},
'transactions': [
{
'label': _('Payment'),
'items': ['Payment Entry', 'Payment Request', 'Journal Entry']
}, },
{ 'internal_links': {
'label': _('Reference'), 'Sales Order': ['items', 'sales_order'],
'items': ['Timesheet', 'Delivery Note', 'Sales Order'] 'Delivery Note': ['items', 'delivery_note'],
}, },
{ 'transactions': [
'label': _('Returns'), {
'items': ['Sales Invoice'] 'label': _('Payment'),
}, 'items': ['Payment Entry', 'Payment Request', 'Journal Entry']
] },
} {
'label': _('Reference'),
'items': ['Timesheet', 'Delivery Note', 'Sales Order']
},
{
'label': _('Returns'),
'items': ['Sales Invoice']
},
]
}

View File

@ -93,7 +93,7 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
me.get_data_from_server(function(){ me.get_data_from_server(function(){
me.load_data(false); me.load_data(false);
me.make_customer(); me.make_customer();
me.make_item_list(true); me.make_item_list();
me.set_missing_values(); me.set_missing_values();
}) })
}); });
@ -269,7 +269,7 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
make: function() { make: function() {
this.make_search(); this.make_search();
this.make_customer(); this.make_customer();
this.make_item_list(true); this.make_item_list();
this.make_discount_field() this.make_discount_field()
}, },
@ -290,7 +290,7 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
this.search.$input.on("keyup", function() { this.search.$input.on("keyup", function() {
setTimeout(function() { setTimeout(function() {
me.items = me.get_items(); me.items = me.get_items();
me.make_item_list(false); me.make_item_list();
}, 1000); }, 1000);
}); });
@ -375,7 +375,7 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
} }
}, },
make_item_list: function(index_search) { make_item_list: function() {
var me = this; var me = this;
if(!this.price_list) { if(!this.price_list) {
msgprint(__("Price List not found or disabled")); msgprint(__("Price List not found or disabled"));
@ -389,7 +389,7 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
if (this.items) { if (this.items) {
$.each(this.items, function(index, obj) { $.each(this.items, function(index, obj) {
if(!index_search || index < 16){ if(index < 30){
$(frappe.render_template("pos_item", { $(frappe.render_template("pos_item", {
item_code: obj.name, item_code: obj.name,
item_price: format_currency(obj.price_list_rate, obj.currency), item_price: format_currency(obj.price_list_rate, obj.currency),
@ -435,7 +435,7 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
key = this.search.$input.val().toLowerCase(); key = this.search.$input.val().toLowerCase();
var re = new RegExp('%', 'g'); var re = new RegExp('%', 'g');
var reg = new RegExp(key.replace(re, '\\w*\\s*[a-zA-Z0-9]*')) var reg = new RegExp(key.replace(re, '[\\w*\\s*[a-zA-Z0-9]*]*'))
search_status = true search_status = true
if(key){ if(key){

View File

@ -303,6 +303,11 @@ def make_purchase_invoice(source_name, target_doc=None):
target.base_amount = target.amount * flt(source_parent.conversion_rate) target.base_amount = target.amount * flt(source_parent.conversion_rate)
target.qty = target.amount / flt(obj.rate) if (flt(obj.rate) and flt(obj.billed_amt)) else flt(obj.qty) target.qty = target.amount / flt(obj.rate) if (flt(obj.rate) and flt(obj.billed_amt)) else flt(obj.qty)
item = frappe.db.get_value("Item", target.item_code, ["item_group", "buying_cost_center"], as_dict=1)
target.cost_center = frappe.db.get_value("Project", obj.project, "cost_center") \
or item.buying_cost_center \
or frappe.db.get_value("Item Group", item.item_group, "default_cost_center")
doc = get_mapped_doc("Purchase Order", source_name, { doc = get_mapped_doc("Purchase Order", source_name, {
"Purchase Order": { "Purchase Order": {
"doctype": "Purchase Invoice", "doctype": "Purchase Invoice",

View File

@ -1,24 +1,25 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'purchase_order', return {
'internal_links': { 'fieldname': 'purchase_order',
'Material Request': ['items', 'material_request'], 'internal_links': {
'Supplier Quotation': ['items', 'supplier_quotation'], 'Material Request': ['items', 'material_request'],
'Project': ['project'], 'Supplier Quotation': ['items', 'supplier_quotation'],
}, 'Project': ['project'],
'transactions': [
{
'label': _('Related'),
'items': ['Purchase Receipt', 'Purchase Invoice']
}, },
{ 'transactions': [
'label': _('Reference'), {
'items': ['Material Request', 'Supplier Quotation', 'Project'] 'label': _('Related'),
}, 'items': ['Purchase Receipt', 'Purchase Invoice']
{ },
'label': _('Sub-contracting'), {
'items': ['Stock Entry'] 'label': _('Reference'),
}, 'items': ['Material Request', 'Supplier Quotation', 'Project']
] },
} {
'label': _('Sub-contracting'),
'items': ['Stock Entry']
},
]
}

View File

@ -1,12 +1,13 @@
from frappe import _ from frappe import _
data = { def get_data():
'docstatus': 1, return {
'fieldname': 'request_for_quotation', 'docstatus': 1,
'transactions': [ 'fieldname': 'request_for_quotation',
{ 'transactions': [
'label': _('Related'), {
'items': ['Supplier Quotation'] 'label': _('Related'),
}, 'items': ['Supplier Quotation']
] },
} ]
}

View File

@ -1,17 +1,18 @@
from frappe import _ from frappe import _
data = { def get_data():
'heatmap': True, return {
'heatmap_message': _('This is based on transactions against this Supplier. See timeline below for details'), 'heatmap': True,
'fieldname': 'supplier', 'heatmap_message': _('This is based on transactions against this Supplier. See timeline below for details'),
'transactions': [ 'fieldname': 'supplier',
{ 'transactions': [
'label': _('Procurement'), {
'items': ['Request for Quotation', 'Supplier Quotation'] 'label': _('Procurement'),
}, 'items': ['Request for Quotation', 'Supplier Quotation']
{ },
'label': _('Orders'), {
'items': ['Purchase Order', 'Purchase Receipt', 'Purchase Invoice'] 'label': _('Orders'),
} 'items': ['Purchase Order', 'Purchase Receipt', 'Purchase Invoice']
] }
} ]
}

View File

@ -1,20 +1,21 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'supplier_quotation', return {
'internal_links': { 'fieldname': 'supplier_quotation',
'Material Request': ['items', 'material_request'], 'internal_links': {
'Request for Quotation': ['items', 'request_for_quotation'], 'Material Request': ['items', 'material_request'],
'Project': ['items', 'project'], 'Request for Quotation': ['items', 'request_for_quotation'],
}, 'Project': ['items', 'project'],
'transactions': [
{
'label': _('Related'),
'items': ['Purchase Order']
}, },
{ 'transactions': [
'label': _('Reference'), {
'items': ['Material Request', 'Request for Quotation', 'Project'] 'label': _('Related'),
}, 'items': ['Purchase Order']
] },
} {
'label': _('Reference'),
'items': ['Material Request', 'Request for Quotation', 'Project']
},
]
}

View File

@ -338,7 +338,7 @@ class calculate_taxes_and_totals(object):
tax.item_wise_tax_detail = json.dumps(tax.item_wise_tax_detail, separators=(',', ':')) tax.item_wise_tax_detail = json.dumps(tax.item_wise_tax_detail, separators=(',', ':'))
def set_discount_amount(self): def set_discount_amount(self):
if not self.doc.discount_amount and self.doc.additional_discount_percentage: if self.doc.additional_discount_percentage:
self.doc.discount_amount = flt(flt(self.doc.get(scrub(self.doc.apply_discount_on))) self.doc.discount_amount = flt(flt(self.doc.get(scrub(self.doc.apply_discount_on)))
* self.doc.additional_discount_percentage / 100, self.doc.precision("discount_amount")) * self.doc.additional_discount_percentage / 100, self.doc.precision("discount_amount"))

View File

@ -1,14 +1,12 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'opportunity', return {
'non_standard_fieldnames': { 'fieldname': 'prevdoc_docname',
'Quotation': 'prevdoc_docname' 'transactions': [
}, {
'transactions': [ 'label': _('Related'),
{ 'items': ['Quotation', 'Supplier Quotation']
'label': _('Related'), },
'items': ['Quotation', 'Supplier Quotation'] ]
}, }
]
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 52 KiB

After

Width:  |  Height:  |  Size: 38 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 55 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 52 KiB

After

Width:  |  Height:  |  Size: 47 KiB

View File

@ -18,6 +18,11 @@ choose to start its fiscal year on October 1. That way, they know what their
income will be for that year, and can adjust their expenses to maintain their income will be for that year, and can adjust their expenses to maintain their
desired profit margins. desired profit margins.
To set the Fiscal Year as default, click on the 'Default' button.
In case you have multiple companies sharing the same Fiscal Year, you can add
it into the grid as shown below.
<img class="screenshot" alt="Fiscal Year" src="{{docs_base_url}}/assets/img/accounts/fiscal-year.png"> <img class="screenshot" alt="Fiscal Year" src="{{docs_base_url}}/assets/img/accounts/fiscal-year.png">
{next} {next}

View File

@ -1,7 +1,7 @@
A Material Request is a simple document identifying a requirement of a set of A Material Request is a simple document identifying a requirement of a set of
Items (products or services) for a particular reason. Items (products or services) for a particular reason.
![Workflow]({{docs_base_url}}/assets/old_images/erpnext/material-request-workflow.jpg) ![Workflow]({{docs_base_url}}/assets/img/buying/material-request-flowchart.png)
To generate a Material Request manually go to: To generate a Material Request manually go to:
@ -25,6 +25,8 @@ A Material Request can be of type:
* Material Issue - If the requested material is to be Issued. * Material Issue - If the requested material is to be Issued.
* Manufacture - If the requested material is to be Produced. * Manufacture - If the requested material is to be Produced.
The User can also raise a [Request For Quotation]({{docs_base_url}}/user/manual/en/buying/request-for-quotation.html) against a Material Request. To create a Request For Quotation the user can click on 'Make'.
> Info: Material Request is not mandatory. It is ideal if you have centralized > Info: Material Request is not mandatory. It is ideal if you have centralized
buying so that you can collect this information from various departments. buying so that you can collect this information from various departments.

View File

@ -1,25 +1,26 @@
from frappe import _ from frappe import _
data = { def get_data():
'heatmap': True, return {
'heatmap_message': _('This is based on the attendance of this Employee'), 'heatmap': True,
'fieldname': 'employee', 'heatmap_message': _('This is based on the attendance of this Employee'),
'transactions': [ 'fieldname': 'employee',
{ 'transactions': [
'label': _('Leave and Attendance'), {
'items': ['Attendance', 'Leave Application', 'Leave Allocation'] 'label': _('Leave and Attendance'),
}, 'items': ['Attendance', 'Leave Application', 'Leave Allocation']
{ },
'label': _('Payroll'), {
'items': ['Salary Structure', 'Salary Slip', 'Timesheet'] 'label': _('Payroll'),
}, 'items': ['Salary Structure', 'Salary Slip', 'Timesheet']
{ },
'label': _('Expense'), {
'items': ['Expense Claim'] 'label': _('Expense'),
}, 'items': ['Expense Claim']
{ },
'label': _('Evaluation'), {
'items': ['Appraisal'] 'label': _('Evaluation'),
} 'items': ['Appraisal']
] }
} ]
}

View File

@ -58,7 +58,8 @@ class ProductionOrder(Document):
if so[0].project: if so[0].project:
self.project = so[0].project self.project = so[0].project
self.validate_production_order_against_so() if not self.material_request:
self.validate_production_order_against_so()
else: else:
frappe.throw(_("Sales Order {0} is not valid").format(self.sales_order)) frappe.throw(_("Sales Order {0} is not valid").format(self.sales_order))

View File

@ -473,20 +473,21 @@ class ProductionPlanningTool(Document):
material_request.update({"material_request_type": item_wrapper.default_material_request_type}) material_request.update({"material_request_type": item_wrapper.default_material_request_type})
for sales_order, requested_qty in items_to_be_requested[item].items(): for sales_order, requested_qty in items_to_be_requested[item].items():
material_request.append("items", { if sales_order != 'No Sales Order':
"doctype": "Material Request Item", material_request.append("items", {
"__islocal": 1, "doctype": "Material Request Item",
"item_code": item, "__islocal": 1,
"item_name": item_wrapper.item_name, "item_code": item,
"description": item_wrapper.description, "item_name": item_wrapper.item_name,
"uom": item_wrapper.stock_uom, "description": item_wrapper.description,
"item_group": item_wrapper.item_group, "uom": item_wrapper.stock_uom,
"brand": item_wrapper.brand, "item_group": item_wrapper.item_group,
"qty": requested_qty, "brand": item_wrapper.brand,
"schedule_date": add_days(nowdate(), cint(item_wrapper.lead_time_days)), "qty": requested_qty,
"warehouse": self.purchase_request_for_warehouse, "schedule_date": add_days(nowdate(), cint(item_wrapper.lead_time_days)),
"sales_order": sales_order if sales_order!="No Sales Order" else None "warehouse": self.purchase_request_for_warehouse,
}) "sales_order": sales_order if sales_order!="No Sales Order" else None
})
material_request.flags.ignore_permissions = 1 material_request.flags.ignore_permissions = 1
material_request.submit() material_request.submit()

View File

@ -1,25 +1,26 @@
from frappe import _ from frappe import _
data = { def get_data():
'heatmap': True, return {
'heatmap_message': _('This is based on the Time Sheets created against this project'), 'heatmap': True,
'fieldname': 'project', 'heatmap_message': _('This is based on the Time Sheets created against this project'),
'transactions': [ 'fieldname': 'project',
{ 'transactions': [
'label': _('Project'), {
'items': ['Task', 'Timesheet', 'Expense Claim', 'Issue'] 'label': _('Project'),
}, 'items': ['Task', 'Timesheet', 'Expense Claim', 'Issue']
{ },
'label': _('Material'), {
'items': ['Material Request', 'BOM', 'Stock Entry'] 'label': _('Material'),
}, 'items': ['Material Request', 'BOM', 'Stock Entry']
{ },
'label': _('Sales'), {
'items': ['Sales Order', 'Delivery Note', 'Sales Invoice'] 'label': _('Sales'),
}, 'items': ['Sales Order', 'Delivery Note', 'Sales Invoice']
{ },
'label': _('Purchase'), {
'items': ['Purchase Order', 'Purchase Receipt', 'Purchase Invoice'] 'label': _('Purchase'),
}, 'items': ['Purchase Order', 'Purchase Receipt', 'Purchase Invoice']
] },
} ]
}

View File

@ -1,15 +1,16 @@
from frappe import _ from frappe import _
data = { def get_data():
'heatmap': True, {
'heatmap_message': _('This is based on the attendance of this Student'), 'heatmap': True,
'fieldname': 'student', 'heatmap_message': _('This is based on the attendance of this Student'),
'transactions': [ 'fieldname': 'student',
{ 'transactions': [
'items': ['Student Log', 'Student Group', 'Student Attendance'] {
}, 'items': ['Student Log', 'Student Group', 'Student Attendance']
{ },
'items': ['Program Enrollment', 'Fees', 'Assessment'] {
} 'items': ['Program Enrollment', 'Fees', 'Assessment', 'Guardian']
] }
} ]
}

View File

@ -1,25 +1,26 @@
from frappe import _ from frappe import _
data = { def get_data():
'heatmap': True, return {
'heatmap_message': _('This is based on transactions against this Customer. See timeline below for details'), 'heatmap': True,
'fieldname': 'customer', 'heatmap_message': _('This is based on transactions against this Customer. See timeline below for details'),
'transactions': [ 'fieldname': 'customer',
{ 'transactions': [
'label': _('Pre Sales'), {
'items': ['Opportunity', 'Quotation'] 'label': _('Pre Sales'),
}, 'items': ['Opportunity', 'Quotation']
{ },
'label': _('Orders'), {
'items': ['Sales Order', 'Delivery Note', 'Sales Invoice'] 'label': _('Orders'),
}, 'items': ['Sales Order', 'Delivery Note', 'Sales Invoice']
{ },
'label': _('Support'), {
'items': ['Issue'] 'label': _('Support'),
}, 'items': ['Issue']
{ },
'label': _('Projects'), {
'items': ['Project'] 'label': _('Projects'),
} 'items': ['Project']
] }
} ]
}

View File

@ -1,11 +1,12 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'prevdoc_docname', return {
'transactions': [ 'fieldname': 'prevdoc_docname',
{ 'transactions': [
'label': _('Related'), {
'items': ['Sales Order'] 'label': _('Related'),
}, 'items': ['Sales Order']
] },
} ]
}

View File

@ -443,6 +443,11 @@ def make_sales_invoice(source_name, target_doc=None, ignore_permissions=False):
target.base_amount = target.amount * flt(source_parent.conversion_rate) target.base_amount = target.amount * flt(source_parent.conversion_rate)
target.qty = target.amount / flt(source.rate) if (source.rate and source.billed_amt) else source.qty target.qty = target.amount / flt(source.rate) if (source.rate and source.billed_amt) else source.qty
item = frappe.db.get_value("Item", target.item_code, ["item_group", "selling_cost_center"], as_dict=1)
target.cost_center = frappe.db.get_value("Project", obj.project, "cost_center") \
or item.selling_cost_center \
or frappe.db.get_value("Item Group", item.item_group, "default_cost_center")
doclist = get_mapped_doc("Sales Order", source_name, { doclist = get_mapped_doc("Sales Order", source_name, {
"Sales Order": { "Sales Order": {
"doctype": "Sales Invoice", "doctype": "Sales Invoice",

View File

@ -1,33 +1,34 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'sales_order', return {
'non_standard_fieldnames': { 'fieldname': 'sales_order',
'Delivery Note': 'against_sales_order', 'non_standard_fieldnames': {
}, 'Delivery Note': 'against_sales_order',
'internal_links': {
'Quotation': ['items', 'prevdoc_docname']
},
'transactions': [
{
'label': _('Fulfillment'),
'items': ['Sales Invoice', 'Delivery Note']
}, },
{ 'internal_links': {
'label': _('Purchasing'), 'Quotation': ['items', 'prevdoc_docname']
'items': ['Material Request', 'Purchase Order']
}, },
{ 'transactions': [
'label': _('Projects'), {
'items': ['Project'] 'label': _('Fulfillment'),
}, 'items': ['Sales Invoice', 'Delivery Note']
{ },
'label': _('Manufacturing'), {
'items': ['Production Order'] 'label': _('Purchasing'),
}, 'items': ['Material Request', 'Purchase Order']
{ },
'label': _('Reference'), {
'items': ['Quotation'] 'label': _('Projects'),
}, 'items': ['Project']
] },
} {
'label': _('Manufacturing'),
'items': ['Production Order']
},
{
'label': _('Reference'),
'items': ['Quotation']
},
]
}

View File

@ -1,26 +1,27 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'delivery_note_no', return {
'non_standard_fieldnames': { 'fieldname': 'delivery_note_no',
'Sales Invoice': 'delivery_note', 'non_standard_fieldnames': {
'Packing Slip': 'delivery_note', 'Sales Invoice': 'delivery_note',
}, 'Packing Slip': 'delivery_note',
'internal_links': {
'Sales Order': ['items', 'against_sales_order'],
},
'transactions': [
{
'label': _('Related'),
'items': ['Sales Invoice', 'Packing Slip']
}, },
{ 'internal_links': {
'label': _('Reference'), 'Sales Order': ['items', 'against_sales_order'],
'items': ['Sales Order', 'Quality Inspection']
}, },
{ 'transactions': [
'label': _('Returns'), {
'items': ['Stock Entry'] 'label': _('Related'),
}, 'items': ['Sales Invoice', 'Packing Slip']
] },
} {
'label': _('Reference'),
'items': ['Sales Order', 'Quality Inspection']
},
{
'label': _('Returns'),
'items': ['Stock Entry']
},
]
}

View File

@ -1,45 +1,46 @@
from frappe import _ from frappe import _
data = { def get_data():
'heatmap': True, return {
'heatmap_message': _('This is based on stock movement. See {0} for details')\ 'heatmap': True,
.format('<a href="#query-report/Stock Ledger">' + _('Stock Ledger') + '</a>'), 'heatmap_message': _('This is based on stock movement. See {0} for details')\
'fieldname': 'item_code', .format('<a href="#query-report/Stock Ledger">' + _('Stock Ledger') + '</a>'),
'non_standard_fieldnames': { 'fieldname': 'item_code',
'Production Order': 'production_item', 'non_standard_fieldnames': {
'Product Bundle': 'new_item_code', 'Production Order': 'production_item',
'BOM': 'item', 'Product Bundle': 'new_item_code',
'Batch': 'item' 'BOM': 'item',
}, 'Batch': 'item'
'transactions': [
{
'label': _('Groups'),
'items': ['BOM', 'Product Bundle']
}, },
{ 'transactions': [
'label': _('Pricing'), {
'items': ['Item Price', 'Pricing Rule'] 'label': _('Groups'),
}, 'items': ['BOM', 'Product Bundle']
{ },
'label': _('Sell'), {
'items': ['Quotation', 'Sales Order', 'Delivery Note', 'Sales Invoice'] 'label': _('Pricing'),
}, 'items': ['Item Price', 'Pricing Rule']
{ },
'label': _('Buy'), {
'items': ['Material Request', 'Supplier Quotation', 'Request for Quotation', 'label': _('Sell'),
'Purchase Order', 'Purchase Invoice'] 'items': ['Quotation', 'Sales Order', 'Delivery Note', 'Sales Invoice']
}, },
{ {
'label': _('Traceability'), 'label': _('Buy'),
'items': ['Serial No', 'Batch'] 'items': ['Material Request', 'Supplier Quotation', 'Request for Quotation',
}, 'Purchase Order', 'Purchase Invoice']
{ },
'label': _('Move'), {
'items': ['Stock Entry'] 'label': _('Traceability'),
}, 'items': ['Serial No', 'Batch']
{ },
'label': _('Manufacture'), {
'items': ['Production Order'] 'label': _('Move'),
} 'items': ['Stock Entry']
] },
} {
'label': _('Manufacture'),
'items': ['Production Order']
}
]
}

View File

@ -1,15 +1,17 @@
from frappe import _ from frappe import _
data = {
'fieldname': 'material_request', def get_data():
'transactions': [ return {
{ 'fieldname': 'material_request',
'label': _('Related'), 'transactions': [
'items': ['Request for Quotation', 'Supplier Quotation', 'Purchase Order'] {
}, 'label': _('Related'),
{ 'items': ['Request for Quotation', 'Supplier Quotation', 'Purchase Order']
'label': _('Manufacturing'), },
'items': ['Production Order'] {
}, 'label': _('Manufacturing'),
] 'items': ['Production Order']
} }
]
}

View File

@ -1,28 +1,29 @@
from frappe import _ from frappe import _
data = { def get_data():
'fieldname': 'purchase_receipt_no', return {
'non_standard_fieldnames': { 'fieldname': 'purchase_receipt_no',
'Purchase Invoice': 'purchase_receipt', 'non_standard_fieldnames': {
'Landed Cost Voucher': 'receipt_document' 'Purchase Invoice': 'purchase_receipt',
}, 'Landed Cost Voucher': 'receipt_document'
'internal_links': {
'Purchase Order': ['items', 'purchase_order'],
'Project': ['items', 'project'],
'Quality Inspection': ['items', 'qa_no'],
},
'transactions': [
{
'label': _('Related'),
'items': ['Purchase Invoice', 'Landed Cost Voucher']
}, },
{ 'internal_links': {
'label': _('Reference'), 'Purchase Order': ['items', 'purchase_order'],
'items': ['Purchase Order', 'Quality Inspection', 'Project'] 'Project': ['items', 'project'],
'Quality Inspection': ['items', 'qa_no'],
}, },
{ 'transactions': [
'label': _('Returns'), {
'items': ['Stock Entry'] 'label': _('Related'),
}, 'items': ['Purchase Invoice', 'Landed Cost Voucher']
] },
} {
'label': _('Reference'),
'items': ['Purchase Order', 'Quality Inspection', 'Project']
},
{
'label': _('Returns'),
'items': ['Stock Entry']
},
]
}