Fixed merge conflict
This commit is contained in:
commit
fa1cdd5bf0
@ -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
|
|
||||||
}
|
}
|
@ -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):
|
||||||
|
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
@ -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){
|
||||||
|
@ -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",
|
||||||
|
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
@ -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']
|
||||||
]
|
},
|
||||||
}
|
]
|
||||||
|
}
|
@ -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']
|
||||||
]
|
}
|
||||||
}
|
]
|
||||||
|
}
|
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
||||||
|
@ -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"))
|
||||||
|
|
||||||
|
@ -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 |
BIN
erpnext/docs/assets/img/buying/material-request-flowchart.png
Normal file
BIN
erpnext/docs/assets/img/buying/material-request-flowchart.png
Normal file
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 |
@ -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}
|
||||||
|
@ -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.
|
||||||
|
|
||||||
|
@ -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']
|
||||||
]
|
}
|
||||||
}
|
]
|
||||||
|
}
|
@ -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))
|
||||||
|
|
||||||
|
@ -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()
|
||||||
|
@ -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']
|
||||||
]
|
},
|
||||||
}
|
]
|
||||||
|
}
|
||||||
|
@ -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']
|
||||||
]
|
}
|
||||||
}
|
]
|
||||||
|
}
|
@ -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']
|
||||||
]
|
}
|
||||||
}
|
]
|
||||||
|
}
|
@ -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']
|
||||||
]
|
},
|
||||||
}
|
]
|
||||||
|
}
|
@ -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",
|
||||||
|
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
@ -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']
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
@ -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']
|
||||||
}
|
}
|
||||||
|
]
|
||||||
|
}
|
@ -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']
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user