diff --git a/.travis.yml b/.travis.yml index 0106858d68..c4e2ea57e0 100644 --- a/.travis.yml +++ b/.travis.yml @@ -12,10 +12,10 @@ install: script: cd ./test_sites/ && - frappe --reinstall -v test_site && - frappe --install_app erpnext -v test_site && + frappe --reinstall test_site && + frappe --install_app erpnext test_site && frappe --request '?cmd=erpnext.setup.page.setup_wizard.setup_wizard.setup_account¤cy=USD&first_name=Test&last_name=User&company_name=Wind+Power+LLC&timezone=America/New_York&company_abbr=WP&industry=Manufacturing&country=United states&fy_start_date=2014-01-01&fy_end_date=2014-12-31' test_site && - frappe --run_tests -v test_site --app erpnext + frappe --run_tests test_site --app erpnext before_script: - mysql -e 'create database travis' && diff --git a/README.md b/README.md index b00fc02351..b9f5466379 100644 --- a/README.md +++ b/README.md @@ -30,7 +30,6 @@ ERPNext is built on [frappe](https://github.com/frappe/frappe) 1. Install pip: `sudo easy_install pip` 1. Create a `bench` directory 1. Clone `frappe` in the `bench` : `git clone https://github.com/frappe/frappe` -1. Install python libraries `sudo pip install webnotes/requirements.txt` 1. Clone `erpnext` in the `bench`: `git clone https://github.com/frappe/erpnext.git` 1. Clone `shopping-cart` in the `bench`: `git clone https://github.com/frappe/shopping-cart.git` 1. Install the packages: `pip install -e frappe/ erpnext/ shopping-cart/` diff --git a/erpnext/accounts/doctype/payment_to_invoice_matching_tool/payment_to_invoice_matching_tool.py b/erpnext/accounts/doctype/payment_to_invoice_matching_tool/payment_to_invoice_matching_tool.py index f6a31a0f7c..b8c1bd6261 100644 --- a/erpnext/accounts/doctype/payment_to_invoice_matching_tool/payment_to_invoice_matching_tool.py +++ b/erpnext/accounts/doctype/payment_to_invoice_matching_tool/payment_to_invoice_matching_tool.py @@ -153,7 +153,7 @@ def gl_entry_details(doctype, txt, searchfield, start, page_len, filters): "dt":filters["dt"], "acc":filters["acc"], "account_type": filters['account_type'], - 'mcond':get_match_cond(doctype, searchfield), + 'mcond':get_match_cond(doctype), 'txt': "%%%s%%" % txt, "start": start, "page_len": page_len diff --git a/erpnext/accounts/doctype/pos_setting/pos_setting.js b/erpnext/accounts/doctype/pos_setting/pos_setting.js index f7fcdfe162..5e7afc65b0 100755 --- a/erpnext/accounts/doctype/pos_setting/pos_setting.js +++ b/erpnext/accounts/doctype/pos_setting/pos_setting.js @@ -74,5 +74,5 @@ cur_frm.fields_dict['select_print_heading'].get_query = function(doc, cdt, cdn) cur_frm.fields_dict.user.get_query = function(doc,cdt,cdn) { - return{ query:"frappe.core.doctype.profile.profile.profile_query"} + return{ query:"frappe.core.doctype.user.user.user_query"} } diff --git a/erpnext/accounts/doctype/pos_setting/pos_setting.txt b/erpnext/accounts/doctype/pos_setting/pos_setting.txt index c00e75e7e9..bad0d7eb59 100755 --- a/erpnext/accounts/doctype/pos_setting/pos_setting.txt +++ b/erpnext/accounts/doctype/pos_setting/pos_setting.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-24 12:15:51", "docstatus": 0, - "modified": "2014-01-29 13:08:24", + "modified": "2014-01-29 13:08:25", "modified_by": "Administrator", "owner": "Administrator" }, @@ -48,7 +48,7 @@ "label": "User", "oldfieldname": "user", "oldfieldtype": "Link", - "options": "Profile", + "options": "User", "read_only": 0 }, { diff --git a/erpnext/accounts/doctype/pricing_rule/pricing_rule.py b/erpnext/accounts/doctype/pricing_rule/pricing_rule.py index 271dadcf21..5073718d43 100644 --- a/erpnext/accounts/doctype/pricing_rule/pricing_rule.py +++ b/erpnext/accounts/doctype/pricing_rule/pricing_rule.py @@ -6,8 +6,9 @@ from __future__ import unicode_literals import frappe from frappe import throw, _ +from frappe.model.controller import DocListController -class DocType: +class DocType(DocListController): def __init__(self, d, dl): self.doc, self.doclist = d, dl @@ -23,15 +24,15 @@ class DocType: frappe.MandatoryError) def cleanup_fields_value(self): - fields = ["item_code", "item_group", "brand", "customer", "customer_group", - "territory", "supplier", "supplier_type", "campaign", "sales_partner", - "price", "discount_percentage"] + for logic_field in ["apply_on", "applicable_for", "price_or_discount"]: + fieldname = frappe.scrub(self.doc.fields.get(logic_field) or "") - for field_with_value in ["apply_on", "applicable_for", "price_or_discount"]: - val = self.doc.fields.get(field_with_value) - if val: - fields.remove(frappe.scrub(val)) - - for field in fields: - self.doc.fields[field] = None + # reset all values except for the logic field + options = (self.meta.get_options(logic_field) or "").split("\n") + for f in options: + if not f: continue + + f = frappe.scrub(f) + if f!=fieldname: + self.doc.fields[f] = None \ No newline at end of file diff --git a/erpnext/accounts/doctype/pricing_rule/pricing_rule.txt b/erpnext/accounts/doctype/pricing_rule/pricing_rule.txt index d0925a2599..413405c962 100644 --- a/erpnext/accounts/doctype/pricing_rule/pricing_rule.txt +++ b/erpnext/accounts/doctype/pricing_rule/pricing_rule.txt @@ -2,7 +2,7 @@ { "creation": "2014-02-21 15:02:51", "docstatus": 0, - "modified": "2014-02-28 14:49:15", + "modified": "2014-03-05 18:23:34", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "autoname": "PRULE.#####", "doctype": "DocType", "document_type": "Master", + "icon": "icon-gift", "istable": 0, "module": "Accounts", "name": "__common__" diff --git a/erpnext/accounts/doctype/purchase_invoice/purchase_invoice.py b/erpnext/accounts/doctype/purchase_invoice/purchase_invoice.py index 5717dfb130..f0a9ecb838 100644 --- a/erpnext/accounts/doctype/purchase_invoice/purchase_invoice.py +++ b/erpnext/accounts/doctype/purchase_invoice/purchase_invoice.py @@ -442,4 +442,4 @@ def get_expense_account(doctype, txt, searchfield, start, page_len, filters): and tabAccount.company = '%(company)s' and tabAccount.%(key)s LIKE '%(txt)s' %(mcond)s""" % {'company': filters['company'], 'key': searchfield, - 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype, searchfield)}) + 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype)}) diff --git a/erpnext/accounts/doctype/sales_invoice/pos.js b/erpnext/accounts/doctype/sales_invoice/pos.js index 480ce02626..fc6190ae7a 100644 --- a/erpnext/accounts/doctype/sales_invoice/pos.js +++ b/erpnext/accounts/doctype/sales_invoice/pos.js @@ -19,7 +19,7 @@ erpnext.POS = Class.extend({ \ \ \ - \ + \ \ \ \ @@ -35,7 +35,7 @@ erpnext.POS = Class.extend({
\
Item'+__("Item")+'Qty
\ \ - \ + \ \ \
Net Total'+__("Net Total")+'
\ @@ -44,7 +44,7 @@ erpnext.POS = Class.extend({ \ \ \ - \ + \ \ \ \ @@ -55,7 +55,7 @@ erpnext.POS = Class.extend({
\
Taxes'+__("Taxes")+'
\ \ - \ + \ \
Discount Amount'+__("Discount Amount")+'\ \ \ \ - \ + \ \ \
Grand Total'+__("Grand Total")+'
\ \ + \ \ \

\
\
\ \ + '+__("Make Payment")+'\
\
\ \ + '+__("Del")+'\
\
\

\ @@ -439,6 +448,12 @@ erpnext.POS = Class.extend({ me.frm.doc.currency)); this.wrapper.find(".grand-total").text(format_currency(this.frm.doc[this.grand_total], me.frm.doc.currency)); + + $(".paid-amount-area").toggle(!!this.frm.doc.paid_amount); + if(this.frm.doc.paid_amount) { + this.wrapper.find(".paid-amount").text(format_currency(this.frm.doc.paid_amount, + me.frm.doc.currency)); + } }, call_when_local: function() { var me = this; @@ -484,25 +499,16 @@ erpnext.POS = Class.extend({ disable_text_box_and_button: function() { var me = this; // if form is submitted & cancelled then disable all input box & buttons - if (this.frm.doc.docstatus>=1) { - $(this.wrapper).find('input, button').each(function () { - $(this).prop('disabled', true); - }); - $(this.wrapper).find(".remove-items").hide(); - $(this.wrapper).find(".make-payment").hide(); - } - else { - $(this.wrapper).find('input, button').each(function () { - $(this).prop('disabled', false); - }); - $(this.wrapper).find(".make-payment").show(); - } + $(this.wrapper) + .find(".remove-items, .make-payment, .increase-qty, .decrease-qty") + .toggle(this.frm.doc.docstatus===0); + + $(this.wrapper).find('input, button').prop("disabled", !(this.frm.doc.docstatus===0)); }, hide_payment_button: function() { - var me = this; - // Show Make Payment button only in Sales Invoice - if (this.frm.doctype != "Sales Invoice") - $(this.wrapper).find(".make-payment").hide(); + $(this.wrapper) + .find(".make-payment") + .toggle(this.frm.doctype == "Sales Invoice" && this.frm.doc.is_pos); }, refresh_delete_btn: function() { $(this.wrapper).find(".remove-items").toggle($(".item-cart .warning").length ? true : false); @@ -568,6 +574,9 @@ erpnext.POS = Class.extend({ frappe.call({ method: 'erpnext.accounts.doctype.sales_invoice.pos.get_mode_of_payment', callback: function(r) { + if(!r.message.length) { + msgprint(__("Please add to Modes of Payment from Setup.")) + } for (x=0; x<=r.message.length - 1; x++) { mode_of_payment.push(r.message[x].name); } diff --git a/erpnext/accounts/doctype/sales_invoice/pos.py b/erpnext/accounts/doctype/sales_invoice/pos.py index 2286ed6b81..c2d7c4b4e5 100644 --- a/erpnext/accounts/doctype/sales_invoice/pos.py +++ b/erpnext/accounts/doctype/sales_invoice/pos.py @@ -49,4 +49,4 @@ def get_item_code(barcode_serial_no): @frappe.whitelist() def get_mode_of_payment(): - return frappe.db.sql("""select name from `tabMode of Payment`""", as_dict=1) \ No newline at end of file + return frappe.get_list("Mode of Payment") diff --git a/erpnext/accounts/doctype/sales_invoice/sales_invoice.js b/erpnext/accounts/doctype/sales_invoice/sales_invoice.js index ac9768b45a..fdbead9ee3 100644 --- a/erpnext/accounts/doctype/sales_invoice/sales_invoice.js +++ b/erpnext/accounts/doctype/sales_invoice/sales_invoice.js @@ -184,8 +184,6 @@ erpnext.accounts.SalesInvoiceController = erpnext.selling.SellingController.exte this.frm.set_value("write_off_amount", flt(this.frm.doc.grand_total - this.frm.doc.paid_amount), precision("write_off_amount")); } - - this.frm.script_manager.trigger("write_off_amount"); }, write_off_amount: function() { diff --git a/erpnext/accounts/doctype/sales_invoice/sales_invoice.py b/erpnext/accounts/doctype/sales_invoice/sales_invoice.py index 6bccd03af3..d0c69fcf82 100644 --- a/erpnext/accounts/doctype/sales_invoice/sales_invoice.py +++ b/erpnext/accounts/doctype/sales_invoice/sales_invoice.py @@ -744,9 +744,9 @@ def send_notification(new_rv): message = get_html(new_rv.doc, new_rv.doclist, "SalesInvoice")) def notify_errors(inv, customer, owner): - from frappe.profile import get_system_managers + from frappe.utils.user import get_system_managers - frappe.sendmail(recipients=get_system_managers() + [frappe.db.get_value("Profile", owner, "email")], + frappe.sendmail(recipients=get_system_managers() + [frappe.db.get_value("User", owner, "email")], subject="[Urgent] Error while creating recurring invoice for %s" % inv, message = frappe.get_template("template/emails/recurring_invoice_failed.html").render({ "name": inv, @@ -793,7 +793,7 @@ def get_income_account(doctype, txt, searchfield, start, page_len, filters): and tabAccount.company = '%(company)s' and tabAccount.%(key)s LIKE '%(txt)s' %(mcond)s""" % {'company': filters['company'], 'key': searchfield, - 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype, searchfield)}) + 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype)}) @frappe.whitelist() diff --git a/erpnext/accounts/page/accounts_browser/accounts_browser.js b/erpnext/accounts/page/accounts_browser/accounts_browser.js index e5b04ddd37..50345d71ca 100644 --- a/erpnext/accounts/page/accounts_browser/accounts_browser.js +++ b/erpnext/accounts/page/accounts_browser/accounts_browser.js @@ -42,7 +42,7 @@ pscript['onload_Accounts Browser'] = function(wrapper){ ''+ '

'+frappe._('Please setup your chart of accounts before you start Accounting Entries')+'

').appendTo(main); - if (frappe.boot.profile.can_create.indexOf("Company") !== -1) { + if (frappe.boot.user.can_create.indexOf("Company") !== -1) { wrapper.appframe.add_button(frappe._('New Company'), function() { newdoc('Company'); }, 'icon-plus'); } @@ -137,7 +137,7 @@ erpnext.AccountsChart = Class.extend({ { condition: function(node) { return !node.root && me.ctype === 'Account' - && frappe.boot.profile.can_read.indexOf("GL Entry") !== -1 + && frappe.boot.user.can_read.indexOf("GL Entry") !== -1 }, label: __("View Ledger"), click: function(node, btn) { diff --git a/erpnext/accounts/report/accounts_payable/accounts_payable.txt b/erpnext/accounts/report/accounts_payable/accounts_payable.txt index 6de97f64e6..9d20510314 100644 --- a/erpnext/accounts/report/accounts_payable/accounts_payable.txt +++ b/erpnext/accounts/report/accounts_payable/accounts_payable.txt @@ -2,7 +2,7 @@ { "creation": "2013-04-22 16:16:03", "docstatus": 0, - "modified": "2013-04-30 17:55:54", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Purchase Invoice", "report_name": "Accounts Payable", diff --git a/erpnext/accounts/report/accounts_receivable/accounts_receivable.txt b/erpnext/accounts/report/accounts_receivable/accounts_receivable.txt index d01bef23d3..6da3088abe 100644 --- a/erpnext/accounts/report/accounts_receivable/accounts_receivable.txt +++ b/erpnext/accounts/report/accounts_receivable/accounts_receivable.txt @@ -2,7 +2,7 @@ { "creation": "2013-04-16 11:31:13", "docstatus": 0, - "modified": "2013-05-24 12:02:52", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Sales Invoice", "report_name": "Accounts Receivable", diff --git a/erpnext/accounts/report/bank_clearance_summary/bank_clearance_summary.txt b/erpnext/accounts/report/bank_clearance_summary/bank_clearance_summary.txt index 3dd2079f3a..3b462a0114 100644 --- a/erpnext/accounts/report/bank_clearance_summary/bank_clearance_summary.txt +++ b/erpnext/accounts/report/bank_clearance_summary/bank_clearance_summary.txt @@ -2,13 +2,14 @@ { "creation": "2013-05-01 12:13:25", "docstatus": 0, - "modified": "2013-05-01 12:13:25", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Journal Voucher", "report_name": "Bank Clearance Summary", diff --git a/erpnext/accounts/report/bank_reconciliation_statement/bank_reconciliation_statement.txt b/erpnext/accounts/report/bank_reconciliation_statement/bank_reconciliation_statement.txt index 9867c5ded7..a2436a8eb0 100644 --- a/erpnext/accounts/report/bank_reconciliation_statement/bank_reconciliation_statement.txt +++ b/erpnext/accounts/report/bank_reconciliation_statement/bank_reconciliation_statement.txt @@ -2,7 +2,7 @@ { "creation": "2013-04-30 18:30:21", "docstatus": 0, - "modified": "2013-05-01 10:53:12", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 0, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Journal Voucher", "report_name": "Bank Reconciliation Statement", diff --git a/erpnext/accounts/report/budget_variance_report/budget_variance_report.txt b/erpnext/accounts/report/budget_variance_report/budget_variance_report.txt index b89cb4545f..be9ce13a22 100644 --- a/erpnext/accounts/report/budget_variance_report/budget_variance_report.txt +++ b/erpnext/accounts/report/budget_variance_report/budget_variance_report.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-18 12:56:36", "docstatus": 0, - "modified": "2013-06-18 12:56:36", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Cost Center", "report_name": "Budget Variance Report", diff --git a/erpnext/accounts/report/customer_account_head/customer_account_head.txt b/erpnext/accounts/report/customer_account_head/customer_account_head.txt index d258facd8a..c2a856bb94 100644 --- a/erpnext/accounts/report/customer_account_head/customer_account_head.txt +++ b/erpnext/accounts/report/customer_account_head/customer_account_head.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-03 16:17:34", "docstatus": 0, - "modified": "2013-06-03 16:17:34", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Account", "report_name": "Customer Account Head", diff --git a/erpnext/accounts/report/delivered_items_to_be_billed/delivered_items_to_be_billed.txt b/erpnext/accounts/report/delivered_items_to_be_billed/delivered_items_to_be_billed.txt index f16aaaa964..a525d2df58 100644 --- a/erpnext/accounts/report/delivered_items_to_be_billed/delivered_items_to_be_billed.txt +++ b/erpnext/accounts/report/delivered_items_to_be_billed/delivered_items_to_be_billed.txt @@ -2,13 +2,14 @@ { "creation": "2013-07-30 17:28:49", "docstatus": 0, - "modified": "2014-02-11 12:40:04", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "query": "select\n `tabDelivery Note`.`name` as \"Delivery Note:Link/Delivery Note:120\",\n\t`tabDelivery Note`.`customer` as \"Customer:Link/Customer:120\",\n\t`tabDelivery Note`.`posting_date` as \"Date:Date\",\n\t`tabDelivery Note`.`project_name` as \"Project\",\n\t`tabDelivery Note Item`.`item_code` as \"Item:Link/Item:120\",\n\t(`tabDelivery Note Item`.`qty` - ifnull((select sum(qty) from `tabSales Invoice Item` \n\t where `tabSales Invoice Item`.docstatus=1 and \n `tabSales Invoice Item`.delivery_note = `tabDelivery Note`.name and\n\t `tabSales Invoice Item`.dn_detail = `tabDelivery Note Item`.name), 0))\n\t\tas \"Qty:Float:110\",\n\t(`tabDelivery Note Item`.`base_amount` - ifnull((select sum(base_amount) from `tabSales Invoice Item` \n where `tabSales Invoice Item`.docstatus=1 and \n `tabSales Invoice Item`.delivery_note = `tabDelivery Note`.name and\n `tabSales Invoice Item`.dn_detail = `tabDelivery Note Item`.name), 0))\n\t\tas \"Amount:Currency:110\",\n\t`tabDelivery Note Item`.`item_name` as \"Item Name::150\",\n\t`tabDelivery Note Item`.`description` as \"Description::200\"\nfrom `tabDelivery Note`, `tabDelivery Note Item`\nwhere\n `tabDelivery Note`.docstatus = 1 and\n\t`tabDelivery Note`.`status` != \"Stopped\" and\n `tabDelivery Note`.name = `tabDelivery Note Item`.parent and\n (`tabDelivery Note Item`.qty > ifnull((select sum(qty) from `tabSales Invoice Item` \n where `tabSales Invoice Item`.docstatus=1 and \n `tabSales Invoice Item`.delivery_note = `tabDelivery Note`.name and\n `tabSales Invoice Item`.dn_detail = `tabDelivery Note Item`.name), 0))\norder by `tabDelivery Note`.`name` desc", "ref_doctype": "Sales Invoice", diff --git a/erpnext/accounts/report/general_ledger/general_ledger.txt b/erpnext/accounts/report/general_ledger/general_ledger.txt index ef169dbe88..cdfb033d0a 100644 --- a/erpnext/accounts/report/general_ledger/general_ledger.txt +++ b/erpnext/accounts/report/general_ledger/general_ledger.txt @@ -2,13 +2,14 @@ { "creation": "2013-12-06 13:22:23", "docstatus": 0, - "modified": "2013-12-06 13:22:23", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "GL Entry", "report_name": "General Ledger", diff --git a/erpnext/accounts/report/gross_profit/gross_profit.txt b/erpnext/accounts/report/gross_profit/gross_profit.txt index bc21484f1c..56776600eb 100644 --- a/erpnext/accounts/report/gross_profit/gross_profit.txt +++ b/erpnext/accounts/report/gross_profit/gross_profit.txt @@ -2,13 +2,14 @@ { "creation": "2013-02-25 17:03:34", "docstatus": 0, - "modified": "2013-02-25 17:03:34", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Sales Invoice", "report_name": "Gross Profit", diff --git a/erpnext/accounts/report/item_wise_purchase_register/item_wise_purchase_register.txt b/erpnext/accounts/report/item_wise_purchase_register/item_wise_purchase_register.txt index 7ded5ff583..3dbd53614b 100644 --- a/erpnext/accounts/report/item_wise_purchase_register/item_wise_purchase_register.txt +++ b/erpnext/accounts/report/item_wise_purchase_register/item_wise_purchase_register.txt @@ -2,7 +2,7 @@ { "creation": "2013-06-05 15:37:30", "docstatus": 0, - "modified": "2013-06-05 15:37:30", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Purchase Invoice", "report_name": "Item-wise Purchase Register", diff --git a/erpnext/accounts/report/item_wise_sales_register/item_wise_sales_register.txt b/erpnext/accounts/report/item_wise_sales_register/item_wise_sales_register.txt index fb0555d459..8d30644c39 100644 --- a/erpnext/accounts/report/item_wise_sales_register/item_wise_sales_register.txt +++ b/erpnext/accounts/report/item_wise_sales_register/item_wise_sales_register.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-13 17:50:55", "docstatus": 0, - "modified": "2013-05-13 17:50:55", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Sales Invoice", "report_name": "Item-wise Sales Register", diff --git a/erpnext/accounts/report/ordered_items_to_be_billed/ordered_items_to_be_billed.txt b/erpnext/accounts/report/ordered_items_to_be_billed/ordered_items_to_be_billed.txt index 8960823f89..09b6cff971 100644 --- a/erpnext/accounts/report/ordered_items_to_be_billed/ordered_items_to_be_billed.txt +++ b/erpnext/accounts/report/ordered_items_to_be_billed/ordered_items_to_be_billed.txt @@ -2,13 +2,14 @@ { "creation": "2013-02-21 14:26:44", "docstatus": 0, - "modified": "2014-02-11 15:53:01", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "query": "select \n `tabSales Order`.`name` as \"Sales Order:Link/Sales Order:120\",\n `tabSales Order`.`customer` as \"Customer:Link/Customer:120\",\n `tabSales Order`.`status` as \"Status\",\n `tabSales Order`.`transaction_date` as \"Date:Date\",\n `tabSales Order`.`project_name` as \"Project\",\n `tabSales Order Item`.item_code as \"Item:Link/Item:120\",\n `tabSales Order Item`.base_amount as \"Amount:Currency:110\",\n (`tabSales Order Item`.billed_amt * ifnull(`tabSales Order`.conversion_rate, 1)) as \"Billed Amount:Currency:110\",\n (ifnull(`tabSales Order Item`.base_amount, 0) - (ifnull(`tabSales Order Item`.billed_amt, 0) * ifnull(`tabSales Order`.conversion_rate, 1))) as \"Pending Amount:Currency:120\",\n `tabSales Order Item`.item_name as \"Item Name::150\",\n `tabSales Order Item`.description as \"Description::200\"\nfrom\n `tabSales Order`, `tabSales Order Item`\nwhere\n `tabSales Order Item`.`parent` = `tabSales Order`.`name`\n and `tabSales Order`.docstatus = 1\n and `tabSales Order`.status != \"Stopped\"\n and ifnull(`tabSales Order Item`.billed_amt,0) < ifnull(`tabSales Order Item`.amount,0)\norder by `tabSales Order`.transaction_date asc", "ref_doctype": "Sales Invoice", diff --git a/erpnext/accounts/report/payment_period_based_on_invoice_date/payment_period_based_on_invoice_date.txt b/erpnext/accounts/report/payment_period_based_on_invoice_date/payment_period_based_on_invoice_date.txt index 408060240c..e48ea69ecc 100644 --- a/erpnext/accounts/report/payment_period_based_on_invoice_date/payment_period_based_on_invoice_date.txt +++ b/erpnext/accounts/report/payment_period_based_on_invoice_date/payment_period_based_on_invoice_date.txt @@ -2,7 +2,7 @@ { "creation": "2013-12-02 17:06:37", "docstatus": 0, - "modified": "2013-12-02 17:06:39", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Journal Voucher", "report_name": "Payment Period Based On Invoice Date", diff --git a/erpnext/accounts/report/purchase_invoice_trends/purchase_invoice_trends.txt b/erpnext/accounts/report/purchase_invoice_trends/purchase_invoice_trends.txt index 1d5c2d5f45..20e5a53f51 100644 --- a/erpnext/accounts/report/purchase_invoice_trends/purchase_invoice_trends.txt +++ b/erpnext/accounts/report/purchase_invoice_trends/purchase_invoice_trends.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-13 18:46:55", "docstatus": 0, - "modified": "2013-06-13 18:46:55", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Purchase Invoice", "report_name": "Purchase Invoice Trends", diff --git a/erpnext/accounts/report/purchase_order_items_to_be_billed/purchase_order_items_to_be_billed.txt b/erpnext/accounts/report/purchase_order_items_to_be_billed/purchase_order_items_to_be_billed.txt index bcde486374..88990cb6d1 100644 --- a/erpnext/accounts/report/purchase_order_items_to_be_billed/purchase_order_items_to_be_billed.txt +++ b/erpnext/accounts/report/purchase_order_items_to_be_billed/purchase_order_items_to_be_billed.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-28 15:54:16", "docstatus": 0, - "modified": "2014-02-11 13:01:05", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "query": "select \n `tabPurchase Order`.`name` as \"Purchase Order:Link/Purchase Order:120\",\n `tabPurchase Order`.`transaction_date` as \"Date:Date:100\",\n\t`tabPurchase Order`.`supplier` as \"Supplier:Link/Supplier:120\",\n\t`tabPurchase Order Item`.`project_name` as \"Project\",\n\t`tabPurchase Order Item`.item_code as \"Item Code:Link/Item:120\",\n\t`tabPurchase Order Item`.base_amount as \"Amount:Currency:100\",\n\t`tabPurchase Order Item`.billed_amt as \"Billed Amount:Currency:100\", \n\t(`tabPurchase Order Item`.base_amount - ifnull(`tabPurchase Order Item`.billed_amt, 0)) as \"Amount to Bill:Currency:100\",\n\t`tabPurchase Order Item`.item_name as \"Item Name::150\",\n\t`tabPurchase Order Item`.description as \"Description::200\"\nfrom\n\t`tabPurchase Order`, `tabPurchase Order Item`\nwhere\n\t`tabPurchase Order Item`.`parent` = `tabPurchase Order`.`name`\n\tand `tabPurchase Order`.docstatus = 1\n\tand `tabPurchase Order`.status != \"Stopped\"\n\tand ifnull(`tabPurchase Order Item`.billed_amt, 0) < ifnull(`tabPurchase Order Item`.base_amount, 0)\norder by `tabPurchase Order`.transaction_date asc", "ref_doctype": "Purchase Invoice", diff --git a/erpnext/accounts/report/purchase_register/purchase_register.txt b/erpnext/accounts/report/purchase_register/purchase_register.txt index 847f5f3b6c..f04f8e6498 100644 --- a/erpnext/accounts/report/purchase_register/purchase_register.txt +++ b/erpnext/accounts/report/purchase_register/purchase_register.txt @@ -2,7 +2,7 @@ { "creation": "2013-04-29 16:13:11", "docstatus": 0, - "modified": "2013-04-30 17:51:19", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Purchase Invoice", "report_name": "Purchase Register", diff --git a/erpnext/accounts/report/received_items_to_be_billed/received_items_to_be_billed.txt b/erpnext/accounts/report/received_items_to_be_billed/received_items_to_be_billed.txt index f7afd3b3fb..3ecb2d8879 100644 --- a/erpnext/accounts/report/received_items_to_be_billed/received_items_to_be_billed.txt +++ b/erpnext/accounts/report/received_items_to_be_billed/received_items_to_be_billed.txt @@ -2,13 +2,14 @@ { "creation": "2013-07-30 18:35:10", "docstatus": 0, - "modified": "2014-02-11 11:46:57", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "query": "select\n `tabPurchase Receipt`.`name` as \"Purchase Receipt:Link/Purchase Receipt:120\",\n `tabPurchase Receipt`.`supplier` as \"Supplier:Link/Supplier:120\",\n\t`tabPurchase Receipt`.`posting_date` as \"Date:Date\",\n\t`tabPurchase Receipt Item`.`project_name` as \"Project\",\n\t`tabPurchase Receipt Item`.`item_code` as \"Item:Link/Item:120\",\n\t(`tabPurchase Receipt Item`.`qty` - ifnull((select sum(qty) from `tabPurchase Invoice Item` \n\t where `tabPurchase Invoice Item`.purchase_receipt = `tabPurchase Receipt`.name and\n\t `tabPurchase Invoice Item`.pr_detail = `tabPurchase Receipt Item`.name), 0))\n\t\tas \"Qty:Float:110\",\n\t(`tabPurchase Receipt Item`.`base_amount` - ifnull((select sum(base_amount) from `tabPurchase Invoice Item` \n where `tabPurchase Invoice Item`.purchase_receipt = `tabPurchase Receipt`.name and\n `tabPurchase Invoice Item`.pr_detail = `tabPurchase Receipt Item`.name), 0))\n\t\tas \"Amount:Currency:110\",\n\t`tabPurchase Receipt Item`.`item_name` as \"Item Name::150\",\n\t`tabPurchase Receipt Item`.`description` as \"Description::200\"\nfrom `tabPurchase Receipt`, `tabPurchase Receipt Item`\nwhere\n `tabPurchase Receipt`.docstatus = 1 and\n\t`tabPurchase Receipt`.`status` != \"Stopped\" and\n `tabPurchase Receipt`.name = `tabPurchase Receipt Item`.parent and\n (`tabPurchase Receipt Item`.qty > ifnull((select sum(qty) from `tabPurchase Invoice Item` \n where `tabPurchase Invoice Item`.purchase_receipt = `tabPurchase Receipt`.name and\n `tabPurchase Invoice Item`.pr_detail = `tabPurchase Receipt Item`.name), 0))\norder by `tabPurchase Receipt`.`name` desc", "ref_doctype": "Purchase Invoice", diff --git a/erpnext/accounts/report/sales_invoice_trends/sales_invoice_trends.txt b/erpnext/accounts/report/sales_invoice_trends/sales_invoice_trends.txt index 279ac1269f..4ffc3499bf 100644 --- a/erpnext/accounts/report/sales_invoice_trends/sales_invoice_trends.txt +++ b/erpnext/accounts/report/sales_invoice_trends/sales_invoice_trends.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-13 18:44:21", "docstatus": 0, - "modified": "2013-06-13 18:44:21", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Sales Invoice", "report_name": "Sales Invoice Trends", diff --git a/erpnext/accounts/report/sales_partners_commission/sales_partners_commission.txt b/erpnext/accounts/report/sales_partners_commission/sales_partners_commission.txt index 52bbf3c751..e79d415b96 100644 --- a/erpnext/accounts/report/sales_partners_commission/sales_partners_commission.txt +++ b/erpnext/accounts/report/sales_partners_commission/sales_partners_commission.txt @@ -2,13 +2,14 @@ { "creation": "2013-05-06 12:28:23", "docstatus": 0, - "modified": "2013-05-06 12:41:15", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "query": "SELECT\n sales_partner as \"Sales Partner:Link/Sales Partner:150\",\n\tsum(net_total) as \"Invoiced Amount (Exculsive Tax):Currency:210\",\n\tsum(total_commission) as \"Total Commission:Currency:150\",\n\tsum(total_commission)*100/sum(net_total) as \"Average Commission Rate:Currency:170\"\nFROM\n\t`tabSales Invoice`\nWHERE\n\tdocstatus = 1 and ifnull(net_total, 0) > 0 and ifnull(total_commission, 0) > 0\nGROUP BY\n\tsales_partner\nORDER BY\n\t\"Total Commission:Currency:120\"", "ref_doctype": "Sales Invoice", diff --git a/erpnext/accounts/report/sales_register/sales_register.txt b/erpnext/accounts/report/sales_register/sales_register.txt index dbf41af0d0..40ac3b5018 100644 --- a/erpnext/accounts/report/sales_register/sales_register.txt +++ b/erpnext/accounts/report/sales_register/sales_register.txt @@ -2,7 +2,7 @@ { "creation": "2013-04-23 18:15:29", "docstatus": 0, - "modified": "2013-04-30 17:53:10", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Sales Invoice", "report_name": "Sales Register", diff --git a/erpnext/accounts/report/supplier_account_head/supplier_account_head.txt b/erpnext/accounts/report/supplier_account_head/supplier_account_head.txt index b0554e8576..cf6e322016 100644 --- a/erpnext/accounts/report/supplier_account_head/supplier_account_head.txt +++ b/erpnext/accounts/report/supplier_account_head/supplier_account_head.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-04 12:56:17", "docstatus": 0, - "modified": "2013-06-04 12:56:46", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Accounts", "name": "__common__", "ref_doctype": "Account", "report_name": "Supplier Account Head", diff --git a/erpnext/buying/doctype/quality_inspection/quality_inspection.py b/erpnext/buying/doctype/quality_inspection/quality_inspection.py index 0acb8eed77..972757f40e 100644 --- a/erpnext/buying/doctype/quality_inspection/quality_inspection.py +++ b/erpnext/buying/doctype/quality_inspection/quality_inspection.py @@ -40,7 +40,7 @@ def item_query(doctype, txt, searchfield, start, page_len, filters): from frappe.widgets.reportview import get_match_cond filters.update({ "txt": txt, - "mcond": get_match_cond(filters["from"], searchfield), + "mcond": get_match_cond(filters["from"]), "start": start, "page_len": page_len }) diff --git a/erpnext/buying/report/item_wise_purchase_history/item_wise_purchase_history.txt b/erpnext/buying/report/item_wise_purchase_history/item_wise_purchase_history.txt index ca6b42490c..199599005d 100644 --- a/erpnext/buying/report/item_wise_purchase_history/item_wise_purchase_history.txt +++ b/erpnext/buying/report/item_wise_purchase_history/item_wise_purchase_history.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-03 14:55:53", "docstatus": 0, - "modified": "2013-07-11 12:28:00", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Buying", "name": "__common__", "query": "select\n po_item.item_code as \"Item Code:Link/Item:120\",\n\tpo_item.item_name as \"Item Name::120\",\n\tpo_item.description as \"Description::150\",\n\tpo_item.qty as \"Qty:Float:100\",\n\tpo_item.stock_uom as \"UOM:Link/UOM:80\",\n\tpo_item.base_rate as \"Rate:Currency:120\",\n\tpo_item.base_amount as \"Amount:Currency:120\",\n\tpo.name as \"Purchase Order:Link/Purchase Order:120\",\n\tpo.transaction_date as \"Transaction Date:Date:140\",\n\tpo.supplier as \"Supplier:Link/Supplier:130\",\n\tpo_item.project_name as \"Project:Link/Project:130\",\n\tifnull(po_item.received_qty, 0) as \"Received Qty:Float:120\"\nfrom\n\t`tabPurchase Order` po, `tabPurchase Order Item` po_item\nwhere\n\tpo.name = po_item.parent and po.docstatus = 1\norder by po.name desc", "ref_doctype": "Purchase Order", diff --git a/erpnext/buying/report/purchase_order_trends/purchase_order_trends.txt b/erpnext/buying/report/purchase_order_trends/purchase_order_trends.txt index 658dd4aab1..683279fc20 100644 --- a/erpnext/buying/report/purchase_order_trends/purchase_order_trends.txt +++ b/erpnext/buying/report/purchase_order_trends/purchase_order_trends.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-13 18:45:01", "docstatus": 0, - "modified": "2013-06-13 18:45:01", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Buying", "name": "__common__", "ref_doctype": "Purchase Order", "report_name": "Purchase Order Trends", diff --git a/erpnext/buying/report/requested_items_to_be_ordered/requested_items_to_be_ordered.txt b/erpnext/buying/report/requested_items_to_be_ordered/requested_items_to_be_ordered.txt index 4d3558ca68..c3e91ae29d 100644 --- a/erpnext/buying/report/requested_items_to_be_ordered/requested_items_to_be_ordered.txt +++ b/erpnext/buying/report/requested_items_to_be_ordered/requested_items_to_be_ordered.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-13 16:10:02", "docstatus": 0, - "modified": "2014-01-24 18:19:11", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Buying", "name": "__common__", "query": "select \n mr.name as \"Material Request:Link/Material Request:120\",\n\tmr.transaction_date as \"Date:Date:100\",\n\tmr_item.item_code as \"Item Code:Link/Item:120\",\n\tsum(ifnull(mr_item.qty, 0)) as \"Qty:Float:100\",\n\tsum(ifnull(mr_item.ordered_qty, 0)) as \"Ordered Qty:Float:100\", \n\t(sum(mr_item.qty) - sum(ifnull(mr_item.ordered_qty, 0))) as \"Qty to Order:Float:100\",\n\tmr_item.item_name as \"Item Name::150\",\n\tmr_item.description as \"Description::200\"\nfrom\n\t`tabMaterial Request` mr, `tabMaterial Request Item` mr_item\nwhere\n\tmr_item.parent = mr.name\n\tand mr.material_request_type = \"Purchase\"\n\tand mr.docstatus = 1\n\tand mr.status != \"Stopped\"\ngroup by mr.name, mr_item.item_code\nhaving\n\tsum(ifnull(mr_item.ordered_qty, 0)) < sum(ifnull(mr_item.qty, 0))\norder by mr.transaction_date asc", "ref_doctype": "Purchase Order", diff --git a/erpnext/buying/report/supplier_addresses_and_contacts/supplier_addresses_and_contacts.txt b/erpnext/buying/report/supplier_addresses_and_contacts/supplier_addresses_and_contacts.txt index fac1e9e929..25c11e73c3 100644 --- a/erpnext/buying/report/supplier_addresses_and_contacts/supplier_addresses_and_contacts.txt +++ b/erpnext/buying/report/supplier_addresses_and_contacts/supplier_addresses_and_contacts.txt @@ -2,13 +2,14 @@ { "creation": "2013-10-09 10:38:40", "docstatus": 0, - "modified": "2013-10-09 10:53:52", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Buying", "name": "__common__", "query": "SELECT\n `tabSupplier`.name as \"Supplier:Link/Supplier:120\",\n\t`tabSupplier`.supplier_name as \"Supplier Name::120\",\n\t`tabSupplier`.supplier_type as \"Supplier Type:Link/Supplier Type:120\",\n\tconcat_ws(', ', \n\t\ttrim(',' from `tabAddress`.address_line1), \n\t\ttrim(',' from tabAddress.address_line2), \n\t\ttabAddress.state, tabAddress.pincode, tabAddress.country\n\t) as 'Address::180',\n concat_ws(', ', `tabContact`.first_name, `tabContact`.last_name) as 'Contact Name::180',\n\t`tabContact`.phone as \"Phone\",\n\t`tabContact`.mobile_no as \"Mobile No\",\n\t`tabContact`.email_id as \"Email Id::120\",\n\t`tabContact`.is_primary_contact as \"Is Primary Contact::120\"\nFROM\n\t`tabSupplier`\n\tleft join `tabAddress` on (\n\t\t`tabAddress`.supplier=`tabSupplier`.name\n\t)\n\tleft join `tabContact` on (\n\t\t`tabContact`.supplier=`tabSupplier`.name\n\t)\nWHERE\n\t`tabSupplier`.docstatus<2\nORDER BY\n\t`tabSupplier`.name asc", "ref_doctype": "Supplier", diff --git a/erpnext/config/accounts.py b/erpnext/config/accounts.py index 7ae67fa18b..2a47c2ab4f 100644 --- a/erpnext/config/accounts.py +++ b/erpnext/config/accounts.py @@ -103,9 +103,14 @@ data = [ }, { "type": "doctype", - "name": "Shipping Rules", + "name": "Shipping Rule", "description": _("Rules for adding shipping costs.") }, + { + "type": "doctype", + "name": "Pricing Rule", + "description": _("Rules for applying pricing and discount.") + }, { "type": "doctype", "name": "Currency", diff --git a/erpnext/config/buying.py b/erpnext/config/buying.py index 41f689f287..0c8c2f647a 100644 --- a/erpnext/config/buying.py +++ b/erpnext/config/buying.py @@ -87,6 +87,11 @@ data = [ "description": _("Multiple Item prices."), "route": "Report/Item Price" }, + { + "type": "doctype", + "name": "Pricing Rule", + "description": _("Rules for applying pricing and discount.") + }, ] }, { diff --git a/erpnext/config/selling.py b/erpnext/config/selling.py index 2646167f3a..65cec9e22e 100644 --- a/erpnext/config/selling.py +++ b/erpnext/config/selling.py @@ -121,7 +121,7 @@ data = [ }, { "type": "doctype", - "name": "Shipping Rules", + "name": "Shipping Rule", "description": _("Rules for adding shipping costs.") }, { @@ -135,6 +135,11 @@ data = [ "description": _("Multiple Item prices."), "route": "Report/Item Price" }, + { + "type": "doctype", + "name": "Pricing Rule", + "description": _("Rules for applying pricing and discount.") + }, { "type": "doctype", "name": "Sales BOM", diff --git a/erpnext/controllers/queries.py b/erpnext/controllers/queries.py index d5ea23257d..1f8077fc8d 100644 --- a/erpnext/controllers/queries.py +++ b/erpnext/controllers/queries.py @@ -4,6 +4,7 @@ from __future__ import unicode_literals import frappe from frappe.widgets.reportview import get_match_cond +from frappe.model.db_query import DatabaseQuery def get_filters_cond(doctype, filters, conditions): if filters: @@ -16,9 +17,12 @@ def get_filters_cond(doctype, filters, conditions): else: flt.append([doctype, f[0], '=', f[1]]) - from frappe.widgets.reportview import build_filter_conditions - build_filter_conditions(flt, conditions) - cond = ' and ' + ' and '.join(conditions) + query = DatabaseQuery(doctype) + query.filters = flt + query.conditions = conditions + query.build_filter_conditions() + + cond = ' and ' + ' and '.join(query.conditions) else: cond = '' return cond @@ -36,7 +40,7 @@ def employee_query(doctype, txt, searchfield, start, page_len, filters): case when employee_name like "%(txt)s" then 0 else 1 end, name limit %(start)s, %(page_len)s""" % {'key': searchfield, 'txt': "%%%s%%" % txt, - 'mcond':get_match_cond(doctype, searchfield), 'start': start, 'page_len': page_len}) + 'mcond':get_match_cond(doctype), 'start': start, 'page_len': page_len}) # searches for leads which are not converted def lead_query(doctype, txt, searchfield, start, page_len, filters): @@ -53,7 +57,7 @@ def lead_query(doctype, txt, searchfield, start, page_len, filters): case when company_name like "%(txt)s" then 0 else 1 end, lead_name asc limit %(start)s, %(page_len)s""" % {'key': searchfield, 'txt': "%%%s%%" % txt, - 'mcond':get_match_cond(doctype, searchfield), 'start': start, 'page_len': page_len}) + 'mcond':get_match_cond(doctype), 'start': start, 'page_len': page_len}) # searches for customer def customer_query(doctype, txt, searchfield, start, page_len, filters): @@ -76,7 +80,7 @@ def customer_query(doctype, txt, searchfield, start, page_len, filters): case when customer_name like "%(txt)s" then 0 else 1 end, name, customer_name limit %(start)s, %(page_len)s""" % {'field': fields,'key': searchfield, - 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype, searchfield), + 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype), 'start': start, 'page_len': page_len}) # searches for supplier @@ -98,7 +102,7 @@ def supplier_query(doctype, txt, searchfield, start, page_len, filters): case when supplier_name like "%(txt)s" then 0 else 1 end, name, supplier_name limit %(start)s, %(page_len)s """ % {'field': fields,'key': searchfield, - 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype, searchfield), 'start': start, + 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype), 'start': start, 'page_len': page_len}) def tax_account_query(doctype, txt, searchfield, start, page_len, filters): @@ -134,7 +138,7 @@ def item_query(doctype, txt, searchfield, start, page_len, filters): {fcond} {mcond} limit %(start)s, %(page_len)s """.format(key=searchfield, fcond=get_filters_cond(doctype, filters, conditions), - mcond=get_match_cond(doctype, searchfield)), + mcond=get_match_cond(doctype)), { "today": nowdate(), "txt": "%%%s%%" % txt, @@ -153,7 +157,7 @@ def bom(doctype, txt, searchfield, start, page_len, filters): %(fcond)s %(mcond)s limit %(start)s, %(page_len)s """ % {'key': searchfield, 'txt': "%%%s%%" % txt, 'fcond': get_filters_cond(doctype, filters, conditions), - 'mcond':get_match_cond(doctype, searchfield), 'start': start, 'page_len': page_len}) + 'mcond':get_match_cond(doctype), 'start': start, 'page_len': page_len}) def get_project_name(doctype, txt, searchfield, start, page_len, filters): cond = '' @@ -165,7 +169,7 @@ def get_project_name(doctype, txt, searchfield, start, page_len, filters): and %(cond)s `tabProject`.name like "%(txt)s" %(mcond)s order by `tabProject`.name asc limit %(start)s, %(page_len)s """ % {'cond': cond,'txt': "%%%s%%" % txt, - 'mcond':get_match_cond(doctype, searchfield),'start': start, 'page_len': page_len}) + 'mcond':get_match_cond(doctype),'start': start, 'page_len': page_len}) def get_delivery_notes_to_be_billed(doctype, txt, searchfield, start, page_len, filters): return frappe.db.sql("""select `tabDelivery Note`.name, `tabDelivery Note`.customer_name @@ -202,7 +206,7 @@ def get_batch_no(doctype, txt, searchfield, start, page_len, filters): order by batch_no desc limit %(start)s, %(page_len)s """ % {'item_code': filters['item_code'], 'warehouse': filters['warehouse'], 'posting_date': filters['posting_date'], - 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype, searchfield), + 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype), 'start': start, 'page_len': page_len}) else: return frappe.db.sql("""select name from tabBatch @@ -214,5 +218,5 @@ def get_batch_no(doctype, txt, searchfield, start, page_len, filters): order by name desc limit %(start)s, %(page_len)s""" % {'item_code': filters['item_code'], 'posting_date': filters['posting_date'], 'txt': "%%%s%%" % txt, - 'mcond':get_match_cond(doctype, searchfield),'start': start, + 'mcond':get_match_cond(doctype),'start': start, 'page_len': page_len}) diff --git a/erpnext/home/page/activity/activity.js b/erpnext/home/page/activity/activity.js index f3f2e0499b..fe0d70b83e 100644 --- a/erpnext/home/page/activity/activity.js +++ b/erpnext/home/page/activity/activity.js @@ -23,7 +23,7 @@ frappe.pages['activity'].onload = function(wrapper) { wrapper.appframe.set_title_right("Refresh", function() { list.run(); }); // Build Report Button - if(frappe.boot.profile.can_get_report.indexOf("Feed")!=-1) { + if(frappe.boot.user.can_get_report.indexOf("Feed")!=-1) { wrapper.appframe.add_primary_action(frappe._('Build Report'), function() { frappe.set_route('Report', "Feed"); }, 'icon-th') diff --git a/erpnext/hooks.txt b/erpnext/hooks.txt index 8b0ece2953..679389014c 100644 --- a/erpnext/hooks.txt +++ b/erpnext/hooks.txt @@ -29,10 +29,6 @@ bean_event:*:on_update = erpnext.home.update_feed bean_event:*:on_submit = erpnext.home.update_feed bean_event:Comment:on_update = erpnext.home.make_comment_feed -bean_event:*:on_update = frappe.core.doctype.notification_count.notification_count.clear_doctype_notifications -bean_event:*:on_cancel = frappe.core.doctype.notification_count.notification_count.clear_doctype_notifications -bean_event:*:on_trash = frappe.core.doctype.notification_count.notification_count.clear_doctype_notifications - bean_event:Stock Entry:on_submit = erpnext.stock.doctype.material_request.material_request.update_completed_qty bean_event:Stock Entry:on_cancel = erpnext.stock.doctype.material_request.material_request.update_completed_qty @@ -43,18 +39,18 @@ standard_queries = Customer:erpnext.selling.doctype.customer.customer.get_custom #### Frequently -scheduler_event = all:erpnext.support.doctype.support_ticket.get_support_mails.get_support_mails -scheduler_event = all:erpnext.hr.doctype.job_applicant.get_job_applications.get_job_applications -scheduler_event = all:erpnext.selling.doctype.lead.get_leads.get_leads +scheduler_event:all = erpnext.support.doctype.support_ticket.get_support_mails.get_support_mails +scheduler_event:all = erpnext.hr.doctype.job_applicant.get_job_applications.get_job_applications +scheduler_event:all = erpnext.selling.doctype.lead.get_leads.get_leads #### Daily -scheduler_event = daily:erpnext.accounts.doctype.sales_invoice.sales_invoice.manage_recurring_invoices -scheduler_event = daily:erpnext.setup.doctype.backup_manager.backup_manager.take_backups_daily -scheduler_event = daily:erpnext.stock.utils.reorder_item -scheduler_event = daily:erpnext.setup.doctype.email_digest.email_digest.send -scheduler_event = daily:support.doctype.support_ticket.support_ticket.auto_close_tickets +scheduler_event:daily = erpnext.accounts.doctype.sales_invoice.sales_invoice.manage_recurring_invoices +scheduler_event:daily_long = erpnext.setup.doctype.backup_manager.backup_manager.take_backups_daily +scheduler_event:daily = erpnext.stock.utils.reorder_item +scheduler_event:daily = erpnext.setup.doctype.email_digest.email_digest.send +scheduler_event:daily = erpnext.support.doctype.support_ticket.support_ticket.auto_close_tickets #### Weekly -scheduler_event = weekly:erpnext.setup.doctype.backup_manager.backup_manager.take_backups_weekly +scheduler_event:weekly_long = erpnext.setup.doctype.backup_manager.backup_manager.take_backups_weekly diff --git a/erpnext/hr/doctype/employee/employee.js b/erpnext/hr/doctype/employee/employee.js index 80150f1589..c27a4c56a2 100644 --- a/erpnext/hr/doctype/employee/employee.js +++ b/erpnext/hr/doctype/employee/employee.js @@ -5,7 +5,7 @@ frappe.provide("erpnext.hr"); erpnext.hr.EmployeeController = frappe.ui.form.Controller.extend({ setup: function() { this.frm.fields_dict.user_id.get_query = function(doc, cdt, cdn) { - return { query:"frappe.core.doctype.profile.profile.profile_query"} } + return { query:"frappe.core.doctype.user.user.user_query"} } this.frm.fields_dict.reports_to.get_query = function(doc, cdt, cdn) { return { query: "erpnext.controllers.queries.employee_query"} } }, @@ -33,8 +33,8 @@ erpnext.hr.EmployeeController = frappe.ui.form.Controller.extend({ callback: function(r) { var df = frappe.meta.get_docfield("Employee Leave Approver", "leave_approver", me.frm.doc.name); - df.options = $.map(r.message, function(profile) { - return {value: profile, label: frappe.user_info(profile).fullname}; + df.options = $.map(r.message, function(user) { + return {value: user, label: frappe.user_info(user).fullname}; }); me.frm.fields_dict.employee_leave_approvers.refresh(); } diff --git a/erpnext/hr/doctype/employee/employee.py b/erpnext/hr/doctype/employee/employee.py index 5838116a88..ad943d391d 100644 --- a/erpnext/hr/doctype/employee/employee.py +++ b/erpnext/hr/doctype/employee/employee.py @@ -39,10 +39,10 @@ class DocType(DocListController): self.validate_duplicate_user_id() def on_update(self): - if self.doc.user_id: + if self.doc.user_id and frappe.db.get_value("User", self.doc.user_id, 'docstatus') == 0: self.restrict_user() self.update_user_default() - self.update_profile() + self.update_user() self.update_dob_event() self.restrict_leave_approver() @@ -71,47 +71,47 @@ class DocType(DocListController): frappe.defaults.add_default("Employee", self.doc.name, user, "Restriction") - def update_profile(self): + def update_user(self): # add employee role if missing if not "Employee" in frappe.db.sql_list("""select role from tabUserRole where parent=%s""", self.doc.user_id): - from frappe.profile import add_role + from frappe.utils.user import add_role add_role(self.doc.user_id, "Employee") - profile_wrapper = frappe.bean("Profile", self.doc.user_id) + user_wrapper = frappe.bean("User", self.doc.user_id) - # copy details like Fullname, DOB and Image to Profile + # copy details like Fullname, DOB and Image to User if self.doc.employee_name: employee_name = self.doc.employee_name.split(" ") if len(employee_name) >= 3: - profile_wrapper.doc.last_name = " ".join(employee_name[2:]) - profile_wrapper.doc.middle_name = employee_name[1] + user_wrapper.doc.last_name = " ".join(employee_name[2:]) + user_wrapper.doc.middle_name = employee_name[1] elif len(employee_name) == 2: - profile_wrapper.doc.last_name = employee_name[1] + user_wrapper.doc.last_name = employee_name[1] - profile_wrapper.doc.first_name = employee_name[0] + user_wrapper.doc.first_name = employee_name[0] if self.doc.date_of_birth: - profile_wrapper.doc.birth_date = self.doc.date_of_birth + user_wrapper.doc.birth_date = self.doc.date_of_birth if self.doc.gender: - profile_wrapper.doc.gender = self.doc.gender + user_wrapper.doc.gender = self.doc.gender if self.doc.image: - if not profile_wrapper.doc.user_image == self.doc.image: - profile_wrapper.doc.user_image = self.doc.image + if not user_wrapper.doc.user_image == self.doc.image: + user_wrapper.doc.user_image = self.doc.image try: frappe.doc({ "doctype": "File Data", "file_name": self.doc.image, - "attached_to_doctype": "Profile", + "attached_to_doctype": "User", "attached_to_name": self.doc.user_id }).insert() except frappe.DuplicateEntryError, e: # already exists pass - profile_wrapper.ignore_permissions = True - profile_wrapper.save() + user_wrapper.ignore_permissions = True + user_wrapper.save() def validate_date(self): if self.doc.date_of_birth and self.doc.date_of_joining and getdate(self.doc.date_of_birth) >= getdate(self.doc.date_of_joining): @@ -143,7 +143,7 @@ class DocType(DocListController): throw(_("Please enter relieving date.")) def validate_for_enabled_user_id(self): - enabled = frappe.db.sql("""select name from `tabProfile` where + enabled = frappe.db.sql("""select name from `tabUser` where name=%s and enabled=1""", self.doc.user_id) if not enabled: throw("{id}: {user_id} {msg}".format(**{ @@ -164,11 +164,11 @@ class DocType(DocListController): })) def validate_employee_leave_approver(self): - from frappe.profile import Profile + from frappe.utils.user import User from erpnext.hr.doctype.leave_application.leave_application import InvalidLeaveApproverError for l in self.doclist.get({"parentfield": "employee_leave_approvers"}): - if "Leave Approver" not in Profile(l.leave_approver).get_roles(): + if "Leave Approver" not in User(l.leave_approver).get_roles(): throw(_("Invalid Leave Approver") + ": \"" + l.leave_approver + "\"", exc=InvalidLeaveApproverError) @@ -212,4 +212,4 @@ def get_retirement_date(date_of_birth=None): if date_of_birth: dt = getdate(date_of_birth) + datetime.timedelta(21915) ret = {'date_of_retirement': dt.strftime('%Y-%m-%d')} - return ret \ No newline at end of file + return ret diff --git a/erpnext/hr/doctype/employee/employee.txt b/erpnext/hr/doctype/employee/employee.txt index 795f4de4af..bc21ff95a0 100644 --- a/erpnext/hr/doctype/employee/employee.txt +++ b/erpnext/hr/doctype/employee/employee.txt @@ -2,7 +2,7 @@ { "creation": "2013-03-07 09:04:18", "docstatus": 0, - "modified": "2014-02-03 18:06:03", + "modified": "2014-02-03 18:06:04", "modified_by": "Administrator", "owner": "Administrator" }, @@ -126,7 +126,7 @@ "fieldname": "user_id", "fieldtype": "Link", "label": "User ID", - "options": "Profile" + "options": "User" }, { "doctype": "DocField", diff --git a/erpnext/hr/doctype/job_applicant/get_job_applications.py b/erpnext/hr/doctype/job_applicant/get_job_applications.py index 91d3fad25a..4f753450d0 100644 --- a/erpnext/hr/doctype/job_applicant/get_job_applications.py +++ b/erpnext/hr/doctype/job_applicant/get_job_applications.py @@ -21,6 +21,7 @@ class JobsMailbox(POP3Mailbox): applicant = frappe.bean("Job Applicant", name) if applicant.doc.status!="Rejected": applicant.doc.status = "Open" + applicant.ignore_permissions = True applicant.doc.save() else: name = (mail.from_real_name and (mail.from_real_name + " - ") or "") \ @@ -32,6 +33,8 @@ class JobsMailbox(POP3Mailbox): "email_id": mail.from_email, "status": "Open" }) + applicant.ignore_permissions = True + applicant.ignore_mandatory = True applicant.insert() mail.save_attachments_in_doc(applicant.doc) diff --git a/erpnext/hr/doctype/leave_application/leave_application.js b/erpnext/hr/doctype/leave_application/leave_application.js index 447f7ff46b..2a6223af44 100755 --- a/erpnext/hr/doctype/leave_application/leave_application.js +++ b/erpnext/hr/doctype/leave_application/leave_application.js @@ -16,8 +16,8 @@ cur_frm.cscript.onload = function(doc, dt, dn) { method: "erpnext.hr.utils.get_leave_approver_list", callback: function(r) { cur_frm.set_df_property("leave_approver", "options", $.map(r.message, - function(profile) { - return {value: profile, label: frappe.user_info(profile).fullname}; + function(user) { + return {value: user, label: frappe.user_info(user).fullname}; })); if(leave_approver) cur_frm.set_value("leave_approver", leave_approver); cur_frm.cscript.get_leave_balance(cur_frm.doc); @@ -116,6 +116,6 @@ cur_frm.cscript.calculate_total_days = function(doc, dt, dn) { cur_frm.fields_dict.employee.get_query = function() { return { - query: "hr.doctype.leave_application.leave_application.query_for_permitted_employees" + query: "erpnext.hr.doctype.leave_application.leave_application.query_for_permitted_employees" }; } \ No newline at end of file diff --git a/erpnext/hr/doctype/leave_application/leave_application.txt b/erpnext/hr/doctype/leave_application/leave_application.txt index 038c29ddef..b56a0ed120 100644 --- a/erpnext/hr/doctype/leave_application/leave_application.txt +++ b/erpnext/hr/doctype/leave_application/leave_application.txt @@ -2,7 +2,7 @@ { "creation": "2013-02-20 11:18:11", "docstatus": 0, - "modified": "2014-01-20 17:48:55", + "modified": "2014-01-20 17:48:56", "modified_by": "Administrator", "owner": "Administrator" }, @@ -55,7 +55,7 @@ "fieldname": "leave_approver", "fieldtype": "Select", "label": "Leave Approver", - "options": "link:Profile", + "options": "link:User", "permlevel": 0 }, { diff --git a/erpnext/hr/doctype/leave_application/test_leave_application.py b/erpnext/hr/doctype/leave_application/test_leave_application.py index 56381fcc26..30f0cb7db9 100644 --- a/erpnext/hr/doctype/leave_application/test_leave_application.py +++ b/erpnext/hr/doctype/leave_application/test_leave_application.py @@ -41,7 +41,7 @@ class TestLeaveApplication(unittest.TestCase): def test_block_list(self): self._clear_roles() - from frappe.profile import add_role + from frappe.utils.user import add_role add_role("test1@example.com", "HR User") frappe.db.set_value("Department", "_Test Department", @@ -64,7 +64,7 @@ class TestLeaveApplication(unittest.TestCase): self._clear_roles() self._clear_applications() - from frappe.profile import add_role + from frappe.utils.user import add_role add_role("test@example.com", "Employee") add_role("test2@example.com", "Leave Approver") @@ -80,7 +80,7 @@ class TestLeaveApplication(unittest.TestCase): def test_global_block_list(self): self._clear_roles() - from frappe.profile import add_role + from frappe.utils.user import add_role add_role("test1@example.com", "Employee") add_role("test@example.com", "Leave Approver") @@ -105,7 +105,7 @@ class TestLeaveApplication(unittest.TestCase): def test_leave_approval(self): self._clear_roles() - from frappe.profile import add_role + from frappe.utils.user import add_role add_role("test@example.com", "Employee") add_role("test1@example.com", "Leave Approver") add_role("test2@example.com", "Leave Approver") diff --git a/erpnext/hr/doctype/leave_block_list_allow/leave_block_list_allow.txt b/erpnext/hr/doctype/leave_block_list_allow/leave_block_list_allow.txt index 94fd3de796..ea548004ce 100644 --- a/erpnext/hr/doctype/leave_block_list_allow/leave_block_list_allow.txt +++ b/erpnext/hr/doctype/leave_block_list_allow/leave_block_list_allow.txt @@ -2,7 +2,7 @@ { "creation": "2013-02-22 01:27:47", "docstatus": 0, - "modified": "2013-12-20 19:23:19", + "modified": "2013-12-20 19:23:18", "modified_by": "Administrator", "owner": "Administrator" }, @@ -19,7 +19,7 @@ "in_list_view": 1, "label": "Allow User", "name": "__common__", - "options": "Profile", + "options": "User", "parent": "Leave Block List Allow", "parentfield": "fields", "parenttype": "DocType", diff --git a/erpnext/hr/report/employee_birthday/employee_birthday.txt b/erpnext/hr/report/employee_birthday/employee_birthday.txt index 575ae73352..a114e5c181 100644 --- a/erpnext/hr/report/employee_birthday/employee_birthday.txt +++ b/erpnext/hr/report/employee_birthday/employee_birthday.txt @@ -2,13 +2,14 @@ { "creation": "2013-05-06 17:56:03", "docstatus": 0, - "modified": "2013-05-06 17:56:03", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "HR", "name": "__common__", "ref_doctype": "Employee", "report_name": "Employee Birthday", diff --git a/erpnext/hr/report/employee_information/employee_information.txt b/erpnext/hr/report/employee_information/employee_information.txt index b9d190b029..8bd3c4c268 100644 --- a/erpnext/hr/report/employee_information/employee_information.txt +++ b/erpnext/hr/report/employee_information/employee_information.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-06 18:43:53", "docstatus": 0, - "modified": "2013-05-06 18:47:43", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "doctype": "Report", "is_standard": "Yes", "json": "{\"filters\":[],\"columns\":[[\"name\",\"Employee\"],[\"employee_number\",\"Employee\"],[\"date_of_joining\",\"Employee\"],[\"branch\",\"Employee\"],[\"department\",\"Employee\"],[\"designation\",\"Employee\"],[\"gender\",\"Employee\"],[\"status\",\"Employee\"],[\"company\",\"Employee\"],[\"employment_type\",\"Employee\"],[\"grade\",\"Employee\"],[\"reports_to\",\"Employee\"],[\"company_email\",\"Employee\"]],\"sort_by\":\"Employee.bank_ac_no\",\"sort_order\":\"desc\",\"sort_by_next\":\"\",\"sort_order_next\":\"desc\"}", + "module": "HR", "name": "__common__", "ref_doctype": "Employee", "report_name": "Employee Information", diff --git a/erpnext/hr/report/employee_leave_balance/employee_leave_balance.txt b/erpnext/hr/report/employee_leave_balance/employee_leave_balance.txt index 2a6d74f20a..f682c64217 100644 --- a/erpnext/hr/report/employee_leave_balance/employee_leave_balance.txt +++ b/erpnext/hr/report/employee_leave_balance/employee_leave_balance.txt @@ -2,13 +2,14 @@ { "creation": "2013-02-22 15:29:34", "docstatus": 0, - "modified": "2013-02-22 15:53:01", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "HR", "name": "__common__", "ref_doctype": "Employee", "report_name": "Employee Leave Balance", diff --git a/erpnext/hr/report/monthly_attendance_sheet/monthly_attendance_sheet.txt b/erpnext/hr/report/monthly_attendance_sheet/monthly_attendance_sheet.txt index 3c53aae8e4..5c51c4ba6e 100644 --- a/erpnext/hr/report/monthly_attendance_sheet/monthly_attendance_sheet.txt +++ b/erpnext/hr/report/monthly_attendance_sheet/monthly_attendance_sheet.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-13 14:04:03", "docstatus": 0, - "modified": "2013-05-13 14:32:42", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 0, "doctype": "Report", "is_standard": "Yes", + "module": "HR", "name": "__common__", "ref_doctype": "Attendance", "report_name": "Monthly Attendance Sheet", diff --git a/erpnext/hr/report/monthly_salary_register/monthly_salary_register.txt b/erpnext/hr/report/monthly_salary_register/monthly_salary_register.txt index b0d5880eaf..80b0c136a7 100644 --- a/erpnext/hr/report/monthly_salary_register/monthly_salary_register.txt +++ b/erpnext/hr/report/monthly_salary_register/monthly_salary_register.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-07 18:09:42", "docstatus": 0, - "modified": "2013-05-07 18:09:42", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "HR", "name": "__common__", "ref_doctype": "Salary Slip", "report_name": "Monthly Salary Register", diff --git a/erpnext/manufacturing/report/completed_production_orders/completed_production_orders.txt b/erpnext/manufacturing/report/completed_production_orders/completed_production_orders.txt index facda7e903..558ef3eedd 100644 --- a/erpnext/manufacturing/report/completed_production_orders/completed_production_orders.txt +++ b/erpnext/manufacturing/report/completed_production_orders/completed_production_orders.txt @@ -2,13 +2,14 @@ { "creation": "2013-08-12 12:44:27", "docstatus": 0, - "modified": "2013-08-12 12:44:27", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Manufacturing", "name": "__common__", "query": "SELECT\n `tabProduction Order`.name as \"Production Order:Link/Production Order:200\",\n `tabProduction Order`.creation as \"Date:Date:120\",\n `tabProduction Order`.production_item as \"Item:Link/Item:150\",\n `tabProduction Order`.qty as \"To Produce:Int:100\",\n `tabProduction Order`.produced_qty as \"Produced:Int:100\"\nFROM\n `tabProduction Order`\nWHERE\n `tabProduction Order`.docstatus=1\n AND ifnull(`tabProduction Order`.produced_qty,0) = `tabProduction Order`.qty", "ref_doctype": "Production Order", diff --git a/erpnext/manufacturing/report/issued_items_against_production_order/issued_items_against_production_order.txt b/erpnext/manufacturing/report/issued_items_against_production_order/issued_items_against_production_order.txt index a5a03bfa00..cb0808b9fd 100644 --- a/erpnext/manufacturing/report/issued_items_against_production_order/issued_items_against_production_order.txt +++ b/erpnext/manufacturing/report/issued_items_against_production_order/issued_items_against_production_order.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-03 17:48:46", "docstatus": 0, - "modified": "2013-05-07 11:49:56", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 0, "doctype": "Report", "is_standard": "Yes", + "module": "Manufacturing", "name": "__common__", "query": "select\n ste.production_order as \"Production Order:Link/Production Order:120\",\n ste.posting_date as \"Issue Date:Date:140\",\n ste_item.item_code as \"Item Code:Link/Item:120\",\n\tste_item.description as \"Description::150\",\n\tste_item.transfer_qty as \"Qty:Float:100\",\n\tste_item.stock_uom as \"UOM:Link/UOM:80\",\n\tste_item.amount as \"Amount:Currency:120\",\n\tste_item.serial_no as \"Serial No:Link/Serial No:80\",\n\tste_item.s_warehouse as \"Source Warehouse:Link/Warehouse:120\",\n\tste_item.t_warehouse as \"Target Warehouse:Link/Warehouse:120\",\n\tpro.production_item as \"Finished Goods:Link/Item:120\", \n\tste.name as \"Stock Entry:Link/Stock Entry:120\"\nfrom\n\t`tabStock Entry` ste, `tabStock Entry Detail` ste_item, `tabProduction Order` pro\nwhere\n\tifnull(ste.production_order, '') != '' and ste.name = ste_item.parent \n\tand ste.production_order = pro.name and ste.docstatus = 1 \n\tand ste.purpose = 'Manufacture/Repack'\norder by ste.posting_date, ste.production_order, ste_item.item_code", "ref_doctype": "Production Order", diff --git a/erpnext/manufacturing/report/open_production_orders/open_production_orders.txt b/erpnext/manufacturing/report/open_production_orders/open_production_orders.txt index f92bdd32d3..861392548a 100644 --- a/erpnext/manufacturing/report/open_production_orders/open_production_orders.txt +++ b/erpnext/manufacturing/report/open_production_orders/open_production_orders.txt @@ -2,13 +2,14 @@ { "creation": "2013-08-12 12:32:30", "docstatus": 0, - "modified": "2013-08-12 12:42:29", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Manufacturing", "name": "__common__", "query": "SELECT\n `tabProduction Order`.name as \"Production Order:Link/Production Order:200\",\n `tabProduction Order`.creation as \"Date:Date:120\",\n `tabProduction Order`.production_item as \"Item:Link/Item:150\",\n `tabProduction Order`.qty as \"To Produce:Int:100\",\n `tabProduction Order`.produced_qty as \"Produced:Int:100\"\nFROM\n `tabProduction Order`\nWHERE\n `tabProduction Order`.docstatus=1\n AND ifnull(`tabProduction Order`.produced_qty,0) < `tabProduction Order`.qty\n AND NOT EXISTS (SELECT name from `tabStock Entry` where production_order =`tabProduction Order`.name) ", "ref_doctype": "Production Order", diff --git a/erpnext/manufacturing/report/production_orders_in_progress/production_orders_in_progress.txt b/erpnext/manufacturing/report/production_orders_in_progress/production_orders_in_progress.txt index 3d3493f8a1..8c4e1d2fbf 100644 --- a/erpnext/manufacturing/report/production_orders_in_progress/production_orders_in_progress.txt +++ b/erpnext/manufacturing/report/production_orders_in_progress/production_orders_in_progress.txt @@ -2,13 +2,14 @@ { "creation": "2013-08-12 12:43:47", "docstatus": 0, - "modified": "2013-08-12 12:43:47", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Manufacturing", "name": "__common__", "query": "SELECT\n `tabProduction Order`.name as \"Production Order:Link/Production Order:200\",\n `tabProduction Order`.creation as \"Date:Date:120\",\n `tabProduction Order`.production_item as \"Item:Link/Item:150\",\n `tabProduction Order`.qty as \"To Produce:Int:100\",\n `tabProduction Order`.produced_qty as \"Produced:Int:100\"\nFROM\n `tabProduction Order`\nWHERE\n `tabProduction Order`.docstatus=1\n AND ifnull(`tabProduction Order`.produced_qty,0) < `tabProduction Order`.qty\n AND EXISTS (SELECT name from `tabStock Entry` where production_order =`tabProduction Order`.name) ", "ref_doctype": "Production Order", diff --git a/erpnext/patches.txt b/erpnext/patches.txt index 08caa76c83..fec9bb0844 100644 --- a/erpnext/patches.txt +++ b/erpnext/patches.txt @@ -1,3 +1,4 @@ +erpnext.patches.4_0.validate_v3_patch erpnext.patches.4_0.update_user_properties erpnext.patches.4_0.move_warehouse_user_to_restrictions erpnext.patches.4_0.new_permissions @@ -26,3 +27,4 @@ erpnext.patches.4_0.customer_discount_to_pricing_rule execute:frappe.db.sql("""delete from `tabWebsite Item Group` where ifnull(item_group, '')=''""") erpnext.patches.4_0.remove_module_home_pages erpnext.patches.4_0.split_email_settings +erpnext.patches.4_0.fix_employee_user_id \ No newline at end of file diff --git a/erpnext/patches/4_0/customer_discount_to_pricing_rule.py b/erpnext/patches/4_0/customer_discount_to_pricing_rule.py index b310a1fa3c..156630138c 100644 --- a/erpnext/patches/4_0/customer_discount_to_pricing_rule.py +++ b/erpnext/patches/4_0/customer_discount_to_pricing_rule.py @@ -7,6 +7,8 @@ import frappe def execute(): frappe.reload_doc("accounts", "doctype", "pricing_rule") + frappe.db.auto_commit_on_many_writes = True + for d in frappe.db.sql("""select * from `tabCustomer Discount` where ifnull(parent, '') != '' and docstatus < 2""", as_dict=1): if not d.item_group: @@ -24,6 +26,7 @@ def execute(): "price_or_discount": "Discount", "discount_percentage": d.discount }]).insert() - + + frappe.db.auto_commit_on_many_writes = False frappe.delete_doc("DocType", "Customer Discount") \ No newline at end of file diff --git a/erpnext/patches/4_0/fix_employee_user_id.py b/erpnext/patches/4_0/fix_employee_user_id.py new file mode 100644 index 0000000000..71107f8301 --- /dev/null +++ b/erpnext/patches/4_0/fix_employee_user_id.py @@ -0,0 +1,13 @@ +import frappe +from frappe.utils import get_fullname + +def execute(): + for user_id in frappe.db.sql_list("""select distinct user_id from `tabEmployee` + where ifnull(user_id, '')!='' + group by user_id having count(name) > 1"""): + + fullname = get_fullname(user_id) + employee = frappe.db.get_value("Employee", {"employee_name": fullname, "user_id": user_id}) + if employee: + frappe.db.sql("""update `tabEmployee` set user_id=null + where user_id=%s and name!=%s""", (user_id, employee)) \ No newline at end of file diff --git a/erpnext/patches/4_0/move_warehouse_user_to_restrictions.py b/erpnext/patches/4_0/move_warehouse_user_to_restrictions.py index d199a42669..16d3b29c96 100644 --- a/erpnext/patches/4_0/move_warehouse_user_to_restrictions.py +++ b/erpnext/patches/4_0/move_warehouse_user_to_restrictions.py @@ -6,8 +6,8 @@ import frappe def execute(): from frappe.core.page.user_properties import user_properties - for warehouse, profile in frappe.db.sql("""select parent, user from `tabWarehouse User`"""): - user_properties.add(profile, "Warehouse", warehouse) + for warehouse, user in frappe.db.sql("""select parent, user from `tabWarehouse User`"""): + user_properties.add(user, "Warehouse", warehouse) frappe.delete_doc("DocType", "Warehouse User") frappe.reload_doc("stock", "doctype", "warehouse") \ No newline at end of file diff --git a/erpnext/patches/4_0/update_user_properties.py b/erpnext/patches/4_0/update_user_properties.py index 5070bfdf1a..6dac125c1c 100644 --- a/erpnext/patches/4_0/update_user_properties.py +++ b/erpnext/patches/4_0/update_user_properties.py @@ -42,10 +42,10 @@ def update_user_match(): meta = frappe.get_doctype(doctype) # for each user with roles of this doctype, check if match condition applies - for profile in frappe.db.sql_list("""select name from `tabProfile` + for user in frappe.db.sql_list("""select name from `tabUser` where enabled=1 and user_type='System User'"""): - user_roles = frappe.get_roles(profile) + user_roles = frappe.get_roles(user) perms = meta.get({"doctype": "DocPerm", "permlevel": 0, "role": ["in", [["All"] + user_roles]], "read": 1}) @@ -69,9 +69,9 @@ def update_user_match(): # add that doc's restriction to that user for match in user_matches: for name in frappe.db.sql_list("""select name from `tab{doctype}` - where `{field}`=%s""".format(doctype=doctype, field=match.split(":")[0]), profile): + where `{field}`=%s""".format(doctype=doctype, field=match.split(":")[0]), user): - frappe.defaults.add_default(doctype, name, profile, "Restriction") + frappe.defaults.add_default(doctype, name, user, "Restriction") def add_employee_restrictions_to_leave_approver(): from frappe.core.page.user_properties import user_properties diff --git a/erpnext/patches/4_0/validate_v3_patch.py b/erpnext/patches/4_0/validate_v3_patch.py new file mode 100644 index 0000000000..5041a81ad3 --- /dev/null +++ b/erpnext/patches/4_0/validate_v3_patch.py @@ -0,0 +1,12 @@ +# Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors +# License: GNU General Public License v3. See license.txt + +from __future__ import unicode_literals +import frappe + +def execute(): + from frappe.modules.patch_handler import executed + last_v3_patch = 'patches.1401.fix_planned_qty' + if not executed(last_v3_patch): + raise Exception, "site not ready to migrate to version 4" + \ No newline at end of file diff --git a/erpnext/projects/doctype/task/task.py b/erpnext/projects/doctype/task/task.py index 6f0ff927b6..0e7678118f 100644 --- a/erpnext/projects/doctype/task/task.py +++ b/erpnext/projects/doctype/task/task.py @@ -85,5 +85,5 @@ def get_project(doctype, txt, searchfield, start, page_len, filters): %(mcond)s order by name limit %(start)s, %(page_len)s """ % {'key': searchfield, - 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype, searchfield), + 'txt': "%%%s%%" % txt, 'mcond':get_match_cond(doctype), 'start': start, 'page_len': page_len}) \ No newline at end of file diff --git a/erpnext/projects/doctype/time_log_batch_detail/time_log_batch_detail.txt b/erpnext/projects/doctype/time_log_batch_detail/time_log_batch_detail.txt index 973fc576b7..3531a877df 100644 --- a/erpnext/projects/doctype/time_log_batch_detail/time_log_batch_detail.txt +++ b/erpnext/projects/doctype/time_log_batch_detail/time_log_batch_detail.txt @@ -2,7 +2,7 @@ { "creation": "2013-03-05 09:11:06", "docstatus": 0, - "modified": "2013-12-20 19:21:53", + "modified": "2013-12-20 19:21:54", "modified_by": "Administrator", "owner": "Administrator" }, @@ -40,7 +40,7 @@ "fieldname": "created_by", "fieldtype": "Link", "label": "Created By", - "options": "Profile", + "options": "User", "read_only": 1 }, { diff --git a/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.py b/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.py index be3d6ce558..c652ca79ac 100644 --- a/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.py +++ b/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.py @@ -15,7 +15,7 @@ def execute(filters=None): "To Datetime::140", "Hours::70", "Activity Type::120", "Task:Link/Task:150", "Task Subject::180", "Project:Link/Project:120", "Status::70"] - profile_map = get_profile_map() + user_map = get_user_map() task_map = get_task_map() conditions = build_conditions(filters) @@ -23,17 +23,17 @@ def execute(filters=None): where docstatus < 2 %s order by owner asc""" % (conditions, ), filters, as_dict=1) if time_logs: - profiles = [time_logs[0].owner] + users = [time_logs[0].owner] data = [] total_hours = total_employee_hours = count = 0 for tl in time_logs: - if tl.owner not in profiles: - profiles.append(tl.owner) + if tl.owner not in users: + users.append(tl.owner) data.append(["", "", "", "Total", total_employee_hours, "", "", "", "", ""]) total_employee_hours = 0 - data.append([tl.name, profile_map[tl.owner], tl.from_time, tl.to_time, tl.hours, + data.append([tl.name, user_map[tl.owner], tl.from_time, tl.to_time, tl.hours, tl.activity_type, tl.task, task_map.get(tl.task), tl.project, tl.status]) count += 1 @@ -48,15 +48,15 @@ def execute(filters=None): return columns, data -def get_profile_map(): - profiles = frappe.db.sql("""select name, +def get_user_map(): + users = frappe.db.sql("""select name, concat(first_name, if(last_name, (' ' + last_name), '')) as fullname - from tabProfile""", as_dict=1) - profile_map = {} - for p in profiles: - profile_map.setdefault(p.name, []).append(p.fullname) + from tabUser""", as_dict=1) + user_map = {} + for p in users: + user_map.setdefault(p.name, []).append(p.fullname) - return profile_map + return user_map def get_task_map(): tasks = frappe.db.sql("""select name, subject from tabTask""", as_dict=1) diff --git a/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.txt b/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.txt index 5bf3e6d57e..fe8feb0a5b 100644 --- a/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.txt +++ b/erpnext/projects/report/daily_time_log_summary/daily_time_log_summary.txt @@ -2,13 +2,14 @@ { "creation": "2013-04-03 11:27:52", "docstatus": 0, - "modified": "2013-04-03 11:48:07", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Projects", "name": "__common__", "ref_doctype": "Time Log", "report_name": "Daily Time Log Summary", diff --git a/erpnext/projects/report/project_wise_stock_tracking/project_wise_stock_tracking.txt b/erpnext/projects/report/project_wise_stock_tracking/project_wise_stock_tracking.txt index 89f5085351..4a8953696d 100644 --- a/erpnext/projects/report/project_wise_stock_tracking/project_wise_stock_tracking.txt +++ b/erpnext/projects/report/project_wise_stock_tracking/project_wise_stock_tracking.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-03 17:37:41", "docstatus": 0, - "modified": "2013-06-03 17:37:41", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Projects", "name": "__common__", "ref_doctype": "Project", "report_name": "Project wise Stock Tracking ", diff --git a/erpnext/public/js/queries.js b/erpnext/public/js/queries.js index 86db28e79b..966b27dd1a 100644 --- a/erpnext/public/js/queries.js +++ b/erpnext/public/js/queries.js @@ -1,11 +1,11 @@ // Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors // License: GNU General Public License v3. See license.txt -// searches for enabled profiles +// searches for enabled users frappe.provide("erpnext.queries"); $.extend(erpnext.queries, { - profile: function() { - return { query: "frappe.core.doctype.profile.profile.profile_query" }; + user: function() { + return { query: "frappe.core.doctype.user.user.user_query" }; }, lead: function() { diff --git a/erpnext/public/js/toolbar.js b/erpnext/public/js/toolbar.js index 53efe30dad..c0645e39a9 100644 --- a/erpnext/public/js/toolbar.js +++ b/erpnext/public/js/toolbar.js @@ -5,9 +5,9 @@ frappe.provide('erpnext.toolbar'); erpnext.toolbar.setup = function() { - // profile + // user var $user = $('#toolbar-user'); - $user.append('
  • ' + $user.append('
  • ' +frappe._("My Settings")+'...
  • '); $user.append('
  • '); $user.append('
  • \ diff --git a/erpnext/selling/doctype/lead/get_leads.py b/erpnext/selling/doctype/lead/get_leads.py index 169f25059d..77a94f7269 100644 --- a/erpnext/selling/doctype/lead/get_leads.py +++ b/erpnext/selling/doctype/lead/get_leads.py @@ -22,6 +22,7 @@ def add_sales_communication(subject, content, sender, real_name, mail=None, "source": "Email" }) lead.ignore_permissions = True + lead.ignore_mandatory = True lead.insert() lead_name = lead.doc.name diff --git a/erpnext/selling/doctype/lead/lead.js b/erpnext/selling/doctype/lead/lead.js index 532b7788f5..c942be19e0 100644 --- a/erpnext/selling/doctype/lead/lead.js +++ b/erpnext/selling/doctype/lead/lead.js @@ -12,14 +12,14 @@ erpnext.LeadController = frappe.ui.form.Controller.extend({ }, onload: function() { - if(cur_frm.fields_dict.lead_owner.df.options.match(/^Profile/)) { + if(cur_frm.fields_dict.lead_owner.df.options.match(/^User/)) { cur_frm.fields_dict.lead_owner.get_query = function(doc, cdt, cdn) { - return { query:"frappe.core.doctype.profile.profile.profile_query" } } + return { query:"frappe.core.doctype.user.user.user_query" } } } - if(cur_frm.fields_dict.contact_by.df.options.match(/^Profile/)) { + if(cur_frm.fields_dict.contact_by.df.options.match(/^User/)) { cur_frm.fields_dict.contact_by.get_query = function(doc, cdt, cdn) { - return { query:"frappe.core.doctype.profile.profile.profile_query" } } + return { query:"frappe.core.doctype.user.user.user_query" } } } if(in_list(user_roles,'System Manager')) { diff --git a/erpnext/selling/doctype/lead/lead.txt b/erpnext/selling/doctype/lead/lead.txt index caf677f524..ba04cb97fd 100644 --- a/erpnext/selling/doctype/lead/lead.txt +++ b/erpnext/selling/doctype/lead/lead.txt @@ -2,7 +2,7 @@ { "creation": "2013-04-10 11:45:37", "docstatus": 0, - "modified": "2014-01-20 17:48:53", + "modified": "2014-01-20 17:48:54", "modified_by": "Administrator", "owner": "Administrator" }, @@ -171,7 +171,7 @@ "label": "Lead Owner", "oldfieldname": "lead_owner", "oldfieldtype": "Link", - "options": "Profile", + "options": "User", "search_index": 1 }, { @@ -190,7 +190,7 @@ "label": "Next Contact By", "oldfieldname": "contact_by", "oldfieldtype": "Link", - "options": "Profile", + "options": "User", "print_hide": 0, "reqd": 0, "width": "100px" diff --git a/erpnext/selling/doctype/opportunity/opportunity.js b/erpnext/selling/doctype/opportunity/opportunity.js index 2828932316..f243758a2e 100644 --- a/erpnext/selling/doctype/opportunity/opportunity.js +++ b/erpnext/selling/doctype/opportunity/opportunity.js @@ -45,8 +45,8 @@ erpnext.selling.Opportunity = frappe.ui.form.Controller.extend({ setup_queries: function() { var me = this; - if(this.frm.fields_dict.contact_by.df.options.match(/^Profile/)) { - this.frm.set_query("contact_by", erpnext.queries.profile); + if(this.frm.fields_dict.contact_by.df.options.match(/^User/)) { + this.frm.set_query("contact_by", erpnext.queries.user); } this.frm.set_query("customer_address", function() { diff --git a/erpnext/selling/doctype/opportunity/opportunity.txt b/erpnext/selling/doctype/opportunity/opportunity.txt index 8cb0f2531b..fd59a31e92 100644 --- a/erpnext/selling/doctype/opportunity/opportunity.txt +++ b/erpnext/selling/doctype/opportunity/opportunity.txt @@ -2,7 +2,7 @@ { "creation": "2013-03-07 18:50:30", "docstatus": 0, - "modified": "2014-01-20 17:48:58", + "modified": "2014-01-20 17:48:59", "modified_by": "Administrator", "owner": "Administrator" }, @@ -400,7 +400,7 @@ "label": "Next Contact By", "oldfieldname": "contact_by", "oldfieldtype": "Link", - "options": "Profile", + "options": "User", "read_only": 0, "width": "75px" }, diff --git a/erpnext/selling/doctype/sales_bom/sales_bom.py b/erpnext/selling/doctype/sales_bom/sales_bom.py index 823b67dcdc..fb4696199c 100644 --- a/erpnext/selling/doctype/sales_bom/sales_bom.py +++ b/erpnext/selling/doctype/sales_bom/sales_bom.py @@ -39,5 +39,5 @@ def get_new_item_code(doctype, txt, searchfield, start, page_len, filters): where is_stock_item="No" and is_sales_item="Yes" and name not in (select name from `tabSales BOM`) and %s like %s %s limit %s, %s""" % (searchfield, "%s", - get_match_cond(doctype, searchfield),"%s", "%s"), + get_match_cond(doctype),"%s", "%s"), ("%%%s%%" % txt, start, page_len)) \ No newline at end of file diff --git a/erpnext/selling/doctype/sales_order/test_sales_order.py b/erpnext/selling/doctype/sales_order/test_sales_order.py index 9992b01cd4..e325aeb1ea 100644 --- a/erpnext/selling/doctype/sales_order/test_sales_order.py +++ b/erpnext/selling/doctype/sales_order/test_sales_order.py @@ -281,10 +281,10 @@ class TestSalesOrder(unittest.TestCase): def test_warehouse_user(self): frappe.defaults.add_default("Warehouse", "_Test Warehouse 1 - _TC1", "test@example.com", "Restriction") - frappe.bean("Profile", "test@example.com").get_controller()\ + frappe.bean("User", "test@example.com").get_controller()\ .add_roles("Sales User", "Sales Manager", "Material User", "Material Manager") - frappe.bean("Profile", "test2@example.com").get_controller()\ + frappe.bean("User", "test2@example.com").get_controller()\ .add_roles("Sales User", "Sales Manager", "Material User", "Material Manager") frappe.set_user("test@example.com") diff --git a/erpnext/selling/page/sales_browser/sales_browser.js b/erpnext/selling/page/sales_browser/sales_browser.js index 7beeb4218b..a7a8770de8 100644 --- a/erpnext/selling/page/sales_browser/sales_browser.js +++ b/erpnext/selling/page/sales_browser/sales_browser.js @@ -57,8 +57,8 @@ erpnext.SalesChart = Class.extend({ var me = this; me.ctype = ctype; me.can_read = frappe.model.can_read(this.ctype); - me.can_create = frappe.boot.profile.can_create.indexOf(this.ctype) !== -1 || - frappe.boot.profile.in_create.indexOf(this.ctype) !== -1; + me.can_create = frappe.boot.user.can_create.indexOf(this.ctype) !== -1 || + frappe.boot.user.in_create.indexOf(this.ctype) !== -1; me.can_write = frappe.model.can_write(this.ctype); me.can_delete = frappe.model.can_delete(this.ctype); @@ -144,9 +144,14 @@ erpnext.SalesChart = Class.extend({ return frappe.call({ method: 'erpnext.selling.page.sales_browser.sales_browser.add_node', args: v, - callback: function() { - d.hide(); - node.reload(); + callback: function(r) { + if(!r.exc) { + d.hide(); + node.reload(); + if(!node.expanded) { + node.toggle_node(); + } + } } }) }); diff --git a/erpnext/selling/report/available_stock_for_packing_items/available_stock_for_packing_items.txt b/erpnext/selling/report/available_stock_for_packing_items/available_stock_for_packing_items.txt index 5cf413393f..6655caad59 100644 --- a/erpnext/selling/report/available_stock_for_packing_items/available_stock_for_packing_items.txt +++ b/erpnext/selling/report/available_stock_for_packing_items/available_stock_for_packing_items.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-21 13:40:05", "docstatus": 0, - "modified": "2013-06-21 15:06:40", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Sales BOM", "report_name": "Available Stock for Packing Items", diff --git a/erpnext/selling/report/customer_acquisition_and_loyalty/customer_acquisition_and_loyalty.txt b/erpnext/selling/report/customer_acquisition_and_loyalty/customer_acquisition_and_loyalty.txt index c1f7e944ed..98ef3a9639 100644 --- a/erpnext/selling/report/customer_acquisition_and_loyalty/customer_acquisition_and_loyalty.txt +++ b/erpnext/selling/report/customer_acquisition_and_loyalty/customer_acquisition_and_loyalty.txt @@ -2,7 +2,7 @@ { "creation": "2013-11-28 14:58:06", "docstatus": 0, - "modified": "2013-11-28 15:02:48", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Customer", "report_name": "Customer Acquisition and Loyalty", diff --git a/erpnext/selling/report/customer_addresses_and_contacts/customer_addresses_and_contacts.txt b/erpnext/selling/report/customer_addresses_and_contacts/customer_addresses_and_contacts.txt index f51f29528e..fbe5b77052 100644 --- a/erpnext/selling/report/customer_addresses_and_contacts/customer_addresses_and_contacts.txt +++ b/erpnext/selling/report/customer_addresses_and_contacts/customer_addresses_and_contacts.txt @@ -2,13 +2,14 @@ { "creation": "2012-10-04 18:45:27", "docstatus": 0, - "modified": "2013-02-22 15:53:01", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "query": "SELECT\n\t`tabCustomer`.name as customer_id,\n\t`tabCustomer`.customer_name,\n\t`tabCustomer`.customer_group,\n\t`tabAddress`.address_line1,\n\t`tabAddress`.address_line2,\n\t`tabAddress`.city,\n\t`tabAddress`.state,\n\t`tabAddress`.pincode,\n\t`tabAddress`.country,\n\t`tabAddress`.is_primary_address, \n\t`tabContact`.first_name,\n\t`tabContact`.last_name,\n\t`tabContact`.phone,\n\t`tabContact`.mobile_no,\n\t`tabContact`.email_id,\n\t`tabContact`.is_primary_contact\nFROM\n\t`tabCustomer`\n\tleft join `tabAddress` on (\n\t\t`tabAddress`.customer=`tabCustomer`.name\n\t)\n\tleft join `tabContact` on (\n\t\t`tabContact`.customer=`tabCustomer`.name\n\t)\nWHERE\n\t`tabCustomer`.docstatus<2\nORDER BY\n\t`tabCustomer`.name asc", "ref_doctype": "Customer", diff --git a/erpnext/selling/report/customers_not_buying_since_long_time/customers_not_buying_since_long_time.txt b/erpnext/selling/report/customers_not_buying_since_long_time/customers_not_buying_since_long_time.txt index 4d94377aa9..54ea37ebcd 100644 --- a/erpnext/selling/report/customers_not_buying_since_long_time/customers_not_buying_since_long_time.txt +++ b/erpnext/selling/report/customers_not_buying_since_long_time/customers_not_buying_since_long_time.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-07 12:27:07", "docstatus": 0, - "modified": "2013-06-07 12:27:07", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Sales Order", "report_name": "Customers Not Buying Since Long Time ", diff --git a/erpnext/selling/report/item_wise_sales_history/item_wise_sales_history.txt b/erpnext/selling/report/item_wise_sales_history/item_wise_sales_history.txt index d8889da129..d03ca924c1 100644 --- a/erpnext/selling/report/item_wise_sales_history/item_wise_sales_history.txt +++ b/erpnext/selling/report/item_wise_sales_history/item_wise_sales_history.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-23 17:42:24", "docstatus": 0, - "modified": "2014-02-11 12:20:17", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -11,6 +11,7 @@ "disabled": 0, "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "query": "select\n so_item.item_code as \"Item Code:Link/Item:120\",\n\tso_item.item_name as \"Item Name::120\",\n\tso_item.description as \"Description::150\",\n\tso_item.qty as \"Qty:Float:100\",\n\tso_item.stock_uom as \"UOM:Link/UOM:80\",\n\tso_item.base_rate as \"Rate:Currency:120\",\n\tso_item.base_amount as \"Amount:Currency:120\",\n\tso.name as \"Sales Order:Link/Sales Order:120\",\n\tso.transaction_date as \"Transaction Date:Date:140\",\n\tso.customer as \"Customer:Link/Customer:130\",\n\tso.territory as \"Territory:Link/Territory:130\",\n so.project_name as \"Project:Link/Project:130\",\n\tifnull(so_item.delivered_qty, 0) as \"Delivered Qty:Float:120\",\n\tifnull(so_item.billed_amt, 0) as \"Billed Amount:Currency:120\"\nfrom\n\t`tabSales Order` so, `tabSales Order Item` so_item\nwhere\n\tso.name = so_item.parent\n\tand so.docstatus = 1\norder by so.name desc", "ref_doctype": "Sales Order", diff --git a/erpnext/selling/report/lead_details/lead_details.txt b/erpnext/selling/report/lead_details/lead_details.txt index 1383a79550..8c9f170171 100644 --- a/erpnext/selling/report/lead_details/lead_details.txt +++ b/erpnext/selling/report/lead_details/lead_details.txt @@ -2,15 +2,16 @@ { "creation": "2013-10-22 11:58:16", "docstatus": 0, - "modified": "2013-11-06 15:01:09", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", - "query": "SELECT\n `tabLead`.name as \"Lead Id:Link/Lead:120\",\n `tabLead`.lead_name as \"Lead Name::120\",\n\t`tabLead`.company_name as \"Company Name::120\",\n\t`tabLead`.status as \"Status::120\",\n\tconcat_ws(', ', \n\t\ttrim(',' from `tabAddress`.address_line1), \n\t\ttrim(',' from tabAddress.address_line2), \n\t\ttabAddress.state, tabAddress.pincode, tabAddress.country\n\t) as 'Address::180',\n\t`tabLead`.phone as \"Phone::100\",\n\t`tabLead`.mobile_no as \"Mobile No::100\",\n\t`tabLead`.email_id as \"Email Id::120\",\n\t`tabLead`.lead_owner as \"Lead Owner::120\",\n\t`tabLead`.source as \"Source::120\",\n\t`tabLead`.territory as \"Territory::120\",\n `tabLead`.owner as \"Owner:Link/Profile:120\"\nFROM\n\t`tabLead`\n\tleft join `tabAddress` on (\n\t\t`tabAddress`.lead=`tabLead`.name\n\t)\nWHERE\n\t`tabLead`.docstatus<2\nORDER BY\n\t`tabLead`.name asc", + "query": "SELECT\n `tabLead`.name as \"Lead Id:Link/Lead:120\",\n `tabLead`.lead_name as \"Lead Name::120\",\n\t`tabLead`.company_name as \"Company Name::120\",\n\t`tabLead`.status as \"Status::120\",\n\tconcat_ws(', ', \n\t\ttrim(',' from `tabAddress`.address_line1), \n\t\ttrim(',' from tabAddress.address_line2), \n\t\ttabAddress.state, tabAddress.pincode, tabAddress.country\n\t) as 'Address::180',\n\t`tabLead`.phone as \"Phone::100\",\n\t`tabLead`.mobile_no as \"Mobile No::100\",\n\t`tabLead`.email_id as \"Email Id::120\",\n\t`tabLead`.lead_owner as \"Lead Owner::120\",\n\t`tabLead`.source as \"Source::120\",\n\t`tabLead`.territory as \"Territory::120\",\n `tabLead`.owner as \"Owner:Link/User:120\"\nFROM\n\t`tabLead`\n\tleft join `tabAddress` on (\n\t\t`tabAddress`.lead=`tabLead`.name\n\t)\nWHERE\n\t`tabLead`.docstatus<2\nORDER BY\n\t`tabLead`.name asc", "ref_doctype": "Lead", "report_name": "Lead Details", "report_type": "Query Report" diff --git a/erpnext/selling/report/pending_so_items_for_purchase_request/pending_so_items_for_purchase_request.txt b/erpnext/selling/report/pending_so_items_for_purchase_request/pending_so_items_for_purchase_request.txt index e0c450a254..07b524b4f9 100644 --- a/erpnext/selling/report/pending_so_items_for_purchase_request/pending_so_items_for_purchase_request.txt +++ b/erpnext/selling/report/pending_so_items_for_purchase_request/pending_so_items_for_purchase_request.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-21 16:46:45", "docstatus": 0, - "modified": "2013-06-21 16:55:54", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "query": "select \n so_item.item_code as \"Item Code:Link/Item:120\",\n so_item.item_name as \"Item Name::120\",\n so_item.description as \"Description::120\",\n so.`name` as \"S.O. No.:Link/Sales Order:120\",\n so.`transaction_date` as \"Date:Date:120\",\n mr.name as \"Material Request:Link/Material Request:120\",\n so.customer as \"Customer:Link/Customer:120\",\n so.territory as \"Terretory:Link/Territory:120\",\n sum(so_item.qty) as \"SO Qty:Float:100 \",\n sum(mr_item.qty) as \"Requested Qty:Float:100\"\nfrom\n `tabSales Order` so, `tabSales Order Item` so_item, \n `tabMaterial Request` mr, `tabMaterial Request Item` mr_item\nwhere\n so_item.`parent` = so.`name` and mr_item.sales_order_no = so.name\n and mr_item.parent = mr.name \n and so.docstatus = 1 and so.status != \"Stopped\" \n and mr.docstatus = 1 and mr.status != \"Stopped\"\ngroup by so.name, so_item.item_code\norder by so.name desc, so_item.item_code asc", "ref_doctype": "Sales Order", diff --git a/erpnext/selling/report/quotation_trends/quotation_trends.txt b/erpnext/selling/report/quotation_trends/quotation_trends.txt index eebffcf84b..5db150f380 100644 --- a/erpnext/selling/report/quotation_trends/quotation_trends.txt +++ b/erpnext/selling/report/quotation_trends/quotation_trends.txt @@ -2,7 +2,7 @@ { "creation": "2013-06-07 16:01:16", "docstatus": 0, - "modified": "2013-06-12 16:31:23", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 0, "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Quotation", "report_name": "Quotation Trends", diff --git a/erpnext/selling/report/sales_order_trends/sales_order_trends.txt b/erpnext/selling/report/sales_order_trends/sales_order_trends.txt index 16ee9ca46b..6ac7595d0f 100644 --- a/erpnext/selling/report/sales_order_trends/sales_order_trends.txt +++ b/erpnext/selling/report/sales_order_trends/sales_order_trends.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-13 18:43:30", "docstatus": 0, - "modified": "2013-06-13 18:43:30", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Sales Order", "report_name": "Sales Order Trends", diff --git a/erpnext/selling/report/sales_person_target_variance_item_group_wise/sales_person_target_variance_item_group_wise.txt b/erpnext/selling/report/sales_person_target_variance_item_group_wise/sales_person_target_variance_item_group_wise.txt index e587c2c084..56674e1046 100644 --- a/erpnext/selling/report/sales_person_target_variance_item_group_wise/sales_person_target_variance_item_group_wise.txt +++ b/erpnext/selling/report/sales_person_target_variance_item_group_wise/sales_person_target_variance_item_group_wise.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-21 12:14:15", "docstatus": 0, - "modified": "2013-06-21 12:14:15", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Sales Order", "report_name": "Sales Person Target Variance Item Group-Wise", diff --git a/erpnext/selling/report/sales_person_wise_transaction_summary/sales_person_wise_transaction_summary.txt b/erpnext/selling/report/sales_person_wise_transaction_summary/sales_person_wise_transaction_summary.txt index abd69f3f2f..b1334c68be 100644 --- a/erpnext/selling/report/sales_person_wise_transaction_summary/sales_person_wise_transaction_summary.txt +++ b/erpnext/selling/report/sales_person_wise_transaction_summary/sales_person_wise_transaction_summary.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-03 11:31:05", "docstatus": 0, - "modified": "2013-05-03 11:31:05", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Sales Order", "report_name": "Sales Person-wise Transaction Summary", diff --git a/erpnext/selling/report/territory_target_variance_item_group_wise/territory_target_variance_item_group_wise.txt b/erpnext/selling/report/territory_target_variance_item_group_wise/territory_target_variance_item_group_wise.txt index 6e16b64d4e..5bce0073e4 100644 --- a/erpnext/selling/report/territory_target_variance_item_group_wise/territory_target_variance_item_group_wise.txt +++ b/erpnext/selling/report/territory_target_variance_item_group_wise/territory_target_variance_item_group_wise.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-21 12:15:00", "docstatus": 0, - "modified": "2013-06-21 12:15:00", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Selling", "name": "__common__", "ref_doctype": "Sales Order", "report_name": "Territory Target Variance Item Group-Wise", diff --git a/erpnext/selling/sales_common.js b/erpnext/selling/sales_common.js index 1b48a8e2bc..12aca892d6 100644 --- a/erpnext/selling/sales_common.js +++ b/erpnext/selling/sales_common.js @@ -403,13 +403,15 @@ erpnext.selling.SellingController = erpnext.TransactionController.extend({ // paid_amount and write_off_amount is only for POS Invoice // total_advance is only for non POS Invoice if(this.frm.doc.doctype == "Sales Invoice" && this.frm.doc.docstatus==0) { - frappe.model.round_floats_in(this.frm.doc, ["grand_total", "total_advance", "write_off_amount", - "paid_amount"]); - var total_amount_to_pay = this.frm.doc.grand_total - this.frm.doc.write_off_amount - this.frm.doc.total_advance; - this.frm.doc.paid_amount = this.frm.doc.is_pos? flt(total_amount_to_pay): 0.0; - - this.frm.doc.outstanding_amount = flt(total_amount_to_pay - this.frm.doc.paid_amount, - precision("outstanding_amount")); + if(this.frm.doc.paid_amount==null) { + frappe.model.round_floats_in(this.frm.doc, ["grand_total", "total_advance", "write_off_amount", + "paid_amount"]); + var total_amount_to_pay = this.frm.doc.grand_total - this.frm.doc.write_off_amount + - this.frm.doc.total_advance; + this.frm.doc.paid_amount = this.frm.doc.is_pos ? flt (total_amount_to_pay) : 0.0; + this.frm.set_value("outstanding_amount", flt(total_amount_to_pay + - this.frm.doc.paid_amount, precision("outstanding_amount"))); + } } }, diff --git a/erpnext/setup/doctype/authorization_control/authorization_control.py b/erpnext/setup/doctype/authorization_control/authorization_control.py index ceab652913..b37686a666 100644 --- a/erpnext/setup/doctype/authorization_control/authorization_control.py +++ b/erpnext/setup/doctype/authorization_control/authorization_control.py @@ -184,7 +184,7 @@ class DocType(TransactionBase): if m['approving_user']: app_specific_user.append(m['approving_user']) elif m['approving_role']: - user_lst = [z[0] for z in frappe.db.sql("select distinct t1.name from `tabProfile` t1, `tabUserRole` t2 where t2.role=%s and t2.parent=t1.name and t1.name !='Administrator' and t1.name != 'Guest' and t1.docstatus !=2",m['approving_role'])] + user_lst = [z[0] for z in frappe.db.sql("select distinct t1.name from `tabUser` t1, `tabUserRole` t2 where t2.role=%s and t2.parent=t1.name and t1.name !='Administrator' and t1.name != 'Guest' and t1.docstatus !=2",m['approving_role'])] for x in user_lst: if not x in app_user: app_user.append(x) diff --git a/erpnext/setup/doctype/authorization_rule/authorization_rule.js b/erpnext/setup/doctype/authorization_rule/authorization_rule.js index dd639ab076..563137c1e5 100644 --- a/erpnext/setup/doctype/authorization_rule/authorization_rule.js +++ b/erpnext/setup/doctype/authorization_rule/authorization_rule.js @@ -65,11 +65,11 @@ cur_frm.cscript.transaction = function(doc, cdt, cdn){ } cur_frm.fields_dict.system_user.get_query = function(doc, cdt, cdn) { - return { query:"frappe.core.doctype.profile.profile.profile_query" } + return { query:"frappe.core.doctype.user.user.user_query" } } cur_frm.fields_dict.approving_user.get_query = function(doc, cdt, cdn) { - return { query:"frappe.core.doctype.profile.profile.profile_query" } + return { query:"frappe.core.doctype.user.user.user_query" } } cur_frm.fields_dict['approving_role'].get_query = cur_frm.fields_dict['system_role'].get_query; diff --git a/erpnext/setup/doctype/authorization_rule/authorization_rule.txt b/erpnext/setup/doctype/authorization_rule/authorization_rule.txt index 24b91d58ab..bd852d0b8e 100644 --- a/erpnext/setup/doctype/authorization_rule/authorization_rule.txt +++ b/erpnext/setup/doctype/authorization_rule/authorization_rule.txt @@ -2,7 +2,7 @@ { "creation": "2013-01-10 16:34:22", "docstatus": 0, - "modified": "2014-01-20 17:48:24", + "modified": "2014-01-20 17:48:25", "modified_by": "Administrator", "owner": "Administrator" }, @@ -102,7 +102,7 @@ "label": "Applicable To (User)", "oldfieldname": "system_user", "oldfieldtype": "Link", - "options": "Profile" + "options": "User" }, { "description": "This will be used for setting rule in HR module", @@ -142,7 +142,7 @@ "label": "Approving User", "oldfieldname": "approving_user", "oldfieldtype": "Link", - "options": "Profile" + "options": "User" }, { "doctype": "DocField", diff --git a/erpnext/setup/doctype/backup_manager/backup_dropbox.py b/erpnext/setup/doctype/backup_manager/backup_dropbox.py index 212efbc4a2..91cb44204d 100644 --- a/erpnext/setup/doctype/backup_manager/backup_dropbox.py +++ b/erpnext/setup/doctype/backup_manager/backup_dropbox.py @@ -21,7 +21,7 @@ def get_dropbox_authorize_url(): sess = get_dropbox_session() request_token = sess.obtain_request_token() return_address = get_request_site_address(True) \ - + "?cmd=setup.doctype.backup_manager.backup_dropbox.dropbox_callback" + + "?cmd=erpnext.setup.doctype.backup_manager.backup_dropbox.dropbox_callback" url = sess.build_authorize_url(request_token, return_address) @@ -71,13 +71,12 @@ def dropbox_callback(oauth_token=None, not_approved=False): def backup_to_dropbox(): from dropbox import client, session - from conf import dropbox_access_key, dropbox_secret_key from frappe.utils.backups import new_backup from frappe.utils import get_files_path, get_backups_path if not frappe.db: frappe.connect() - sess = session.DropboxSession(dropbox_access_key, dropbox_secret_key, "app_folder") + sess = session.DropboxSession(frappe.conf.dropbox_access_key, frappe.conf.dropbox_secret_key, "app_folder") sess.set_token(frappe.db.get_value("Backup Manager", None, "dropbox_access_key"), frappe.db.get_value("Backup Manager", None, "dropbox_access_secret")) @@ -120,13 +119,11 @@ def get_dropbox_session(): from dropbox import session except: frappe.msgprint(_("Please install dropbox python module"), raise_exception=1) - - try: - from conf import dropbox_access_key, dropbox_secret_key - except ImportError: - frappe.msgprint(_("Please set Dropbox access keys in") + " conf.py", - raise_exception=True) - sess = session.DropboxSession(dropbox_access_key, dropbox_secret_key, "app_folder") + + if not (frappe.conf.dropbox_access_key or frappe.conf.dropbox_secret_key): + frappe.throw(_("Please set Dropbox access keys in your site config")) + + sess = session.DropboxSession(frappe.conf.dropbox_access_key, frappe.conf.dropbox_secret_key, "app_folder") return sess def upload_file_to_dropbox(filename, folder, dropbox_client): diff --git a/erpnext/setup/doctype/contact_control/contact_control.js b/erpnext/setup/doctype/contact_control/contact_control.js index 94984495f8..f28e3a0972 100755 --- a/erpnext/setup/doctype/contact_control/contact_control.js +++ b/erpnext/setup/doctype/contact_control/contact_control.js @@ -162,7 +162,7 @@ cur_frm.cscript.delete_doc = function(doctype, name) { // Render List cur_frm.cscript.render_list = function(doc, doctype, wrapper, ListView, make_new_doc) { frappe.model.with_doctype(doctype, function(r) { - if((r && r['403']) || frappe.boot.profile.all_read.indexOf(doctype)===-1) { + if((r && r['403']) || frappe.boot.user.all_read.indexOf(doctype)===-1) { return; } var RecordListView = frappe.views.RecordListView.extend({ diff --git a/erpnext/setup/doctype/email_digest/email_digest.css b/erpnext/setup/doctype/email_digest/email_digest.css index 0654dec254..c07dd48cdb 100644 --- a/erpnext/setup/doctype/email_digest/email_digest.css +++ b/erpnext/setup/doctype/email_digest/email_digest.css @@ -1,4 +1,4 @@ -table.profile-list { +table.user-list { text-align: left; margin: auto; line-height: 250%; diff --git a/erpnext/setup/doctype/email_digest/email_digest.js b/erpnext/setup/doctype/email_digest/email_digest.js index 31ba66a054..875061b1b2 100644 --- a/erpnext/setup/doctype/email_digest/email_digest.js +++ b/erpnext/setup/doctype/email_digest/email_digest.js @@ -48,8 +48,8 @@ cur_frm.cscript.refresh = function(doc, dt, dn) { } cur_frm.cscript.addremove_recipients = function(doc, dt, dn) { - // Get profile list - return $c_obj(make_doclist(dt, dn), 'get_profiles', '', function(r, rt) { + // Get user list + return $c_obj(make_doclist(dt, dn), 'get_users', '', function(r, rt) { if(r.exc) { msgprint(r.exc); } else { @@ -60,10 +60,10 @@ cur_frm.cscript.addremove_recipients = function(doc, dt, dn) { width: 400 }); var dialog_div = $a(d.body, 'div', 'dialog-div', '', ''); - var tab = make_table(dialog_div, r.profile_list.length+2, 2, '', ['15%', '85%']); - tab.className = 'profile-list'; + var tab = make_table(dialog_div, r.user_list.length+2, 2, '', ['15%', '85%']); + tab.className = 'user-list'; var add_or_update = 'Add'; - $.each(r.profile_list, function(i, v) { + $.each(r.user_list, function(i, v) { var check = $a_input($td(tab, i+1, 0), 'checkbox'); check.value = v.name; if(v.checked==1) { @@ -75,18 +75,18 @@ cur_frm.cscript.addremove_recipients = function(doc, dt, dn) { if(v.enabled==0) { v.name = repl(" %(name)s (disabled user)", {name: v.name}); } - var profile = $a($td(tab, i+1, 1), 'span', '', '', v.name); - //profile.onclick = function() { check.checked = !check.checked; } + var user = $a($td(tab, i+1, 1), 'span', '', '', v.name); + //user.onclick = function() { check.checked = !check.checked; } }); // Display add recipients button - if(r.profile_list.length>15) { + if(r.user_list.length>15) { $btn($td(tab, 0, 1), add_or_update + ' Recipients', function() { - cur_frm.cscript.add_to_rec_list(doc, tab, r.profile_list.length); + cur_frm.cscript.add_to_rec_list(doc, tab, r.user_list.length); }); } - $btn($td(tab, r.profile_list.length+1, 1), add_or_update + ' Recipients', function() { - cur_frm.cscript.add_to_rec_list(doc, tab, r.profile_list.length); + $btn($td(tab, r.user_list.length+1, 1), add_or_update + ' Recipients', function() { + cur_frm.cscript.add_to_rec_list(doc, tab, r.user_list.length); }); cur_frm.rec_dialog = d; @@ -96,7 +96,7 @@ cur_frm.cscript.addremove_recipients = function(doc, dt, dn) { } cur_frm.cscript.add_to_rec_list = function(doc, tab, length) { - // add checked profiles to list of recipients + // add checked users to list of recipients var rec_list = []; for(var i = 1; i <= length; i++) { var input = $($td(tab, i, 0)).find('input'); diff --git a/erpnext/setup/doctype/email_digest/email_digest.py b/erpnext/setup/doctype/email_digest/email_digest.py index 0cdbcb98b9..b94b77754e 100644 --- a/erpnext/setup/doctype/email_digest/email_digest.py +++ b/erpnext/setup/doctype/email_digest/email_digest.py @@ -52,10 +52,10 @@ class DocType(DocListController): self.currency = frappe.db.get_value("Company", self.doc.company, "default_currency") - def get_profiles(self): - """get list of profiles""" - profile_list = frappe.db.sql(""" - select name, enabled from tabProfile + def get_users(self): + """get list of users""" + user_list = frappe.db.sql(""" + select name, enabled from tabUser where docstatus=0 and name not in ('Administrator', 'Guest') and user_type = "System User" order by enabled desc, name asc""", as_dict=1) @@ -64,14 +64,14 @@ class DocType(DocListController): recipient_list = self.doc.recipient_list.split("\n") else: recipient_list = [] - for p in profile_list: + for p in user_list: p["checked"] = p["name"] in recipient_list and 1 or 0 - frappe.response['profile_list'] = profile_list + frappe.response['user_list'] = user_list def send(self): # send email only to enabled users - valid_users = [p[0] for p in frappe.db.sql("""select name from `tabProfile` + valid_users = [p[0] for p in frappe.db.sql("""select name from `tabUser` where enabled=1""")] recipients = filter(lambda r: r in valid_users, self.doc.recipient_list.split("\n")) @@ -314,8 +314,10 @@ class DocType(DocListController): return 0, "

    Calendar Events

    " def get_todo_list(self, user_id): - from frappe.core.page.todo.todo import get - todo_list = get() + todo_list = frappe.db.sql("""select * + from `tabToDo` where (owner=%s or assigned_by=%s) + order by field(priority, 'High', 'Medium', 'Low') asc, date asc""", + (user_id, user_id), as_dict=True) html = "" if todo_list: diff --git a/erpnext/setup/doctype/sales_person/sales_person.py b/erpnext/setup/doctype/sales_person/sales_person.py index 7bf2fd6aba..3ef838cf21 100644 --- a/erpnext/setup/doctype/sales_person/sales_person.py +++ b/erpnext/setup/doctype/sales_person/sales_person.py @@ -23,9 +23,9 @@ class DocType(DocTypeNestedSet): self.validate_one_root() def get_email_id(self): - profile = frappe.db.get_value("Employee", self.doc.employee, "user_id") - if not profile: - frappe.throw("User ID (Profile) not set for Employee %s" % self.doc.employee) + user = frappe.db.get_value("Employee", self.doc.employee, "user_id") + if not user: + frappe.throw("User ID not set for Employee %s" % self.doc.employee) else: - return frappe.db.get_value("Profile", profile, "email") or profile + return frappe.db.get_value("User", user, "email") or user \ No newline at end of file diff --git a/erpnext/setup/install.py b/erpnext/setup/install.py index 35e3534bfa..9633f61f01 100644 --- a/erpnext/setup/install.py +++ b/erpnext/setup/install.py @@ -102,6 +102,7 @@ def import_defaults(): {'uom_name': 'Set', 'doctype': 'UOM', 'name': 'Set', "must_be_whole_number": 1}, {'uom_name': 'Hour', 'doctype': 'UOM', 'name': 'Hour'}, {'uom_name': 'Minute', 'doctype': 'UOM', 'name': 'Minute'}, + ] from frappe.modules import scrub diff --git a/erpnext/setup/page/setup_wizard/setup_wizard.js b/erpnext/setup/page/setup_wizard/setup_wizard.js index 6e28bbbe4c..33603a7f38 100644 --- a/erpnext/setup/page/setup_wizard/setup_wizard.js +++ b/erpnext/setup/page/setup_wizard/setup_wizard.js @@ -30,7 +30,7 @@ frappe.pages['setup-wizard'].onload = function(wrapper) { frappe.app.logout(); }, 2000); } else { - window.location = "app.html"; + window.location = "/desk"; } }, 2000); } @@ -67,16 +67,16 @@ frappe.pages['setup-wizard'].onload = function(wrapper) { reqd:1, "description":"Your Login Id", "options":"Email"}, {"fieldname": "password", "label": frappe._("Password"), "fieldtype": "Password", reqd:1}, - {fieldtype:"Attach Image", fieldname:"attach_profile", - label:"Attach Your Profile..."}, + {fieldtype:"Attach Image", fieldname:"attach_user", + label:"Attach Your User..."}, ], help: frappe._('The first user will become the System Manager (you can change that later).'), onload: function(slide) { if(user!=="Administrator") { slide.form.fields_dict.password.$wrapper.toggle(false); slide.form.fields_dict.email.$wrapper.toggle(false); - slide.form.fields_dict.first_name.set_input(frappe.boot.profile.first_name); - slide.form.fields_dict.last_name.set_input(frappe.boot.profile.last_name); + slide.form.fields_dict.first_name.set_input(frappe.boot.user.first_name); + slide.form.fields_dict.last_name.set_input(frappe.boot.user.last_name); delete slide.form.fields_dict.email; delete slide.form.fields_dict.password; diff --git a/erpnext/setup/page/setup_wizard/setup_wizard.py b/erpnext/setup/page/setup_wizard/setup_wizard.py index 3900eba043..b79e5ca093 100644 --- a/erpnext/setup/page/setup_wizard/setup_wizard.py +++ b/erpnext/setup/page/setup_wizard/setup_wizard.py @@ -19,7 +19,7 @@ def setup_account(args=None): args = json.loads(args) args = frappe._dict(args) - update_profile_name(args) + update_user_name(args) create_fiscal_year_and_company(args) set_defaults(args) create_territories() @@ -41,12 +41,12 @@ def setup_account(args=None): return "okay" -def update_profile_name(args): +def update_user_name(args): if args.get("email"): args['name'] = args.get("email") frappe.flags.mute_emails = True frappe.bean({ - "doctype":"Profile", + "doctype":"User", "email": args.get("email"), "first_name": args.get("first_name"), "last_name": args.get("last_name") @@ -58,16 +58,16 @@ def update_profile_name(args): else: args['name'] = frappe.session.user - # Update Profile + # Update User if not args.get('last_name') or args.get('last_name')=='None': args['last_name'] = None - frappe.db.sql("""update `tabProfile` SET first_name=%(first_name)s, + frappe.db.sql("""update `tabUser` SET first_name=%(first_name)s, last_name=%(last_name)s WHERE name=%(name)s""", args) - if args.get("attach_profile"): - filename, filetype, content = args.get("attach_profile").split(",") - fileurl = save_file(filename, content, "Profile", args.get("name"), decode=True).file_name - frappe.db.set_value("Profile", args.get("name"), "user_image", fileurl) + if args.get("attach_user"): + filename, filetype, content = args.get("attach_user").split(",") + fileurl = save_file(filename, content, "User", args.get("name"), decode=True).file_name + frappe.db.set_value("User", args.get("name"), "user_image", fileurl) add_all_roles_to(args.get("name")) @@ -176,7 +176,7 @@ def create_feed_and_todo(): 'ERNext Setup Complete!', '#6B24B3') def create_email_digest(): - from frappe.profile import get_system_managers + from frappe.utils.user import get_system_managers system_managers = get_system_managers(only_name=True) if not system_managers: return @@ -335,10 +335,10 @@ def create_letter_head(args): def add_all_roles_to(name): - profile = frappe.doc("Profile", name) + user = frappe.doc("User", name) for role in frappe.db.sql("""select name from tabRole"""): if role[0] not in ["Administrator", "Guest", "All", "Customer", "Supplier", "Partner"]: - d = profile.addchild("user_roles", "UserRole") + d = user.addchild("user_roles", "UserRole") d.role = role[0] d.insert() diff --git a/erpnext/setup/page/setup_wizard/test_setup_data.py b/erpnext/setup/page/setup_wizard/test_setup_data.py index b5b6359893..f521c53f2c 100644 --- a/erpnext/setup/page/setup_wizard/test_setup_data.py +++ b/erpnext/setup/page/setup_wizard/test_setup_data.py @@ -2,7 +2,7 @@ args = { "attach_letterhead": "erpnext.jpg,", "attach_logo": "logo-2013-color-small.png,", -"attach_profile": "rushabh.jpeg,", +"attach_user": "rushabh.jpeg,", "company_abbr": "WN", "company_name": "Web Notes", "company_tagline": "Open Source ERP", diff --git a/erpnext/startup/__init__.py b/erpnext/startup/__init__.py index 1c49c8f581..e20ece3d10 100644 --- a/erpnext/startup/__init__.py +++ b/erpnext/startup/__init__.py @@ -16,13 +16,13 @@ # You should have received a copy of the GNU General Public License # along with this program. If not, see . -# default settings that can be made for a profile. +# default settings that can be made for a user. from __future__ import unicode_literals import frappe product_name = "ERPNext" -profile_defaults = { +user_defaults = { "Company": "company", "Territory": "territory" } diff --git a/erpnext/startup/event_handlers.py b/erpnext/startup/event_handlers.py index fe445e4861..c4fc18f67d 100644 --- a/erpnext/startup/event_handlers.py +++ b/erpnext/startup/event_handlers.py @@ -14,9 +14,9 @@ def on_session_creation(login_manager): if frappe.session['user'] not in ('Guest'): # create feed from frappe.utils import nowtime - from frappe.profile import get_user_fullname + from frappe.utils.user import get_user_fullname frappe.db.begin() - make_feed('Login', 'Profile', login_manager.user, login_manager.user, + make_feed('Login', 'User', login_manager.user, login_manager.user, '%s logged in at %s' % (get_user_fullname(login_manager.user), nowtime()), login_manager.user=='Administrator' and '#8CA2B3' or '#1B750D') frappe.db.commit() \ No newline at end of file diff --git a/erpnext/stock/doctype/item/item.txt b/erpnext/stock/doctype/item/item.txt index ff66df3e0a..51abc22807 100644 --- a/erpnext/stock/doctype/item/item.txt +++ b/erpnext/stock/doctype/item/item.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-03 10:45:46", "docstatus": 0, - "modified": "2014-02-20 18:27:02", + "modified": "2014-03-05 15:20:59", "modified_by": "Administrator", "owner": "Administrator" }, @@ -111,6 +111,7 @@ "doctype": "DocField", "fieldname": "stock_uom", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default Unit of Measure", "oldfieldname": "stock_uom", "oldfieldtype": "Link", @@ -217,6 +218,7 @@ "doctype": "DocField", "fieldname": "default_warehouse", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default Warehouse", "oldfieldname": "default_warehouse", "oldfieldtype": "Link", @@ -349,6 +351,7 @@ "doctype": "DocField", "fieldname": "weight_uom", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Weight UOM", "options": "UOM", "read_only": 0 @@ -420,6 +423,7 @@ "doctype": "DocField", "fieldname": "default_supplier", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default Supplier", "options": "Supplier" }, @@ -441,6 +445,7 @@ "doctype": "DocField", "fieldname": "expense_account", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default Expense Account", "oldfieldname": "purchase_account", "oldfieldtype": "Link", @@ -453,6 +458,7 @@ "doctype": "DocField", "fieldname": "buying_cost_center", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default Buying Cost Center", "oldfieldname": "cost_center", "oldfieldtype": "Link", @@ -579,6 +585,7 @@ "doctype": "DocField", "fieldname": "income_account", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default Income Account", "options": "Account", "read_only": 0 @@ -588,6 +595,7 @@ "doctype": "DocField", "fieldname": "selling_cost_center", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default Selling Cost Center", "options": "Cost Center", "read_only": 0 @@ -691,6 +699,7 @@ "doctype": "DocField", "fieldname": "default_bom", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Default BOM", "no_copy": 1, "oldfieldname": "default_bom", @@ -802,6 +811,7 @@ "doctype": "DocField", "fieldname": "website_warehouse", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Website Warehouse", "options": "Warehouse", "read_only": 0 @@ -852,6 +862,7 @@ "doctype": "DocField", "fieldname": "parent_website_route", "fieldtype": "Link", + "ignore_restrictions": 1, "label": "Parent Website Route", "options": "Website Route" }, diff --git a/erpnext/stock/doctype/packing_slip/packing_slip.py b/erpnext/stock/doctype/packing_slip/packing_slip.py index 03d6e41ae7..b7b6473203 100644 --- a/erpnext/stock/doctype/packing_slip/packing_slip.py +++ b/erpnext/stock/doctype/packing_slip/packing_slip.py @@ -171,5 +171,5 @@ def item_details(doctype, txt, searchfield, start, page_len, filters): and ifnull(qty, 0) > ifnull(packed_qty, 0)) and %s like "%s" %s limit %s, %s """ % ("%s", searchfield, "%s", - get_match_cond(doctype, searchfield), "%s", "%s"), + get_match_cond(doctype), "%s", "%s"), (filters["delivery_note"], "%%%s%%" % txt, start, page_len)) \ No newline at end of file diff --git a/erpnext/stock/doctype/stock_entry/stock_entry.js b/erpnext/stock/doctype/stock_entry/stock_entry.js index b78c10497d..535fcb735b 100644 --- a/erpnext/stock/doctype/stock_entry/stock_entry.js +++ b/erpnext/stock/doctype/stock_entry/stock_entry.js @@ -68,7 +68,7 @@ erpnext.stock.StockEntry = erpnext.stock.StockController.extend({ this.show_general_ledger(); if(this.frm.doc.docstatus === 1 && - frappe.boot.profile.can_create.indexOf("Journal Voucher")!==-1) { + frappe.boot.user.can_create.indexOf("Journal Voucher")!==-1) { if(this.frm.doc.purpose === "Sales Return") { this.frm.add_custom_button(frappe._("Make Credit Note"), function() { me.make_return_jv(); }); this.add_excise_button(); @@ -339,18 +339,21 @@ cur_frm.fields_dict['mtn_details'].grid.get_field('batch_no').get_query = functi cur_frm.cscript.item_code = function(doc, cdt, cdn) { var d = locals[cdt][cdn]; - args = { - 'item_code' : d.item_code, - 'warehouse' : cstr(d.s_warehouse) || cstr(d.t_warehouse), - 'transfer_qty' : d.transfer_qty, - 'serial_no' : d.serial_no, - 'bom_no' : d.bom_no, - 'expense_account' : d.expense_account, - 'cost_center' : d.cost_center, - 'company' : cur_frm.doc.company - }; - return get_server_fields('get_item_details', JSON.stringify(args), - 'mtn_details', doc, cdt, cdn, 1); + if(d.item_code) { + args = { + 'item_code' : d.item_code, + 'warehouse' : cstr(d.s_warehouse) || cstr(d.t_warehouse), + 'transfer_qty' : d.transfer_qty, + 'serial_no' : d.serial_no, + 'bom_no' : d.bom_no, + 'expense_account' : d.expense_account, + 'cost_center' : d.cost_center, + 'company' : cur_frm.doc.company + }; + return get_server_fields('get_item_details', JSON.stringify(args), + 'mtn_details', doc, cdt, cdn, 1); + } + } cur_frm.cscript.s_warehouse = function(doc, cdt, cdn) { diff --git a/erpnext/stock/doctype/stock_entry/stock_entry.py b/erpnext/stock/doctype/stock_entry/stock_entry.py index 719f7b1aa7..3aeb507873 100644 --- a/erpnext/stock/doctype/stock_entry/stock_entry.py +++ b/erpnext/stock/doctype/stock_entry/stock_entry.py @@ -631,7 +631,7 @@ def query_sales_return_doc(doctype, txt, searchfield, start, page_len, filters): or `customer` like %%(txt)s) %s %s order by name, customer, customer_name limit %s""" % (doctype, searchfield, conditions, - get_match_cond(doctype, searchfield), "%(start)s, %(page_len)s"), + get_match_cond(doctype), "%(start)s, %(page_len)s"), {"txt": "%%%s%%" % txt, "start": start, "page_len": page_len}, as_list=True) @@ -641,7 +641,7 @@ def query_purchase_return_doc(doctype, txt, searchfield, start, page_len, filter and (`%s` like %%(txt)s or `supplier` like %%(txt)s) %s order by name, supplier, supplier_name - limit %s""" % (doctype, searchfield, get_match_cond(doctype, searchfield), + limit %s""" % (doctype, searchfield, get_match_cond(doctype), "%(start)s, %(page_len)s"), {"txt": "%%%s%%" % txt, "start": start, "page_len": page_len}, as_list=True) @@ -679,7 +679,7 @@ def get_batch_no(doctype, txt, searchfield, start, page_len, filters): 's_warehouse': filters['s_warehouse'], 'posting_date': filters['posting_date'], 'txt': "%%%s%%" % txt, - 'mcond':get_match_cond(doctype, searchfield), + 'mcond':get_match_cond(doctype), "start": start, "page_len": page_len } diff --git a/erpnext/stock/doctype/stock_entry/test_stock_entry.py b/erpnext/stock/doctype/stock_entry/test_stock_entry.py index f127aa134f..d14e896fb0 100644 --- a/erpnext/stock/doctype/stock_entry/test_stock_entry.py +++ b/erpnext/stock/doctype/stock_entry/test_stock_entry.py @@ -765,7 +765,7 @@ class TestStockEntry(unittest.TestCase): def test_warehouse_company_validation(self): set_perpetual_inventory(0) self._clear_stock_account_balance() - frappe.bean("Profile", "test2@example.com").get_controller()\ + frappe.bean("User", "test2@example.com").get_controller()\ .add_roles("Sales User", "Sales Manager", "Material User", "Material Manager") frappe.set_user("test2@example.com") @@ -783,9 +783,9 @@ class TestStockEntry(unittest.TestCase): frappe.defaults.add_default("Warehouse", "_Test Warehouse 1 - _TC1", "test@example.com", "Restriction") frappe.defaults.add_default("Warehouse", "_Test Warehouse 2 - _TC1", "test2@example.com", "Restriction") - frappe.bean("Profile", "test@example.com").get_controller()\ + frappe.bean("User", "test@example.com").get_controller()\ .add_roles("Sales User", "Sales Manager", "Material User", "Material Manager") - frappe.bean("Profile", "test2@example.com").get_controller()\ + frappe.bean("User", "test2@example.com").get_controller()\ .add_roles("Sales User", "Sales Manager", "Material User", "Material Manager") frappe.set_user("test@example.com") diff --git a/erpnext/stock/doctype/warehouse_user/warehouse_user.txt b/erpnext/stock/doctype/warehouse_user/warehouse_user.txt index c28a37f5f0..ae22eecd77 100644 --- a/erpnext/stock/doctype/warehouse_user/warehouse_user.txt +++ b/erpnext/stock/doctype/warehouse_user/warehouse_user.txt @@ -20,7 +20,7 @@ "in_list_view": 1, "label": "User", "name": "__common__", - "options": "Profile", + "options": "User", "parent": "Warehouse User", "parentfield": "fields", "parenttype": "DocType", diff --git a/erpnext/stock/report/batch_wise_balance_history/batch_wise_balance_history.txt b/erpnext/stock/report/batch_wise_balance_history/batch_wise_balance_history.txt index 9e795b9f31..6a70042ffd 100644 --- a/erpnext/stock/report/batch_wise_balance_history/batch_wise_balance_history.txt +++ b/erpnext/stock/report/batch_wise_balance_history/batch_wise_balance_history.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-04 11:03:47", "docstatus": 0, - "modified": "2013-06-04 19:32:27", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Stock Ledger Entry", "report_name": "Batch-Wise Balance History", diff --git a/erpnext/stock/report/delivery_note_trends/delivery_note_trends.txt b/erpnext/stock/report/delivery_note_trends/delivery_note_trends.txt index bb8720074a..2d7c9536da 100644 --- a/erpnext/stock/report/delivery_note_trends/delivery_note_trends.txt +++ b/erpnext/stock/report/delivery_note_trends/delivery_note_trends.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-13 18:42:11", "docstatus": 0, - "modified": "2013-06-13 18:42:11", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Delivery Note", "report_name": "Delivery Note Trends", diff --git a/erpnext/stock/report/item_prices/item_prices.txt b/erpnext/stock/report/item_prices/item_prices.txt index 4c49ca1748..e5e96347c6 100644 --- a/erpnext/stock/report/item_prices/item_prices.txt +++ b/erpnext/stock/report/item_prices/item_prices.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-05 11:43:30", "docstatus": 0, - "modified": "2013-06-05 11:43:30", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Stock Ledger Entry", "report_name": "Item Prices", diff --git a/erpnext/stock/report/item_shortage_report/item_shortage_report.txt b/erpnext/stock/report/item_shortage_report/item_shortage_report.txt index 7d54ace93f..615c373986 100644 --- a/erpnext/stock/report/item_shortage_report/item_shortage_report.txt +++ b/erpnext/stock/report/item_shortage_report/item_shortage_report.txt @@ -2,7 +2,7 @@ { "creation": "2013-08-20 13:43:30", "docstatus": 0, - "modified": "2013-08-20 13:46:15", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "doctype": "Report", "is_standard": "Yes", "json": "{\"filters\":[[\"Bin\",\"projected_qty\",\"<\",\"0\"]],\"columns\":[[\"warehouse\",\"Bin\"],[\"item_code\",\"Bin\"],[\"actual_qty\",\"Bin\"],[\"ordered_qty\",\"Bin\"],[\"planned_qty\",\"Bin\"],[\"reserved_qty\",\"Bin\"],[\"projected_qty\",\"Bin\"]],\"sort_by\":\"Bin.projected_qty\",\"sort_order\":\"asc\",\"sort_by_next\":\"\",\"sort_order_next\":\"desc\"}", + "module": "Stock", "name": "__common__", "ref_doctype": "Bin", "report_name": "Item Shortage Report", diff --git a/erpnext/stock/report/item_wise_price_list_rate/item_wise_price_list_rate.txt b/erpnext/stock/report/item_wise_price_list_rate/item_wise_price_list_rate.txt index f4d1d67ca4..14b0872943 100644 --- a/erpnext/stock/report/item_wise_price_list_rate/item_wise_price_list_rate.txt +++ b/erpnext/stock/report/item_wise_price_list_rate/item_wise_price_list_rate.txt @@ -2,7 +2,7 @@ { "creation": "2013-09-25 10:21:15", "docstatus": 0, - "modified": "2014-01-07 18:35:22", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "doctype": "Report", "is_standard": "Yes", "json": "{\"filters\":[[\"Item Price\",\"price_list\",\"like\",\"%\"],[\"Item Price\",\"item_code\",\"like\",\"%\"]],\"columns\":[[\"name\",\"Item Price\"],[\"price_list\",\"Item Price\"],[\"item_code\",\"Item Price\"],[\"item_name\",\"Item Price\"],[\"item_description\",\"Item Price\"],[\"ref_rate\",\"Item Price\"],[\"buying\",\"Item Price\"],[\"selling\",\"Item Price\"],[\"currency\",\"Item Price\"]],\"sort_by\":\"Item Price.modified\",\"sort_order\":\"desc\",\"sort_by_next\":\"\",\"sort_order_next\":\"desc\"}", + "module": "Stock", "name": "__common__", "ref_doctype": "Price List", "report_name": "Item-wise Price List Rate", diff --git a/erpnext/stock/report/items_to_be_requested/items_to_be_requested.txt b/erpnext/stock/report/items_to_be_requested/items_to_be_requested.txt index 91e8ca3f26..97f45ce0ff 100644 --- a/erpnext/stock/report/items_to_be_requested/items_to_be_requested.txt +++ b/erpnext/stock/report/items_to_be_requested/items_to_be_requested.txt @@ -2,13 +2,14 @@ { "creation": "2013-08-20 15:08:10", "docstatus": 0, - "modified": "2013-08-20 15:10:45", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "query": "SELECT\n tabBin.item_code as \"Item:Link/Item:120\",\n tabBin.warehouse as \"Warehouse:Link/Warehouse:120\",\n tabBin.actual_qty as \"Actual:Float:90\",\n tabBin.indented_qty as \"Requested:Float:90\",\n tabBin.reserved_qty as \"Reserved:Float:90\",\n tabBin.ordered_qty as \"Ordered:Float:90\",\n tabBin.projected_qty as \"Projected:Float:90\"\nFROM\n tabBin, tabItem\nWHERE\n tabBin.item_code = tabItem.name\n AND tabItem.is_purchase_item = \"Yes\"\n AND tabBin.projected_qty < 0\nORDER BY\n tabBin.projected_qty ASC", "ref_doctype": "Item", diff --git a/erpnext/stock/report/itemwise_recommended_reorder_level/itemwise_recommended_reorder_level.txt b/erpnext/stock/report/itemwise_recommended_reorder_level/itemwise_recommended_reorder_level.txt index 2763f21dfe..5f6cad974d 100644 --- a/erpnext/stock/report/itemwise_recommended_reorder_level/itemwise_recommended_reorder_level.txt +++ b/erpnext/stock/report/itemwise_recommended_reorder_level/itemwise_recommended_reorder_level.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-07 12:47:22", "docstatus": 0, - "modified": "2013-06-07 13:03:54", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Item", "report_name": "Itemwise Recommended Reorder Level", diff --git a/erpnext/stock/report/material_requests_for_which_supplier_quotations_are_not_created/material_requests_for_which_supplier_quotations_are_not_created.txt b/erpnext/stock/report/material_requests_for_which_supplier_quotations_are_not_created/material_requests_for_which_supplier_quotations_are_not_created.txt index 5c842a84dd..05f7afbf61 100644 --- a/erpnext/stock/report/material_requests_for_which_supplier_quotations_are_not_created/material_requests_for_which_supplier_quotations_are_not_created.txt +++ b/erpnext/stock/report/material_requests_for_which_supplier_quotations_are_not_created/material_requests_for_which_supplier_quotations_are_not_created.txt @@ -2,13 +2,14 @@ { "creation": "2013-08-09 12:20:58", "docstatus": 0, - "modified": "2013-08-09 12:25:29", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "query": "select \n mr.name as \"Material Request:Link/Material Request:120\",\n mr.transaction_date as \"Date:Date:100\",\n\tmr_item.item_code as \"Item Code:Link/Item:120\",\n\tmr_item.qty as \"Qty:Float:100\",\n\tmr_item.item_name as \"Item Name::150\",\n\tmr_item.description as \"Description::200\"\nfrom\n\t`tabMaterial Request` mr, `tabMaterial Request Item` mr_item\nwhere\n\tmr_item.parent = mr.name\n\tand mr.material_request_type = \"Purchase\"\n\tand mr.docstatus = 1\n\tand mr.status != \"Stopped\"\n\tand not exists(select name from `tabSupplier Quotation Item` where prevdoc_docname=mr.name)\norder by mr.transaction_date asc", "ref_doctype": "Material Request", diff --git a/erpnext/stock/report/ordered_items_to_be_delivered/ordered_items_to_be_delivered.txt b/erpnext/stock/report/ordered_items_to_be_delivered/ordered_items_to_be_delivered.txt index 0eb46bc82b..a0a34b99a5 100644 --- a/erpnext/stock/report/ordered_items_to_be_delivered/ordered_items_to_be_delivered.txt +++ b/erpnext/stock/report/ordered_items_to_be_delivered/ordered_items_to_be_delivered.txt @@ -2,13 +2,14 @@ { "creation": "2013-02-22 18:01:55", "docstatus": 0, - "modified": "2014-02-11 11:17:54", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "query": "select \n `tabSales Order`.`name` as \"Sales Order:Link/Sales Order:120\",\n `tabSales Order`.`customer` as \"Customer:Link/Customer:120\",\n `tabSales Order`.`transaction_date` as \"Date:Date\",\n `tabSales Order`.`project_name` as \"Project\",\n `tabSales Order Item`.item_code as \"Item:Link/Item:120\",\n `tabSales Order Item`.qty as \"Qty:Float:140\",\n `tabSales Order Item`.delivered_qty as \"Delivered Qty:Float:140\",\n (`tabSales Order Item`.qty - ifnull(`tabSales Order Item`.delivered_qty, 0)) as \"Qty to Deliver:Float:140\",\n `tabSales Order Item`.base_amount as \"Amount:Float:140\",\n `tabSales Order`.`delivery_date` as \"Expected Delivery Date:Date:120\",\n `tabSales Order Item`.item_name as \"Item Name::150\",\n `tabSales Order Item`.description as \"Description::200\",\n `tabSales Order Item`.item_group as \"Item Group:Link/Item Group:120\"\nfrom\n `tabSales Order`, `tabSales Order Item`\nwhere\n `tabSales Order Item`.`parent` = `tabSales Order`.`name`\n and `tabSales Order`.docstatus = 1\n and `tabSales Order`.status != \"Stopped\"\n and ifnull(`tabSales Order Item`.delivered_qty,0) < ifnull(`tabSales Order Item`.qty,0)\norder by `tabSales Order`.transaction_date asc", "ref_doctype": "Delivery Note", diff --git a/erpnext/stock/report/purchase_in_transit/purchase_in_transit.txt b/erpnext/stock/report/purchase_in_transit/purchase_in_transit.txt index ccc374b55c..d0e17e0ab3 100644 --- a/erpnext/stock/report/purchase_in_transit/purchase_in_transit.txt +++ b/erpnext/stock/report/purchase_in_transit/purchase_in_transit.txt @@ -2,13 +2,14 @@ { "creation": "2013-05-06 12:09:05", "docstatus": 0, - "modified": "2014-02-11 12:22:52", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "query": "SELECT\n pi.name as \"Purchase Invoice:Link/Purchase Invoice:120\",\n\tpi.posting_date as \"Posting Date:Date:100\",\n\tpi.credit_to as \"Supplier Account:Link/Account:120\",\n\tpi_item.item_code as \"Item Code:Link/Item:120\",\n\tpi_item.description as \"Description:Data:140\",\n\tpi_item.qty as \"Qty:Float:120\",\n\tpi_item.base_amount as \"Amount:Currency:120\",\n\tpi_item.purchase_order as \"Purchase Order:Link/Purchase Order:120\",\n\tpi_item.purchase_receipt as \"Purchase Receipt:Link/Purchase Receipt:120\",\n\tpr.posting_date as \"PR Posting Date:Date:130\",\n\tpi.company as \"Company:Link/Company:120\"\nFROM\n\t`tabPurchase Invoice` pi, `tabPurchase Invoice Item` pi_item, `tabPurchase Receipt` pr\nWHERE\n\tpi.name = pi_item.parent and pi_item.purchase_receipt = pr.name\n\tand pi.docstatus = 1 and pr.posting_date > pi.posting_date\nORDER BY\n\tpi.name desc", "ref_doctype": "Purchase Receipt", diff --git a/erpnext/stock/report/purchase_order_items_to_be_received/purchase_order_items_to_be_received.txt b/erpnext/stock/report/purchase_order_items_to_be_received/purchase_order_items_to_be_received.txt index 98dcd22e8c..41aa05e6a2 100644 --- a/erpnext/stock/report/purchase_order_items_to_be_received/purchase_order_items_to_be_received.txt +++ b/erpnext/stock/report/purchase_order_items_to_be_received/purchase_order_items_to_be_received.txt @@ -2,7 +2,7 @@ { "creation": "2013-02-22 18:01:55", "docstatus": 0, - "modified": "2013-07-16 13:19:24", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "query": "select \n `tabPurchase Order`.`name` as \"Purchase Order:Link/Purchase Order:120\",\n\t`tabPurchase Order`.`transaction_date` as \"Date:Date:100\",\n\t`tabPurchase Order`.`supplier` as \"Supplier:Link/Supplier:120\",\n\t`tabPurchase Order Item`.`project_name` as \"Project\",\n\t`tabPurchase Order Item`.item_code as \"Item Code:Link/Item:120\",\n\t`tabPurchase Order Item`.qty as \"Qty:Float:100\",\n\t`tabPurchase Order Item`.received_qty as \"Received Qty:Float:100\", \n\t(`tabPurchase Order Item`.qty - ifnull(`tabPurchase Order Item`.received_qty, 0)) as \"Qty to Receive:Float:100\",\n `tabPurchase Order Item`.warehouse as \"Warehouse:Link/Warehouse:150\",\n\t`tabPurchase Order Item`.item_name as \"Item Name::150\",\n\t`tabPurchase Order Item`.description as \"Description::200\",\n `tabPurchase Order Item`.brand as \"Brand::100\"\nfrom\n\t`tabPurchase Order`, `tabPurchase Order Item`\nwhere\n\t`tabPurchase Order Item`.`parent` = `tabPurchase Order`.`name`\n\tand `tabPurchase Order`.docstatus = 1\n\tand `tabPurchase Order`.status != \"Stopped\"\n\tand ifnull(`tabPurchase Order Item`.received_qty, 0) < ifnull(`tabPurchase Order Item`.qty, 0)\norder by `tabPurchase Order`.transaction_date asc", "ref_doctype": "Purchase Receipt", diff --git a/erpnext/stock/report/purchase_receipt_trends/purchase_receipt_trends.txt b/erpnext/stock/report/purchase_receipt_trends/purchase_receipt_trends.txt index 179c524f96..11e0592512 100644 --- a/erpnext/stock/report/purchase_receipt_trends/purchase_receipt_trends.txt +++ b/erpnext/stock/report/purchase_receipt_trends/purchase_receipt_trends.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-13 18:45:44", "docstatus": 0, - "modified": "2013-06-13 18:45:44", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Purchase Receipt", "report_name": "Purchase Receipt Trends", diff --git a/erpnext/stock/report/requested_items_to_be_transferred/requested_items_to_be_transferred.txt b/erpnext/stock/report/requested_items_to_be_transferred/requested_items_to_be_transferred.txt index 030ed242d8..c86de91790 100644 --- a/erpnext/stock/report/requested_items_to_be_transferred/requested_items_to_be_transferred.txt +++ b/erpnext/stock/report/requested_items_to_be_transferred/requested_items_to_be_transferred.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-13 16:23:05", "docstatus": 0, - "modified": "2013-05-13 16:25:08", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "query": "select \n mr.name as \"Material Request:Link/Material Request:120\",\n\tmr.transaction_date as \"Date:Date:100\",\n\tmr_item.item_code as \"Item Code:Link/Item:120\",\n\tmr_item.qty as \"Qty:Float:100\",\n\tmr_item.ordered_qty as \"Transferred Qty:Float:100\", \n\t(mr_item.qty - ifnull(mr_item.ordered_qty, 0)) as \"Qty to Transfer:Float:100\",\n\tmr_item.item_name as \"Item Name::150\",\n\tmr_item.description as \"Description::200\"\nfrom\n\t`tabMaterial Request` mr, `tabMaterial Request Item` mr_item\nwhere\n\tmr_item.parent = mr.name\n\tand mr.material_request_type = \"Transfer\"\n\tand mr.docstatus = 1\n\tand mr.status != \"Stopped\"\n\tand ifnull(mr_item.ordered_qty, 0) < ifnull(mr_item.qty, 0)\norder by mr.transaction_date asc", "ref_doctype": "Stock Entry", diff --git a/erpnext/stock/report/serial_no_service_contract_expiry/serial_no_service_contract_expiry.txt b/erpnext/stock/report/serial_no_service_contract_expiry/serial_no_service_contract_expiry.txt index 641e489c38..b37b601726 100644 --- a/erpnext/stock/report/serial_no_service_contract_expiry/serial_no_service_contract_expiry.txt +++ b/erpnext/stock/report/serial_no_service_contract_expiry/serial_no_service_contract_expiry.txt @@ -2,7 +2,7 @@ { "creation": "2013-01-14 10:52:58", "docstatus": 0, - "modified": "2013-02-22 15:53:01", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "doctype": "Report", "is_standard": "Yes", "json": "{\"filters\":[[\"Serial No\",\"status\",\"=\",\"Delivered\"]],\"columns\":[[\"name\",\"Serial No\"],[\"item_code\",\"Serial No\"],[\"amc_expiry_date\",\"Serial No\"],[\"maintenance_status\",\"Serial No\"],[\"delivery_document_no\",\"Serial No\"],[\"customer\",\"Serial No\"],[\"customer_name\",\"Serial No\"],[\"item_name\",\"Serial No\"],[\"description\",\"Serial No\"],[\"item_group\",\"Serial No\"],[\"brand\",\"Serial No\"]],\"sort_by\":\"Serial No.amc_expiry_date\",\"sort_order\":\"asc\",\"sort_by_next\":\"\",\"sort_order_next\":\"desc\"}", + "module": "Stock", "name": "__common__", "ref_doctype": "Serial No", "report_name": "Serial No Service Contract Expiry", diff --git a/erpnext/stock/report/serial_no_status/serial_no_status.txt b/erpnext/stock/report/serial_no_status/serial_no_status.txt index 23b1624394..68e4c2e315 100644 --- a/erpnext/stock/report/serial_no_status/serial_no_status.txt +++ b/erpnext/stock/report/serial_no_status/serial_no_status.txt @@ -2,7 +2,7 @@ { "creation": "2013-01-14 10:52:58", "docstatus": 0, - "modified": "2013-02-22 15:53:01", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "doctype": "Report", "is_standard": "Yes", "json": "{\"filters\":[],\"columns\":[[\"name\",\"Serial No\"],[\"item_code\",\"Serial No\"],[\"warehouse\",\"Serial No\"],[\"status\",\"Serial No\"],[\"item_name\",\"Serial No\"],[\"description\",\"Serial No\"],[\"item_group\",\"Serial No\"],[\"brand\",\"Serial No\"],[\"purchase_document_no\",\"Serial No\"],[\"purchase_date\",\"Serial No\"],[\"customer\",\"Serial No\"],[\"customer_name\",\"Serial No\"],[\"purchase_rate\",\"Serial No\"],[\"delivery_document_no\",\"Serial No\"],[\"delivery_date\",\"Serial No\"],[\"supplier\",\"Serial No\"],[\"supplier_name\",\"Serial No\"]],\"sort_by\":\"Serial No.name\",\"sort_order\":\"desc\",\"sort_by_next\":\"\",\"sort_order_next\":\"desc\"}", + "module": "Stock", "name": "__common__", "ref_doctype": "Serial No", "report_name": "Serial No Status", diff --git a/erpnext/stock/report/serial_no_warranty_expiry/serial_no_warranty_expiry.txt b/erpnext/stock/report/serial_no_warranty_expiry/serial_no_warranty_expiry.txt index e4c2380cba..6471a58a1b 100644 --- a/erpnext/stock/report/serial_no_warranty_expiry/serial_no_warranty_expiry.txt +++ b/erpnext/stock/report/serial_no_warranty_expiry/serial_no_warranty_expiry.txt @@ -2,7 +2,7 @@ { "creation": "2013-01-14 10:52:58", "docstatus": 0, - "modified": "2013-02-22 15:53:01", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "doctype": "Report", "is_standard": "Yes", "json": "{\"filters\":[[\"Serial No\",\"status\",\"=\",\"Delivered\"]],\"columns\":[[\"name\",\"Serial No\"],[\"item_code\",\"Serial No\"],[\"warranty_expiry_date\",\"Serial No\"],[\"warranty_period\",\"Serial No\"],[\"maintenance_status\",\"Serial No\"],[\"purchase_document_no\",\"Serial No\"],[\"purchase_date\",\"Serial No\"],[\"supplier\",\"Serial No\"],[\"supplier_name\",\"Serial No\"],[\"delivery_document_no\",\"Serial No\"],[\"delivery_date\",\"Serial No\"],[\"customer\",\"Serial No\"],[\"customer_name\",\"Serial No\"],[\"item_name\",\"Serial No\"],[\"description\",\"Serial No\"],[\"item_group\",\"Serial No\"],[\"brand\",\"Serial No\"]],\"sort_by\":\"Serial No.warranty_expiry_date\",\"sort_order\":\"asc\",\"sort_by_next\":\"\",\"sort_order_next\":\"asc\"}", + "module": "Stock", "name": "__common__", "ref_doctype": "Serial No", "report_name": "Serial No Warranty Expiry", diff --git a/erpnext/stock/report/stock_ageing/stock_ageing.txt b/erpnext/stock/report/stock_ageing/stock_ageing.txt index b88ebce5ed..18a7ec8cb3 100644 --- a/erpnext/stock/report/stock_ageing/stock_ageing.txt +++ b/erpnext/stock/report/stock_ageing/stock_ageing.txt @@ -2,13 +2,14 @@ { "creation": "2013-12-02 17:09:31", "docstatus": 0, - "modified": "2013-12-02 17:09:31", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Item", "report_name": "Stock Ageing", diff --git a/erpnext/stock/report/stock_ledger/stock_ledger.txt b/erpnext/stock/report/stock_ledger/stock_ledger.txt index aadf32306f..7da9f93dba 100644 --- a/erpnext/stock/report/stock_ledger/stock_ledger.txt +++ b/erpnext/stock/report/stock_ledger/stock_ledger.txt @@ -2,13 +2,14 @@ { "creation": "2013-11-29 17:08:23", "docstatus": 0, - "modified": "2013-11-29 17:28:15", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Stock Ledger Entry", "report_name": "Stock Ledger", diff --git a/erpnext/stock/report/stock_projected_qty/stock_projected_qty.txt b/erpnext/stock/report/stock_projected_qty/stock_projected_qty.txt index 1998f7ae74..4eb46c5ea0 100644 --- a/erpnext/stock/report/stock_projected_qty/stock_projected_qty.txt +++ b/erpnext/stock/report/stock_projected_qty/stock_projected_qty.txt @@ -2,7 +2,7 @@ { "creation": "2013-12-04 18:21:56", "docstatus": 0, - "modified": "2013-12-04 18:21:56", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Item", "report_name": "Stock Projected Qty", diff --git a/erpnext/stock/report/supplier_wise_sales_analytics/supplier_wise_sales_analytics.txt b/erpnext/stock/report/supplier_wise_sales_analytics/supplier_wise_sales_analytics.txt index 936292c2d9..53eeca7bf6 100644 --- a/erpnext/stock/report/supplier_wise_sales_analytics/supplier_wise_sales_analytics.txt +++ b/erpnext/stock/report/supplier_wise_sales_analytics/supplier_wise_sales_analytics.txt @@ -2,7 +2,7 @@ { "creation": "2013-11-29 15:45:39", "docstatus": 0, - "modified": "2013-11-29 15:45:40", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, @@ -10,6 +10,7 @@ "add_total_row": 1, "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Stock Ledger Entry", "report_name": "Supplier-Wise Sales Analytics", diff --git a/erpnext/stock/report/warehouse_wise_stock_balance/warehouse_wise_stock_balance.txt b/erpnext/stock/report/warehouse_wise_stock_balance/warehouse_wise_stock_balance.txt index 2513587632..c8e36eb95d 100644 --- a/erpnext/stock/report/warehouse_wise_stock_balance/warehouse_wise_stock_balance.txt +++ b/erpnext/stock/report/warehouse_wise_stock_balance/warehouse_wise_stock_balance.txt @@ -2,13 +2,14 @@ { "creation": "2013-06-05 11:00:31", "docstatus": 0, - "modified": "2013-06-05 11:00:31", + "modified": "2014-03-07 15:30:28", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Stock", "name": "__common__", "ref_doctype": "Stock Ledger Entry", "report_name": "Warehouse-Wise Stock Balance", diff --git a/erpnext/stock/utils.py b/erpnext/stock/utils.py index 7105e79401..3a0766aca8 100644 --- a/erpnext/stock/utils.py +++ b/erpnext/stock/utils.py @@ -289,7 +289,7 @@ def send_email_notification(mr_list): """ Notify user about auto creation of indent""" email_list = frappe.db.sql_list("""select distinct r.parent - from tabUserRole r, tabProfile p + from tabUserRole r, tabUser p where p.name = r.parent and p.enabled = 1 and p.docstatus < 2 and r.role in ('Purchase Manager','Material Manager') and p.name not in ('Administrator', 'All', 'Guest')""") @@ -320,5 +320,5 @@ def notify_errors(exceptions_list): Regards, Administrator""" % ("\n\n".join(["\n".join(msg) for msg in exceptions_list]),) - from frappe.profile import get_system_managers + from frappe.utils.user import get_system_managers sendmail(get_system_managers(), subject=subject, msg=msg) diff --git a/erpnext/support/doctype/customer_issue/customer_issue.txt b/erpnext/support/doctype/customer_issue/customer_issue.txt index 37db518888..90ac593ce9 100644 --- a/erpnext/support/doctype/customer_issue/customer_issue.txt +++ b/erpnext/support/doctype/customer_issue/customer_issue.txt @@ -2,7 +2,7 @@ { "creation": "2013-01-10 16:34:30", "docstatus": 0, - "modified": "2014-01-20 17:48:34", + "modified": "2014-01-20 17:48:35", "modified_by": "Administrator", "owner": "harshada@webnotestech.com" }, @@ -250,7 +250,7 @@ "no_copy": 1, "oldfieldname": "resolved_by", "oldfieldtype": "Link", - "options": "Profile", + "options": "User", "search_index": 1 }, { diff --git a/erpnext/support/doctype/maintenance_schedule/maintenance_schedule.py b/erpnext/support/doctype/maintenance_schedule/maintenance_schedule.py index 7211a8945c..28d821127a 100644 --- a/erpnext/support/doctype/maintenance_schedule/maintenance_schedule.py +++ b/erpnext/support/doctype/maintenance_schedule/maintenance_schedule.py @@ -81,7 +81,7 @@ class DocType(TransactionBase): "event_type": "Private", "ref_type": self.doc.doctype, "ref_name": self.doc.name - }).insert() + }).insert(ignore_permissions=1) frappe.db.set(self.doc, 'status', 'Submitted') diff --git a/erpnext/support/doctype/newsletter/newsletter.js b/erpnext/support/doctype/newsletter/newsletter.js index aaf9e19fe2..dfa9af9a2e 100644 --- a/erpnext/support/doctype/newsletter/newsletter.js +++ b/erpnext/support/doctype/newsletter/newsletter.js @@ -15,7 +15,7 @@ cur_frm.cscript.onload = function(doc) { cur_frm.cscript.refresh = function(doc) { erpnext.hide_naming_series(); if(!doc.__islocal && !cint(doc.email_sent) && !doc.__unsaved - && inList(frappe.boot.profile.can_write, doc.doctype)) { + && inList(frappe.boot.user.can_write, doc.doctype)) { cur_frm.add_custom_button(frappe._('Send'), function() { return $c_obj(make_doclist(doc.doctype, doc.name), 'send_emails', '', function(r) { cur_frm.refresh(); diff --git a/erpnext/support/doctype/support_ticket/get_support_mails.py b/erpnext/support/doctype/support_ticket/get_support_mails.py index d4d362b7a7..8ac5eba17a 100644 --- a/erpnext/support/doctype/support_ticket/get_support_mails.py +++ b/erpnext/support/doctype/support_ticket/get_support_mails.py @@ -72,6 +72,7 @@ def add_support_communication(subject, content, sender, docname=None, mail=None) "status": "Open", })]) ticket.ignore_permissions = True + ticket.ignore_mandatory = True ticket.insert() _make(content=content, sender=sender, subject = subject, diff --git a/erpnext/support/report/maintenance_schedules/maintenance_schedules.txt b/erpnext/support/report/maintenance_schedules/maintenance_schedules.txt index eec3d7f852..a4c6fdb5e0 100644 --- a/erpnext/support/report/maintenance_schedules/maintenance_schedules.txt +++ b/erpnext/support/report/maintenance_schedules/maintenance_schedules.txt @@ -2,13 +2,14 @@ { "creation": "2013-05-06 14:25:21", "docstatus": 0, - "modified": "2013-12-31 12:24:48", + "modified": "2014-03-07 15:30:27", "modified_by": "Administrator", "owner": "Administrator" }, { "doctype": "Report", "is_standard": "Yes", + "module": "Support", "name": "__common__", "query": "SELECT\n ms_sch.scheduled_date as \"Schedule Date:Date:120\",\n\tms_sch.item_code as \"Item Code:Link/Item:120\",\n\tms_sch.item_name as \"Item Name::120\",\n\tms_sch.serial_no as \"Serial No::120\",\n\tms_sch.sales_person as \"Sales Person::120\",\n\tms.customer_name as \"Customer:Link/Customer:120\",\n\tms.address_display as \"Customer Address::120\",\n\tms_item.prevdoc_docname as \"Sales Order:Link/Sales Order:120\",\n\tms.company as \"Company:Link/Company:120\"\n\t\nFROM\n\t`tabMaintenance Schedule` ms, \n `tabMaintenance Schedule Detail` ms_sch, \n `tabMaintenance Schedule Item` ms_item\nWHERE\n\tms.name = ms_sch.parent and ms.name = ms_item.parent and ms.docstatus = 1\nORDER BY\n\tms_sch.scheduled_date asc, ms_sch.item_code asc", "ref_doctype": "Maintenance Schedule", diff --git a/erpnext/translations/ar.csv b/erpnext/translations/ar.csv index 34bcbb34f1..7fa8b86d94 100644 --- a/erpnext/translations/ar.csv +++ b/erpnext/translations/ar.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,يوصى به Itemwise إعادة ترتيب JV,JV Job Applicant,طالب العمل Job Opening,افتتاح العمل -Job Profile,العمل الشخصي +Job User,العمل الشخصي Job Title,المسمى الوظيفي -"Job profile, qualifications required etc.",العمل الشخصي، المؤهلات المطلوبة الخ. +"Job User, qualifications required etc.",العمل الشخصي، المؤهلات المطلوبة الخ. Jobs Email Settings,إعدادات البريد الإلكتروني وظائف Journal Entries,مجلة مقالات Journal Entry,إدخال دفتر اليومية @@ -1678,7 +1678,7 @@ Ordered Quantity,أمرت الكمية Orders released for production.,أوامر الإفراج عن الإنتاج. Organization,منظمة Organization Name,اسم المنظمة -Organization Profile,الملف الشخصي المنظمة +Organization User,الملف الشخصي المنظمة Other,آخر Other Details,تفاصيل أخرى Out Qty,من الكمية diff --git a/erpnext/translations/de.csv b/erpnext/translations/de.csv index 0a0569e359..7c3f2d88c0 100644 --- a/erpnext/translations/de.csv +++ b/erpnext/translations/de.csv @@ -1352,9 +1352,9 @@ Itemwise Recommended Reorder Level,Itemwise Empfohlene Meldebestand JV,JV Job Applicant,Job Applicant Job Opening,Stellenangebot -Job Profile,Job Profil +Job User,Job Profil Job Title,Berufsbezeichnung -"Job profile, qualifications required etc.","Job-Profil, etc. erforderlichen Qualifikationen." +"Job User, qualifications required etc.","Job-Profil, etc. erforderlichen Qualifikationen." Jobs Email Settings,Jobs per E-Mail Einstellungen Journal Entries,Journal Entries Journal Entry,Journal Entry @@ -1752,7 +1752,7 @@ Ordered Quantity,Bestellte Menge Orders released for production.,Bestellungen für die Produktion freigegeben. Organization,Organisation Organization Name,Name der Organisation -Organization Profile,Organisation Profil +Organization User,Organisation Profil Other,Andere Other Details,Weitere Details Out Qty,out Menge diff --git a/erpnext/translations/el.csv b/erpnext/translations/el.csv index dd14658753..24f61796d1 100644 --- a/erpnext/translations/el.csv +++ b/erpnext/translations/el.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise Συνιστάται Αναδιάτ JV,JV Job Applicant,Αιτών εργασία Job Opening,Άνοιγμα θέσεων εργασίας -Job Profile,Προφίλ Εργασίας +Job User,Προφίλ Εργασίας Job Title,Τίτλος εργασίας -"Job profile, qualifications required etc.","Προφίλ δουλειά, προσόντα που απαιτούνται κ.λπ." +"Job User, qualifications required etc.","Προφίλ δουλειά, προσόντα που απαιτούνται κ.λπ." Jobs Email Settings,Εργασία Ρυθμίσεις Email Journal Entries,Εφημερίδα Καταχωρήσεις Journal Entry,Journal Entry @@ -1678,7 +1678,7 @@ Ordered Quantity,Διέταξε ποσότητα Orders released for production.,Παραγγελίες κυκλοφόρησε για την παραγωγή. Organization,οργάνωση Organization Name,Όνομα Οργανισμού -Organization Profile,Προφίλ Οργανισμού +Organization User,Προφίλ Οργανισμού Other,Άλλος Other Details,Άλλες λεπτομέρειες Out Qty,out Ποσότητα diff --git a/erpnext/translations/es.csv b/erpnext/translations/es.csv index f98ea6c72d..aabaaf30df 100644 --- a/erpnext/translations/es.csv +++ b/erpnext/translations/es.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise Recomendado Nivel de Reabastecimient JV,JV Job Applicant,Solicitante de empleo Job Opening,Job Opening -Job Profile,Job perfil +Job User,Job perfil Job Title,Título del trabajo -"Job profile, qualifications required etc.","Perfil de trabajo, calificaciones requeridas, etc" +"Job User, qualifications required etc.","Perfil de trabajo, calificaciones requeridas, etc" Jobs Email Settings,Trabajos Configuración del correo electrónico Journal Entries,Entradas de diario Journal Entry,Asientos de diario @@ -1678,7 +1678,7 @@ Ordered Quantity,Cantidad ordenada Orders released for production.,Los pedidos a producción. Organization,organización Organization Name,Nombre de la organización -Organization Profile,Perfil de la organización +Organization User,Perfil de la organización Other,Otro Other Details,Otros detalles Out Qty,Salir Cant. diff --git a/erpnext/translations/fr.csv b/erpnext/translations/fr.csv index 9db5c98cf1..ede1000a13 100644 --- a/erpnext/translations/fr.csv +++ b/erpnext/translations/fr.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise recommandée SEUIL DE COMMANDE JV,JV Job Applicant,Demandeur d'emploi Job Opening,Offre d'emploi -Job Profile,Profil d'emploi +Job User,Profil d'emploi Job Title,Titre d'emploi -"Job profile, qualifications required etc.","Profil de poste, qualifications requises, etc" +"Job User, qualifications required etc.","Profil de poste, qualifications requises, etc" Jobs Email Settings,Paramètres de messagerie Emploi Journal Entries,Journal Entries Journal Entry,Journal Entry @@ -1678,7 +1678,7 @@ Ordered Quantity,Quantité commandée Orders released for production.,Commandes validé pour la production. Organization,organisation Organization Name,Nom de l'organisme -Organization Profile,Profil de l'organisation +Organization User,Profil de l'organisation Other,Autre Other Details,Autres détails Out Qty,out Quantité diff --git a/erpnext/translations/hi.csv b/erpnext/translations/hi.csv index 7417aba91c..4a398fd311 100644 --- a/erpnext/translations/hi.csv +++ b/erpnext/translations/hi.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise स्तर Reorder अनुशं JV,जेवी Job Applicant,नौकरी आवेदक Job Opening,नौकरी खोलने -Job Profile,नौकरी प्रोफाइल +Job User,नौकरी प्रोफाइल Job Title,कार्य शीर्षक -"Job profile, qualifications required etc.","नौकरी प्रोफाइल योग्यता, आदि की आवश्यकता" +"Job User, qualifications required etc.","नौकरी प्रोफाइल योग्यता, आदि की आवश्यकता" Jobs Email Settings,नौकरियां ईमेल सेटिंग Journal Entries,जर्नल प्रविष्टियां Journal Entry,जर्नल प्रविष्टि @@ -1678,7 +1678,7 @@ Ordered Quantity,आदेशित मात्रा Orders released for production.,उत्पादन के लिए आदेश जारी किया. Organization,संगठन Organization Name,संगठन का नाम -Organization Profile,संगठन प्रोफाइल +Organization User,संगठन प्रोफाइल Other,अन्य Other Details,अन्य विवरण Out Qty,मात्रा बाहर diff --git a/erpnext/translations/hr.csv b/erpnext/translations/hr.csv index fed240c328..65ae6162c5 100644 --- a/erpnext/translations/hr.csv +++ b/erpnext/translations/hr.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise Preporučio redoslijeda Level JV,JV Job Applicant,Posao podnositelj Job Opening,Posao Otvaranje -Job Profile,Posao Profil +Job User,Posao Profil Job Title,Titula -"Job profile, qualifications required etc.","Posao profil, kvalifikacije potrebne, itd." +"Job User, qualifications required etc.","Posao profil, kvalifikacije potrebne, itd." Jobs Email Settings,Poslovi Postavke e-pošte Journal Entries,Časopis upisi Journal Entry,Časopis Stupanje @@ -1678,7 +1678,7 @@ Ordered Quantity,Količina Ž Orders released for production.,Narudžbe objavljen za proizvodnju. Organization,organizacija Organization Name,Naziv organizacije -Organization Profile,Organizacija Profil +Organization User,Organizacija Profil Other,Drugi Other Details,Ostali podaci Out Qty,Od kol diff --git a/erpnext/translations/it.csv b/erpnext/translations/it.csv index 0c3cbf40e1..72682555bb 100644 --- a/erpnext/translations/it.csv +++ b/erpnext/translations/it.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise consigliata riordino Livello JV,JV Job Applicant,Candidato di lavoro Job Opening,Apertura di lavoro -Job Profile,Profilo di lavoro +Job User,Profilo di lavoro Job Title,Professione -"Job profile, qualifications required etc.","Profilo professionale, le qualifiche richieste, ecc" +"Job User, qualifications required etc.","Profilo professionale, le qualifiche richieste, ecc" Jobs Email Settings,Impostazioni email Lavoro Journal Entries,Prime note Journal Entry,Journal Entry @@ -1678,7 +1678,7 @@ Ordered Quantity,Ordinato Quantità Orders released for production.,Gli ordini rilasciati per la produzione. Organization,organizzazione Organization Name,Nome organizzazione -Organization Profile,Profilo dell'organizzazione +Organization User,Profilo dell'organizzazione Other,Altro Other Details,Altri dettagli Out Qty,out Quantità diff --git a/erpnext/translations/nl.csv b/erpnext/translations/nl.csv index 030f77ec64..5f74b40112 100644 --- a/erpnext/translations/nl.csv +++ b/erpnext/translations/nl.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise Aanbevolen Reorder Niveau JV,JV Job Applicant,Sollicitant Job Opening,Vacature -Job Profile,Functieprofiel +Job User,Functieprofiel Job Title,Functie -"Job profile, qualifications required etc.","Functieprofiel, kwalificaties, etc. nodig" +"Job User, qualifications required etc.","Functieprofiel, kwalificaties, etc. nodig" Jobs Email Settings,Vacatures E-mailinstellingen Journal Entries,Journaalposten Journal Entry,Journal Entry @@ -1678,7 +1678,7 @@ Ordered Quantity,Bestelde hoeveelheid Orders released for production.,Bestellingen vrijgegeven voor productie. Organization,organisatie Organization Name,Naam van de Organisatie -Organization Profile,Organisatie Profiel +Organization User,Organisatie Profiel Other,Ander Other Details,Andere Details Out Qty,out Aantal diff --git a/erpnext/translations/pt-BR.csv b/erpnext/translations/pt-BR.csv index 6b563488fe..0bfd6227a7 100644 --- a/erpnext/translations/pt-BR.csv +++ b/erpnext/translations/pt-BR.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise Recomendado nível de reposição JV,JV Job Applicant,Candidato a emprego Job Opening,Vaga de emprego -Job Profile,Perfil da vaga +Job User,Perfil da vaga Job Title,Cargo -"Job profile, qualifications required etc.","Perfil da vaga, qualificações exigidas, etc" +"Job User, qualifications required etc.","Perfil da vaga, qualificações exigidas, etc" Jobs Email Settings,Configurações do e-mail de empregos Journal Entries,Lançamentos do livro Diário Journal Entry,Lançamento do livro Diário @@ -1678,7 +1678,7 @@ Ordered Quantity,Quantidade encomendada Orders released for production.,Ordens liberadas para produção. Organization,organização Organization Name,Nome da Organização -Organization Profile,Perfil da Organização +Organization User,Perfil da Organização Other,Outro Other Details,Outros detalhes Out Qty,Fora Qtde diff --git a/erpnext/translations/pt.csv b/erpnext/translations/pt.csv index 1b1b2da7f0..898ced3aff 100644 --- a/erpnext/translations/pt.csv +++ b/erpnext/translations/pt.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise Recomendado nível de reposição JV,JV Job Applicant,Candidato a emprego Job Opening,Abertura de emprego -Job Profile,Perfil trabalho +Job User,Perfil trabalho Job Title,Cargo -"Job profile, qualifications required etc.","Profissão de perfil, qualificações exigidas, etc" +"Job User, qualifications required etc.","Profissão de perfil, qualificações exigidas, etc" Jobs Email Settings,E-mail Configurações de empregos Journal Entries,Jornal entradas Journal Entry,Journal Entry @@ -1678,7 +1678,7 @@ Ordered Quantity,Quantidade pedida Orders released for production.,Ordens liberado para produção. Organization,organisatie Organization Name,Naam van de Organisatie -Organization Profile,Perfil da Organização +Organization User,Perfil da Organização Other,Outro Other Details,Outros detalhes Out Qty,out Aantal diff --git a/erpnext/translations/sr.csv b/erpnext/translations/sr.csv index 42e74a6606..290ec8952c 100644 --- a/erpnext/translations/sr.csv +++ b/erpnext/translations/sr.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Препоручени ниво Итемви JV,ЈВ Job Applicant,Посао захтева Job Opening,Посао Отварање -Job Profile,Посао Профил +Job User,Посао Профил Job Title,Звање -"Job profile, qualifications required etc.","Посао профила, квалификације потребне итд" +"Job User, qualifications required etc.","Посао профила, квалификације потребне итд" Jobs Email Settings,Послови Емаил подешавања Journal Entries,Часопис Ентриес Journal Entry,Јоурнал Ентри @@ -1678,7 +1678,7 @@ Ordered Quantity,Наручено Количина Orders released for production.,Поруџбине пуштен за производњу. Organization,организација Organization Name,Име организације -Organization Profile,Организација Профил +Organization User,Организација Профил Other,Други Other Details,Остали детаљи Out Qty,Од Кол diff --git a/erpnext/translations/ta.csv b/erpnext/translations/ta.csv index 8a5e9990ea..caa5e735f3 100644 --- a/erpnext/translations/ta.csv +++ b/erpnext/translations/ta.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,இனவாரியாக நிலை ம JV,கூட்டு தொழில் Job Applicant,வேலை விண்ணப்பதாரர் Job Opening,வேலை திறக்கிறது -Job Profile,வேலை செய்தது +Job User,வேலை செய்தது Job Title,வேலை தலைப்பு -"Job profile, qualifications required etc.","வேலை சுயவிவரத்தை, தகுதிகள் போன்ற தேவை" +"Job User, qualifications required etc.","வேலை சுயவிவரத்தை, தகுதிகள் போன்ற தேவை" Jobs Email Settings,வேலைகள் மின்னஞ்சல் அமைப்புகள் Journal Entries,ஜர்னல் பதிவுகள் Journal Entry,பத்திரிகை நுழைவு @@ -1678,7 +1678,7 @@ Ordered Quantity,உத்தரவிட்டார் அளவு Orders released for production.,ஆணைகள் உற்பத்தி வெளியிடப்பட்டது. Organization,அமைப்பு Organization Name,நிறுவன பெயர் -Organization Profile,அமைப்பு விவரம் +Organization User,அமைப்பு விவரம் Other,வேறு Other Details,மற்ற விவரங்கள் Out Qty,அளவு அவுட் diff --git a/erpnext/translations/th.csv b/erpnext/translations/th.csv index 90135436d8..15b76635f1 100644 --- a/erpnext/translations/th.csv +++ b/erpnext/translations/th.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,แนะนำ Itemwise Reorder ระดั JV,JV Job Applicant,ผู้สมัครงาน Job Opening,เปิดงาน -Job Profile,รายละเอียดงาน +Job User,รายละเอียดงาน Job Title,ตำแหน่งงาน -"Job profile, qualifications required etc.",งานคุณสมบัติรายละเอียดที่จำเป็น ฯลฯ +"Job User, qualifications required etc.",งานคุณสมบัติรายละเอียดที่จำเป็น ฯลฯ Jobs Email Settings,งานการตั้งค่าอีเมล Journal Entries,คอมเมนต์วารสาร Journal Entry,รายการวารสาร @@ -1678,7 +1678,7 @@ Ordered Quantity,จำนวนสั่ง Orders released for production.,คำสั่งปล่อยให้การผลิต Organization,องค์กร Organization Name,ชื่อองค์กร -Organization Profile,รายละเอียดองค์กร +Organization User,รายละเอียดองค์กร Other,อื่น ๆ Other Details,รายละเอียดอื่น ๆ Out Qty,ออก จำนวน diff --git a/erpnext/translations/zh-cn.csv b/erpnext/translations/zh-cn.csv index 2c76909844..eb715a46b2 100644 --- a/erpnext/translations/zh-cn.csv +++ b/erpnext/translations/zh-cn.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise推荐级别重新排序 JV,合资公司 Job Applicant,求职者 Job Opening,招聘开幕 -Job Profile,工作简介 +Job User,工作简介 Job Title,职位 -"Job profile, qualifications required etc.",所需的工作概况,学历等。 +"Job User, qualifications required etc.",所需的工作概况,学历等。 Jobs Email Settings,乔布斯邮件设置 Journal Entries,日记帐分录 Journal Entry,日记帐分录 @@ -1678,7 +1678,7 @@ Ordered Quantity,订购数量 Orders released for production.,发布生产订单。 Organization,组织 Organization Name,组织名称 -Organization Profile,组织简介 +Organization User,组织简介 Other,其他 Other Details,其他详细信息 Out Qty,输出数量 diff --git a/erpnext/translations/zh-tw.csv b/erpnext/translations/zh-tw.csv index 4a56919e30..fc5a9be7cd 100644 --- a/erpnext/translations/zh-tw.csv +++ b/erpnext/translations/zh-tw.csv @@ -1304,9 +1304,9 @@ Itemwise Recommended Reorder Level,Itemwise推薦級別重新排序 JV,合資公司 Job Applicant,求職者 Job Opening,招聘開幕 -Job Profile,工作簡介 +Job User,工作簡介 Job Title,職位 -"Job profile, qualifications required etc.",所需的工作概況,學歷等。 +"Job User, qualifications required etc.",所需的工作概況,學歷等。 Jobs Email Settings,喬布斯郵件設置 Journal Entries,日記帳分錄 Journal Entry,日記帳分錄 @@ -1678,7 +1678,7 @@ Ordered Quantity,訂購數量 Orders released for production.,發布生產訂單。 Organization,組織 Organization Name,組織名稱 -Organization Profile,組織簡介 +Organization User,組織簡介 Other,其他 Other Details,其他詳細信息 Out Qty,輸出數量 diff --git a/erpnext/utilities/doctype/note_user/note_user.txt b/erpnext/utilities/doctype/note_user/note_user.txt index 86fdc44a9f..6ae80de1a4 100644 --- a/erpnext/utilities/doctype/note_user/note_user.txt +++ b/erpnext/utilities/doctype/note_user/note_user.txt @@ -2,7 +2,7 @@ { "creation": "2013-05-24 14:24:48", "docstatus": 0, - "modified": "2013-12-20 19:23:22", + "modified": "2013-12-20 19:23:23", "modified_by": "Administrator", "owner": "Administrator" }, @@ -32,7 +32,7 @@ "fieldname": "user", "fieldtype": "Link", "label": "User", - "options": "Profile", + "options": "User", "reqd": 1 }, { diff --git a/erpnext/utilities/transaction_base.py b/erpnext/utilities/transaction_base.py index e84cdf93ee..11dfc5252b 100644 --- a/erpnext/utilities/transaction_base.py +++ b/erpnext/utilities/transaction_base.py @@ -47,7 +47,7 @@ class TransactionBase(StatusUpdater): "ref_name": self.doc.name }] - if frappe.db.exists("Profile", self.doc.contact_by): + if frappe.db.exists("User", self.doc.contact_by): event_doclist.append({ "doctype": "Event User", "parentfield": "event_individuals",