blob: 66e935ab6fdd0bb105ff6f02fefa8004f7ddaba4 [file] [log] [blame]
Rushabh Mehtaad45e312013-11-20 12:59:58 +05301// Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors
Rushabh Mehtae67d1fb2013-08-05 14:59:54 +05302// License: GNU General Public License v3. See license.txt
Rushabh Mehta3966f1d2012-02-23 12:35:32 +05303
Pratik Vyasc1e6e4c2011-06-08 14:37:15 +05304// Preset
5// ------
6// cur_frm.cscript.tname - Details table name
7// cur_frm.cscript.fname - Details fieldname
Rushabh Mehta6de403f2013-12-13 14:10:14 +05308// cur_frm.cscript.other_fname - fieldname
Pratik Vyasc1e6e4c2011-06-08 14:37:15 +05309// cur_frm.cscript.sales_team_fname - Sales Team fieldname
10
Rushabh Mehta793ba6b2014-02-14 15:47:51 +053011frappe.provide("erpnext.selling");
12frappe.require("assets/erpnext/js/transaction.js");
Rushabh Mehtab09d9da2014-01-02 11:47:23 +053013
Rushabh Mehta6de403f2013-12-13 14:10:14 +053014{% include "public/js/controllers/accounts.js" %}
Anand Doshi1dde46a2013-05-15 21:15:57 +053015
Anand Doshi3543f302013-05-24 19:25:01 +053016erpnext.selling.SellingController = erpnext.TransactionController.extend({
Anand Doshi9b496142013-07-11 19:13:58 +053017 onload: function() {
18 this._super();
Anand Doshi9b496142013-07-11 19:13:58 +053019 this.setup_queries();
Anand Doshi33fe8672013-08-02 12:39:10 +053020 this.toggle_editable_price_list_rate();
Anand Doshi9b496142013-07-11 19:13:58 +053021 },
Anand Doshibd67e872014-04-11 16:51:27 +053022
Rushabh Mehtab6843f22014-06-04 13:10:41 +053023 onload_post_render: function() {
Rushabh Mehta880b3ef2014-06-06 11:45:11 +053024 cur_frm.get_field(this.fname).grid.set_multiple_add("item_code", "qty");
Rushabh Mehtab6843f22014-06-04 13:10:41 +053025 },
26
Anand Doshi9b496142013-07-11 19:13:58 +053027 setup_queries: function() {
Anand Doshi99100a42013-07-04 17:13:53 +053028 var me = this;
Anand Doshibd67e872014-04-11 16:51:27 +053029
Anand Doshif3096132013-05-21 19:35:06 +053030 this.frm.add_fetch("sales_partner", "commission_rate", "commission_rate");
Anand Doshibd67e872014-04-11 16:51:27 +053031
32 $.each([["customer_address", "customer_filter"],
Anand Doshid5d39ac2013-07-29 13:28:37 +053033 ["shipping_address_name", "customer_filter"],
Anand Doshibd67e872014-04-11 16:51:27 +053034 ["contact_person", "customer_filter"],
35 ["customer", "customer"],
36 ["lead", "lead"]],
Anand Doshid5d39ac2013-07-29 13:28:37 +053037 function(i, opts) {
Anand Doshibd67e872014-04-11 16:51:27 +053038 if(me.frm.fields_dict[opts[0]])
Anand Doshid5d39ac2013-07-29 13:28:37 +053039 me.frm.set_query(opts[0], erpnext.queries[opts[1]]);
40 });
Anand Doshibd67e872014-04-11 16:51:27 +053041
Akhilesh Darjee4f721562014-01-29 16:31:38 +053042 if(this.frm.fields_dict.taxes_and_charges) {
43 this.frm.set_query("taxes_and_charges", function() {
Saurabhf52dc072013-07-10 13:07:49 +053044 return {
45 filters: [
46 ['Sales Taxes and Charges Master', 'company', '=', me.frm.doc.company],
Saurabhf52dc072013-07-10 13:07:49 +053047 ['Sales Taxes and Charges Master', 'docstatus', '!=', 2]
48 ]
49 }
Anand Doshi99100a42013-07-04 17:13:53 +053050 });
51 }
Anand Doshi99100a42013-07-04 17:13:53 +053052
Rushabh Mehta4a404e92013-08-09 18:11:35 +053053 if(this.frm.fields_dict.selling_price_list) {
54 this.frm.set_query("selling_price_list", function() {
Nabin Haitdc15b4f2014-01-20 16:48:49 +053055 return { filters: { selling: 1 } };
Anand Doshi720a01a2013-07-26 11:32:02 +053056 });
Anand Doshi720a01a2013-07-26 11:32:02 +053057 }
Anand Doshibd67e872014-04-11 16:51:27 +053058
Anand Doshi99100a42013-07-04 17:13:53 +053059 if(!this.fname) {
60 return;
61 }
Anand Doshibd67e872014-04-11 16:51:27 +053062
Anand Doshi99100a42013-07-04 17:13:53 +053063 if(this.frm.fields_dict[this.fname].grid.get_field('item_code')) {
64 this.frm.set_query("item_code", this.fname, function() {
Anand Doshi9b496142013-07-11 19:13:58 +053065 return {
Rushabh Mehta6de403f2013-12-13 14:10:14 +053066 query: "erpnext.controllers.queries.item_query",
Anand Doshi9b496142013-07-11 19:13:58 +053067 filters: (me.frm.doc.order_type === "Maintenance" ?
68 {'is_service_item': 'Yes'}:
69 {'is_sales_item': 'Yes' })
70 }
Anand Doshi99100a42013-07-04 17:13:53 +053071 });
72 }
Anand Doshibd67e872014-04-11 16:51:27 +053073
Anand Doshi99100a42013-07-04 17:13:53 +053074 if(this.frm.fields_dict[this.fname].grid.get_field('batch_no')) {
75 this.frm.set_query("batch_no", this.fname, function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +053076 var item = frappe.get_doc(cdt, cdn);
Anand Doshi99100a42013-07-04 17:13:53 +053077 if(!item.item_code) {
Pratik Vyasb52618c2014-04-14 16:25:30 +053078 frappe.throw(__("Please enter Item Code to get batch no"));
Anand Doshi99100a42013-07-04 17:13:53 +053079 } else {
Nabin Haitd1fd1e22013-10-18 12:29:11 +053080 filters = {
81 'item_code': item.item_code,
82 'posting_date': me.frm.doc.posting_date,
83 }
84 if(item.warehouse) filters["warehouse"] = item.warehouse
Anand Doshibd67e872014-04-11 16:51:27 +053085
Nabin Haitd1fd1e22013-10-18 12:29:11 +053086 return {
Akhilesh Darjee4f721562014-01-29 16:31:38 +053087 query : "erpnext.controllers.queries.get_batch_no",
Nabin Haitd1fd1e22013-10-18 12:29:11 +053088 filters: filters
Anand Doshi99100a42013-07-04 17:13:53 +053089 }
90 }
91 });
92 }
Anand Doshibd67e872014-04-11 16:51:27 +053093
Anand Doshied698922013-07-23 15:16:50 +053094 if(this.frm.fields_dict.sales_team && this.frm.fields_dict.sales_team.grid.get_field("sales_person")) {
Anand Doshid5d39ac2013-07-29 13:28:37 +053095 this.frm.set_query("sales_person", "sales_team", erpnext.queries.not_a_group_filter);
Anand Doshied698922013-07-23 15:16:50 +053096 }
Anand Doshi1dde46a2013-05-15 21:15:57 +053097 },
Anand Doshibd67e872014-04-11 16:51:27 +053098
Anand Doshic4a54fe2013-08-01 18:19:51 +053099 refresh: function() {
100 this._super();
Anand Doshibd67e872014-04-11 16:51:27 +0530101 this.frm.toggle_display("customer_name",
Akhilesh Darjee5ce1b8b2013-12-09 16:29:04 +0530102 (this.frm.doc.customer_name && this.frm.doc.customer_name!==this.frm.doc.customer));
Anand Doshic4a54fe2013-08-01 18:19:51 +0530103 if(this.frm.fields_dict.packing_details) {
Rushabh Mehtaaa355af2014-03-26 18:24:30 +0530104 var packing_list_exists = (this.frm.doc.packing_details || []).length;
Anand Doshic4a54fe2013-08-01 18:19:51 +0530105 this.frm.toggle_display("packing_list", packing_list_exists ? true : false);
106 }
Rushabh Mehta8aded132013-07-04 12:50:52 +0530107 },
Anand Doshibd67e872014-04-11 16:51:27 +0530108
Anand Doshi3543f302013-05-24 19:25:01 +0530109 customer: function() {
Nabin Haita3dd72a2014-05-28 12:49:20 +0530110 var me = this;
111 erpnext.utils.get_party_details(this.frm, null, null, function(){me.apply_pricing_rule()});
Anand Doshi3543f302013-05-24 19:25:01 +0530112 },
Anand Doshibd67e872014-04-11 16:51:27 +0530113
Nabin Haita279d782013-07-15 13:04:33 +0530114 customer_address: function() {
Rushabh Mehtab09d9da2014-01-02 11:47:23 +0530115 erpnext.utils.get_address_display(this.frm, "customer_address");
Nabin Haita279d782013-07-15 13:04:33 +0530116 },
Anand Doshibd67e872014-04-11 16:51:27 +0530117
Nabin Hait9d1f0772014-02-19 17:43:24 +0530118 shipping_address_name: function() {
119 erpnext.utils.get_address_display(this.frm, "shipping_address_name", "shipping_address");
120 },
Anand Doshibd67e872014-04-11 16:51:27 +0530121
Nabin Haita279d782013-07-15 13:04:33 +0530122 contact_person: function() {
Rushabh Mehtab09d9da2014-01-02 11:47:23 +0530123 erpnext.utils.get_contact_details(this.frm);
Nabin Haita279d782013-07-15 13:04:33 +0530124 },
Anand Doshibd67e872014-04-11 16:51:27 +0530125
Nabin Haita3dd72a2014-05-28 12:49:20 +0530126 sales_partner: function() {
127 this.apply_pricing_rule();
128 },
129
130 campaign: function() {
131 this.apply_pricing_rule();
132 },
133
Anand Doshif3096132013-05-21 19:35:06 +0530134 barcode: function(doc, cdt, cdn) {
135 this.item_code(doc, cdt, cdn);
Anand Doshi1dde46a2013-05-15 21:15:57 +0530136 },
Anand Doshibd67e872014-04-11 16:51:27 +0530137
Rushabh Mehta4a404e92013-08-09 18:11:35 +0530138 selling_price_list: function() {
Anand Doshidffec8f2014-07-01 17:45:15 +0530139 this.apply_price_list();
Anand Doshif3096132013-05-21 19:35:06 +0530140 },
Anand Doshibd67e872014-04-11 16:51:27 +0530141
Nabin Haita7f757a2014-02-10 17:54:04 +0530142 price_list_rate: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530143 var item = frappe.get_doc(cdt, cdn);
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530144 frappe.model.round_floats_in(item, ["price_list_rate", "discount_percentage"]);
Anand Doshibd67e872014-04-11 16:51:27 +0530145
Nabin Hait7979f7e2014-02-10 18:26:49 +0530146 item.rate = flt(item.price_list_rate * (1 - item.discount_percentage / 100.0),
147 precision("rate", item));
Anand Doshibd67e872014-04-11 16:51:27 +0530148
Anand Doshif3096132013-05-21 19:35:06 +0530149 this.calculate_taxes_and_totals();
150 },
Anand Doshibd67e872014-04-11 16:51:27 +0530151
Nabin Haita7f757a2014-02-10 17:54:04 +0530152 discount_percentage: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530153 var item = frappe.get_doc(cdt, cdn);
Nabin Haita7f757a2014-02-10 17:54:04 +0530154 if(!item.price_list_rate) {
155 item.discount_percentage = 0.0;
Anand Doshi923d41d2013-05-28 17:23:36 +0530156 } else {
Nabin Haita7f757a2014-02-10 17:54:04 +0530157 this.price_list_rate(doc, cdt, cdn);
Anand Doshi923d41d2013-05-28 17:23:36 +0530158 }
Anand Doshif3096132013-05-21 19:35:06 +0530159 },
Anand Doshibd67e872014-04-11 16:51:27 +0530160
Nabin Hait7979f7e2014-02-10 18:26:49 +0530161 rate: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530162 var item = frappe.get_doc(cdt, cdn);
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530163 frappe.model.round_floats_in(item, ["rate", "price_list_rate"]);
Anand Doshibd67e872014-04-11 16:51:27 +0530164
Nabin Haita7f757a2014-02-10 17:54:04 +0530165 if(item.price_list_rate) {
Nabin Hait7979f7e2014-02-10 18:26:49 +0530166 item.discount_percentage = flt((1 - item.rate / item.price_list_rate) * 100.0,
Nabin Haita7f757a2014-02-10 17:54:04 +0530167 precision("discount_percentage", item));
Anand Doshif3096132013-05-21 19:35:06 +0530168 } else {
Nabin Haita7f757a2014-02-10 17:54:04 +0530169 item.discount_percentage = 0.0;
Anand Doshif3096132013-05-21 19:35:06 +0530170 }
Anand Doshibd67e872014-04-11 16:51:27 +0530171
Anand Doshif3096132013-05-21 19:35:06 +0530172 this.calculate_taxes_and_totals();
173 },
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530174
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530175 discount_amount: function() {
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530176 this.calculate_taxes_and_totals();
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530177 },
Anand Doshibd67e872014-04-11 16:51:27 +0530178
Anand Doshif3096132013-05-21 19:35:06 +0530179 commission_rate: function() {
180 this.calculate_commission();
181 refresh_field("total_commission");
182 },
Anand Doshibd67e872014-04-11 16:51:27 +0530183
Anand Doshif3096132013-05-21 19:35:06 +0530184 total_commission: function() {
185 if(this.frm.doc.net_total) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530186 frappe.model.round_floats_in(this.frm.doc, ["net_total", "total_commission"]);
Anand Doshibd67e872014-04-11 16:51:27 +0530187
Anand Doshif3096132013-05-21 19:35:06 +0530188 if(this.frm.doc.net_total < this.frm.doc.total_commission) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530189 var msg = (__("[Error]") + " " +
190 __(frappe.meta.get_label(this.frm.doc.doctype, "total_commission",
Anand Doshibd67e872014-04-11 16:51:27 +0530191 this.frm.doc.name)) + " > " +
Pratik Vyasb52618c2014-04-14 16:25:30 +0530192 __(frappe.meta.get_label(this.frm.doc.doctype, "net_total", this.frm.doc.name)));
Anand Doshif3096132013-05-21 19:35:06 +0530193 msgprint(msg);
194 throw msg;
195 }
Anand Doshibd67e872014-04-11 16:51:27 +0530196
197 this.frm.set_value("commission_rate",
Anand Doshif3096132013-05-21 19:35:06 +0530198 flt(this.frm.doc.total_commission * 100.0 / this.frm.doc.net_total));
199 }
200 },
Anand Doshibd67e872014-04-11 16:51:27 +0530201
Anand Doshif3096132013-05-21 19:35:06 +0530202 allocated_percentage: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530203 var sales_person = frappe.get_doc(cdt, cdn);
Anand Doshibd67e872014-04-11 16:51:27 +0530204
Anand Doshif3096132013-05-21 19:35:06 +0530205 if(sales_person.allocated_percentage) {
206 sales_person.allocated_percentage = flt(sales_person.allocated_percentage,
207 precision("allocated_percentage", sales_person));
208 sales_person.allocated_amount = flt(this.frm.doc.net_total *
Anand Doshibd67e872014-04-11 16:51:27 +0530209 sales_person.allocated_percentage / 100.0,
Anand Doshif3096132013-05-21 19:35:06 +0530210 precision("allocated_amount", sales_person));
211
212 refresh_field(["allocated_percentage", "allocated_amount"], sales_person.name,
213 sales_person.parentfield);
214 }
215 },
Anand Doshibd67e872014-04-11 16:51:27 +0530216
Anand Doshifc777182013-05-27 19:29:07 +0530217 warehouse: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530218 var item = frappe.get_doc(cdt, cdn);
Anand Doshi1dc95ed2013-07-23 13:36:38 +0530219 if(item.item_code && item.warehouse) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530220 return this.frm.call({
Nabin Hait0984f222014-05-30 19:10:12 +0530221 method: "erpnext.stock.get_item_details.get_available_qty",
Anand Doshifc777182013-05-27 19:29:07 +0530222 child: item,
223 args: {
224 item_code: item.item_code,
Anand Doshi1dc95ed2013-07-23 13:36:38 +0530225 warehouse: item.warehouse,
Anand Doshifc777182013-05-27 19:29:07 +0530226 },
227 });
228 }
229 },
Anand Doshibd67e872014-04-11 16:51:27 +0530230
Anand Doshi33fe8672013-08-02 12:39:10 +0530231 toggle_editable_price_list_rate: function() {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530232 var df = frappe.meta.get_docfield(this.tname, "price_list_rate", this.frm.doc.name);
233 var editable_price_list_rate = cint(frappe.defaults.get_default("editable_price_list_rate"));
Anand Doshibd67e872014-04-11 16:51:27 +0530234
Anand Doshi33fe8672013-08-02 12:39:10 +0530235 if(df && editable_price_list_rate) {
236 df.read_only = 0;
237 }
238 },
Anand Doshibd67e872014-04-11 16:51:27 +0530239
Anand Doshi652bc072014-04-16 15:21:46 +0530240 calculate_taxes_and_totals: function(update_paid_amount) {
Anand Doshi3543f302013-05-24 19:25:01 +0530241 this._super();
Anand Doshi652bc072014-04-16 15:21:46 +0530242 this.calculate_total_advance("Sales Invoice", "advance_adjustment_details", update_paid_amount);
Anand Doshif3096132013-05-21 19:35:06 +0530243 this.calculate_commission();
244 this.calculate_contribution();
Anand Doshi923d41d2013-05-28 17:23:36 +0530245
246 // TODO check for custom_recalc in custom scripts of server
Anand Doshibd67e872014-04-11 16:51:27 +0530247
Anand Doshi2168e392013-05-23 19:25:08 +0530248 this.frm.refresh_fields();
Anand Doshif3096132013-05-21 19:35:06 +0530249 },
Anand Doshibd67e872014-04-11 16:51:27 +0530250
Anand Doshif3096132013-05-21 19:35:06 +0530251 calculate_item_values: function() {
252 var me = this;
Anand Doshibd67e872014-04-11 16:51:27 +0530253
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530254 if (!this.discount_amount_applied) {
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530255 $.each(this.frm.item_doclist, function(i, item) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530256 frappe.model.round_floats_in(item);
Nabin Hait1eb56012014-02-10 19:20:15 +0530257 item.amount = flt(item.rate * item.qty, precision("amount", item));
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530258
Nabin Haita7f757a2014-02-10 17:54:04 +0530259 me._set_in_company_currency(item, "price_list_rate", "base_price_list_rate");
Nabin Hait7979f7e2014-02-10 18:26:49 +0530260 me._set_in_company_currency(item, "rate", "base_rate");
Nabin Hait1eb56012014-02-10 19:20:15 +0530261 me._set_in_company_currency(item, "amount", "base_amount");
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530262 });
263 }
Anand Doshif3096132013-05-21 19:35:06 +0530264 },
Anand Doshibd67e872014-04-11 16:51:27 +0530265
Anand Doshif3096132013-05-21 19:35:06 +0530266 determine_exclusive_rate: function() {
267 var me = this;
268 $.each(me.frm.item_doclist, function(n, item) {
269 var item_tax_map = me._load_item_tax_rate(item.item_tax_rate);
270 var cumulated_tax_fraction = 0.0;
Anand Doshibd67e872014-04-11 16:51:27 +0530271
Anand Doshif3096132013-05-21 19:35:06 +0530272 $.each(me.frm.tax_doclist, function(i, tax) {
273 tax.tax_fraction_for_current_item = me.get_current_tax_fraction(tax, item_tax_map);
Anand Doshibd67e872014-04-11 16:51:27 +0530274
Anand Doshif3096132013-05-21 19:35:06 +0530275 if(i==0) {
Anand Doshi2168e392013-05-23 19:25:08 +0530276 tax.grand_total_fraction_for_current_item = 1 + tax.tax_fraction_for_current_item;
Anand Doshif3096132013-05-21 19:35:06 +0530277 } else {
Anand Doshibd67e872014-04-11 16:51:27 +0530278 tax.grand_total_fraction_for_current_item =
Anand Doshi2168e392013-05-23 19:25:08 +0530279 me.frm.tax_doclist[i-1].grand_total_fraction_for_current_item +
Anand Doshif3096132013-05-21 19:35:06 +0530280 tax.tax_fraction_for_current_item;
281 }
Anand Doshibd67e872014-04-11 16:51:27 +0530282
Anand Doshif3096132013-05-21 19:35:06 +0530283 cumulated_tax_fraction += tax.tax_fraction_for_current_item;
284 });
Anand Doshibd67e872014-04-11 16:51:27 +0530285
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530286 if(cumulated_tax_fraction && !me.discount_amount_applied) {
Nabin Hait1eb56012014-02-10 19:20:15 +0530287 item.base_amount = flt(
288 (item.amount * me.frm.doc.conversion_rate) / (1 + cumulated_tax_fraction),
289 precision("base_amount", item));
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530290
Nabin Hait1eb56012014-02-10 19:20:15 +0530291 item.base_rate = flt(item.base_amount / item.qty, precision("base_rate", item));
Anand Doshibd67e872014-04-11 16:51:27 +0530292
Nabin Haita7f757a2014-02-10 17:54:04 +0530293 if(item.discount_percentage == 100) {
Nabin Hait7979f7e2014-02-10 18:26:49 +0530294 item.base_price_list_rate = item.base_rate;
295 item.base_rate = 0.0;
Anand Doshif3096132013-05-21 19:35:06 +0530296 } else {
Nabin Hait7979f7e2014-02-10 18:26:49 +0530297 item.base_price_list_rate = flt(item.base_rate / (1 - item.discount_percentage / 100.0),
Nabin Haita7f757a2014-02-10 17:54:04 +0530298 precision("base_price_list_rate", item));
Anand Doshif3096132013-05-21 19:35:06 +0530299 }
300 }
301 });
302 },
Anand Doshibd67e872014-04-11 16:51:27 +0530303
Anand Doshif3096132013-05-21 19:35:06 +0530304 get_current_tax_fraction: function(tax, item_tax_map) {
305 // Get tax fraction for calculating tax exclusive amount
306 // from tax inclusive amount
307 var current_tax_fraction = 0.0;
Anand Doshibd67e872014-04-11 16:51:27 +0530308
Anand Doshif3096132013-05-21 19:35:06 +0530309 if(cint(tax.included_in_print_rate)) {
Anand Doshi2168e392013-05-23 19:25:08 +0530310 var tax_rate = this._get_tax_rate(tax, item_tax_map);
Anand Doshibd67e872014-04-11 16:51:27 +0530311
Anand Doshif3096132013-05-21 19:35:06 +0530312 if(tax.charge_type == "On Net Total") {
313 current_tax_fraction = (tax_rate / 100.0);
Anand Doshibd67e872014-04-11 16:51:27 +0530314
Anand Doshif3096132013-05-21 19:35:06 +0530315 } else if(tax.charge_type == "On Previous Row Amount") {
316 current_tax_fraction = (tax_rate / 100.0) *
Anand Doshi2168e392013-05-23 19:25:08 +0530317 this.frm.tax_doclist[cint(tax.row_id) - 1].tax_fraction_for_current_item;
Anand Doshibd67e872014-04-11 16:51:27 +0530318
Anand Doshif3096132013-05-21 19:35:06 +0530319 } else if(tax.charge_type == "On Previous Row Total") {
320 current_tax_fraction = (tax_rate / 100.0) *
Anand Doshi2168e392013-05-23 19:25:08 +0530321 this.frm.tax_doclist[cint(tax.row_id) - 1].grand_total_fraction_for_current_item;
Anand Doshif3096132013-05-21 19:35:06 +0530322 }
323 }
Anand Doshibd67e872014-04-11 16:51:27 +0530324
Anand Doshif3096132013-05-21 19:35:06 +0530325 return current_tax_fraction;
326 },
Anand Doshibd67e872014-04-11 16:51:27 +0530327
Anand Doshif3096132013-05-21 19:35:06 +0530328 calculate_net_total: function() {
329 var me = this;
Anand Doshif3096132013-05-21 19:35:06 +0530330 this.frm.doc.net_total = this.frm.doc.net_total_export = 0.0;
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530331
Anand Doshif3096132013-05-21 19:35:06 +0530332 $.each(this.frm.item_doclist, function(i, item) {
Nabin Hait1eb56012014-02-10 19:20:15 +0530333 me.frm.doc.net_total += item.base_amount;
334 me.frm.doc.net_total_export += item.amount;
Anand Doshif3096132013-05-21 19:35:06 +0530335 });
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530336
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530337 frappe.model.round_floats_in(this.frm.doc, ["net_total", "net_total_export"]);
Anand Doshif3096132013-05-21 19:35:06 +0530338 },
Anand Doshibd67e872014-04-11 16:51:27 +0530339
Anand Doshif3096132013-05-21 19:35:06 +0530340 calculate_totals: function() {
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530341 var me = this;
Anand Doshif3096132013-05-21 19:35:06 +0530342 var tax_count = this.frm.tax_doclist.length;
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530343
Anand Doshif3096132013-05-21 19:35:06 +0530344 this.frm.doc.grand_total = flt(
345 tax_count ? this.frm.tax_doclist[tax_count - 1].total : this.frm.doc.net_total,
346 precision("grand_total"));
347 this.frm.doc.grand_total_export = flt(this.frm.doc.grand_total / this.frm.doc.conversion_rate,
348 precision("grand_total_export"));
Anand Doshibd67e872014-04-11 16:51:27 +0530349
Anand Doshif3096132013-05-21 19:35:06 +0530350 this.frm.doc.other_charges_total = flt(this.frm.doc.grand_total - this.frm.doc.net_total,
351 precision("other_charges_total"));
Anand Doshibd67e872014-04-11 16:51:27 +0530352 this.frm.doc.other_charges_total_export = flt(this.frm.doc.grand_total_export -
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530353 this.frm.doc.net_total_export + flt(this.frm.doc.discount_amount),
Anand Doshif3096132013-05-21 19:35:06 +0530354 precision("other_charges_total_export"));
Anand Doshibd67e872014-04-11 16:51:27 +0530355
Anand Doshif3096132013-05-21 19:35:06 +0530356 this.frm.doc.rounded_total = Math.round(this.frm.doc.grand_total);
357 this.frm.doc.rounded_total_export = Math.round(this.frm.doc.grand_total_export);
358 },
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530359
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530360 apply_discount_amount: function() {
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530361 var me = this;
362 var distributed_amount = 0.0;
363
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530364 if (this.frm.doc.discount_amount) {
365 var grand_total_for_discount_amount = this.get_grand_total_for_discount_amount();
366 // calculate item amount after Discount Amount
367 if (grand_total_for_discount_amount) {
368 $.each(this.frm.item_doclist, function(i, item) {
Nabin Hait1eb56012014-02-10 19:20:15 +0530369 distributed_amount = flt(me.frm.doc.discount_amount) * item.base_amount / grand_total_for_discount_amount;
370 item.base_amount = flt(item.base_amount - distributed_amount, precision("base_amount", item));
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530371 });
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530372
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530373 this.discount_amount_applied = true;
374 this._calculate_taxes_and_totals();
375 }
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530376 }
377 },
378
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530379 get_grand_total_for_discount_amount: function() {
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530380 var me = this;
381 var total_actual_tax = 0.0;
382 var actual_taxes_dict = {};
383
384 $.each(this.frm.tax_doclist, function(i, tax) {
385 if (tax.charge_type == "Actual")
386 actual_taxes_dict[tax.idx] = tax.tax_amount;
387 else if (actual_taxes_dict[tax.row_id] !== null) {
388 actual_tax_amount = flt(actual_taxes_dict[tax.row_id]) * flt(tax.rate) / 100;
389 actual_taxes_dict[tax.idx] = actual_tax_amount;
390 }
391 });
392
393 $.each(actual_taxes_dict, function(key, value) {
394 if (value)
395 total_actual_tax += value;
396 });
397
Anand Doshibd67e872014-04-11 16:51:27 +0530398 grand_total_for_discount_amount = flt(this.frm.doc.grand_total - total_actual_tax,
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530399 precision("grand_total"));
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530400 return grand_total_for_discount_amount;
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530401 },
Anand Doshibd67e872014-04-11 16:51:27 +0530402
Anand Doshi652bc072014-04-16 15:21:46 +0530403 calculate_outstanding_amount: function(update_paid_amount) {
Anand Doshibd67e872014-04-11 16:51:27 +0530404 // NOTE:
Akhilesh Darjee38e8f982013-09-05 12:59:33 +0530405 // paid_amount and write_off_amount is only for POS Invoice
Anand Doshi923d41d2013-05-28 17:23:36 +0530406 // total_advance is only for non POS Invoice
Anand Doshi29ea5d02013-07-05 17:23:14 +0530407 if(this.frm.doc.doctype == "Sales Invoice" && this.frm.doc.docstatus==0) {
Nabin Hait54106802014-03-13 17:26:41 +0530408 frappe.model.round_floats_in(this.frm.doc, ["grand_total", "total_advance", "write_off_amount",
409 "paid_amount"]);
Anand Doshibd67e872014-04-11 16:51:27 +0530410 var total_amount_to_pay = this.frm.doc.grand_total - this.frm.doc.write_off_amount
Nabin Hait54106802014-03-13 17:26:41 +0530411 - this.frm.doc.total_advance;
Nabin Hait0c9d4222014-03-25 19:35:41 +0530412 if(this.frm.doc.is_pos) {
Anand Doshi652bc072014-04-16 15:21:46 +0530413 if(!this.frm.doc.paid_amount || update_paid_amount===undefined || update_paid_amount) {
414 this.frm.doc.paid_amount = flt(total_amount_to_pay);
415 }
Nabin Hait0c9d4222014-03-25 19:35:41 +0530416 } else {
417 this.frm.doc.paid_amount = 0
418 }
Nabin Hait482ffac2014-03-13 16:32:43 +0530419
Anand Doshibd67e872014-04-11 16:51:27 +0530420 this.frm.set_value("outstanding_amount", flt(total_amount_to_pay
Nabin Hait54106802014-03-13 17:26:41 +0530421 - this.frm.doc.paid_amount, precision("outstanding_amount")));
Anand Doshifc777182013-05-27 19:29:07 +0530422 }
423 },
Anand Doshibd67e872014-04-11 16:51:27 +0530424
Anand Doshif3096132013-05-21 19:35:06 +0530425 calculate_commission: function() {
Anand Doshi923d41d2013-05-28 17:23:36 +0530426 if(this.frm.fields_dict.commission_rate) {
427 if(this.frm.doc.commission_rate > 100) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530428 var msg = __(frappe.meta.get_label(this.frm.doc.doctype, "commission_rate", this.frm.doc.name)) +
429 " " + __("cannot be greater than 100");
Anand Doshi923d41d2013-05-28 17:23:36 +0530430 msgprint(msg);
431 throw msg;
432 }
Anand Doshibd67e872014-04-11 16:51:27 +0530433
Anand Doshi923d41d2013-05-28 17:23:36 +0530434 this.frm.doc.total_commission = flt(this.frm.doc.net_total * this.frm.doc.commission_rate / 100.0,
435 precision("total_commission"));
436 }
Anand Doshif3096132013-05-21 19:35:06 +0530437 },
Anand Doshibd67e872014-04-11 16:51:27 +0530438
Anand Doshif3096132013-05-21 19:35:06 +0530439 calculate_contribution: function() {
Anand Doshi2168e392013-05-23 19:25:08 +0530440 var me = this;
Rushabh Mehtaaa355af2014-03-26 18:24:30 +0530441 $.each(this.frm.doc.doctype.sales_team || [], function(i, sales_person) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530442 frappe.model.round_floats_in(sales_person);
Anand Doshif3096132013-05-21 19:35:06 +0530443 if(sales_person.allocated_percentage) {
444 sales_person.allocated_amount = flt(
445 me.frm.doc.net_total * sales_person.allocated_percentage / 100.0,
446 precision("allocated_amount", sales_person));
447 }
448 });
449 },
Anand Doshibd67e872014-04-11 16:51:27 +0530450
Anand Doshif3096132013-05-21 19:35:06 +0530451 _cleanup: function() {
Anand Doshi3543f302013-05-24 19:25:01 +0530452 this._super();
453 this.frm.doc.in_words = this.frm.doc.in_words_export = "";
Anand Doshif3096132013-05-21 19:35:06 +0530454 },
Anand Doshi2168e392013-05-23 19:25:08 +0530455
Anand Doshicefccb92013-07-15 18:28:14 +0530456 shipping_rule: function() {
457 var me = this;
458 if(this.frm.doc.shipping_rule) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530459 return this.frm.call({
Anand Doshicefccb92013-07-15 18:28:14 +0530460 doc: this.frm.doc,
461 method: "apply_shipping_rule",
462 callback: function(r) {
463 if(!r.exc) {
464 me.calculate_taxes_and_totals();
465 }
466 }
467 })
468 }
469 },
Anand Doshibd67e872014-04-11 16:51:27 +0530470
Anand Doshi2168e392013-05-23 19:25:08 +0530471 set_dynamic_labels: function() {
Anand Doshi61a2f682013-06-21 17:55:31 +0530472 this._super();
Nabin Hait0b157552014-06-24 17:02:45 +0530473 this.set_sales_bom_help(this.frm.doc);
474 },
475
476 set_sales_bom_help: function(doc) {
477 if(!cur_frm.fields_dict.packing_list) return;
478 if ((doc.packing_details || []).length) {
479 $(cur_frm.fields_dict.packing_list.row.wrapper).toggle(true);
480
481 if (inList(['Delivery Note', 'Sales Invoice'], doc.doctype)) {
482 help_msg = "<div class='alert alert-warning'>" +
Nabin Hait60c48fe2014-06-24 17:34:52 +0530483 __("For 'Sales BOM' items, Warehouse, Serial No and Batch No will be considered from the 'Packing List' table. If Warehouse and Batch No are same for all packing items for any 'Sales BOM' item, those values can be entered in the main Item table, values will be copied to 'Packing List' table.")+
Nabin Hait0b157552014-06-24 17:02:45 +0530484 "</div>";
485 frappe.meta.get_docfield(doc.doctype, 'sales_bom_help', doc.name).options = help_msg;
486 }
487 } else {
488 $(cur_frm.fields_dict.packing_list.row.wrapper).toggle(false);
489 if (inList(['Delivery Note', 'Sales Invoice'], doc.doctype)) {
490 frappe.meta.get_docfield(doc.doctype, 'sales_bom_help', doc.name).options = '';
491 }
492 }
493 refresh_field('sales_bom_help');
Anand Doshi2168e392013-05-23 19:25:08 +0530494 },
Anand Doshibd67e872014-04-11 16:51:27 +0530495
Anand Doshi2168e392013-05-23 19:25:08 +0530496 change_form_labels: function(company_currency) {
497 var me = this;
498 var field_label_map = {};
Anand Doshibd67e872014-04-11 16:51:27 +0530499
Anand Doshi2168e392013-05-23 19:25:08 +0530500 var setup_field_label_map = function(fields_list, currency) {
501 $.each(fields_list, function(i, fname) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530502 var docfield = frappe.meta.docfield_map[me.frm.doc.doctype][fname];
Anand Doshi2168e392013-05-23 19:25:08 +0530503 if(docfield) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530504 var label = __(docfield.label || "").replace(/\([^\)]*\)/g, "");
Anand Doshi2168e392013-05-23 19:25:08 +0530505 field_label_map[fname] = label.trim() + " (" + currency + ")";
506 }
507 });
508 };
Anand Doshibd67e872014-04-11 16:51:27 +0530509 setup_field_label_map(["net_total", "other_charges_total", "grand_total",
Anand Doshi2168e392013-05-23 19:25:08 +0530510 "rounded_total", "in_words",
511 "outstanding_amount", "total_advance", "paid_amount", "write_off_amount"],
512 company_currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530513
514 setup_field_label_map(["net_total_export", "other_charges_total_export", "grand_total_export",
Anand Doshi2168e392013-05-23 19:25:08 +0530515 "rounded_total_export", "in_words_export"], this.frm.doc.currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530516
517 cur_frm.set_df_property("conversion_rate", "description", "1 " + this.frm.doc.currency
Rushabh Mehtaef584552013-11-02 14:47:11 +0530518 + " = [?] " + company_currency)
Anand Doshibd67e872014-04-11 16:51:27 +0530519
Anand Doshi2168e392013-05-23 19:25:08 +0530520 if(this.frm.doc.price_list_currency && this.frm.doc.price_list_currency!=company_currency) {
Anand Doshibd67e872014-04-11 16:51:27 +0530521 cur_frm.set_df_property("plc_conversion_rate", "description", "1 " + this.frm.doc.price_list_currency
Rushabh Mehtaef584552013-11-02 14:47:11 +0530522 + " = [?] " + company_currency)
Anand Doshi2168e392013-05-23 19:25:08 +0530523 }
Anand Doshibd67e872014-04-11 16:51:27 +0530524
Anand Doshi2168e392013-05-23 19:25:08 +0530525 // toggle fields
Anand Doshibd67e872014-04-11 16:51:27 +0530526 this.frm.toggle_display(["conversion_rate", "net_total", "other_charges_total",
Anand Doshi2168e392013-05-23 19:25:08 +0530527 "grand_total", "rounded_total", "in_words"],
528 this.frm.doc.currency != company_currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530529
530 this.frm.toggle_display(["plc_conversion_rate", "price_list_currency"],
Anand Doshi2168e392013-05-23 19:25:08 +0530531 this.frm.doc.price_list_currency != company_currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530532
Anand Doshi2168e392013-05-23 19:25:08 +0530533 // set labels
534 $.each(field_label_map, function(fname, label) {
535 me.frm.fields_dict[fname].set_label(label);
536 });
537 },
Anand Doshibd67e872014-04-11 16:51:27 +0530538
Anand Doshi2168e392013-05-23 19:25:08 +0530539 change_grid_labels: function(company_currency) {
540 var me = this;
541 var field_label_map = {};
Anand Doshibd67e872014-04-11 16:51:27 +0530542
Anand Doshi2168e392013-05-23 19:25:08 +0530543 var setup_field_label_map = function(fields_list, currency, parentfield) {
544 var grid_doctype = me.frm.fields_dict[parentfield].grid.doctype;
545 $.each(fields_list, function(i, fname) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530546 var docfield = frappe.meta.docfield_map[grid_doctype][fname];
Anand Doshi2168e392013-05-23 19:25:08 +0530547 if(docfield) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530548 var label = __(docfield.label || "").replace(/\([^\)]*\)/g, "");
Anand Doshibd67e872014-04-11 16:51:27 +0530549 field_label_map[grid_doctype + "-" + fname] =
Anand Doshi2168e392013-05-23 19:25:08 +0530550 label.trim() + " (" + currency + ")";
551 }
552 });
553 }
Anand Doshibd67e872014-04-11 16:51:27 +0530554
Nabin Hait1eb56012014-02-10 19:20:15 +0530555 setup_field_label_map(["base_rate", "base_price_list_rate", "base_amount"],
Anand Doshi2168e392013-05-23 19:25:08 +0530556 company_currency, this.fname);
Anand Doshibd67e872014-04-11 16:51:27 +0530557
Nabin Hait1eb56012014-02-10 19:20:15 +0530558 setup_field_label_map(["rate", "price_list_rate", "amount"],
Anand Doshi2168e392013-05-23 19:25:08 +0530559 this.frm.doc.currency, this.fname);
Anand Doshibd67e872014-04-11 16:51:27 +0530560
Anand Doshi2168e392013-05-23 19:25:08 +0530561 setup_field_label_map(["tax_amount", "total"], company_currency, "other_charges");
Anand Doshibd67e872014-04-11 16:51:27 +0530562
Anand Doshi2168e392013-05-23 19:25:08 +0530563 if(this.frm.fields_dict["advance_allocation_details"]) {
564 setup_field_label_map(["advance_amount", "allocated_amount"], company_currency,
565 "advance_allocation_details");
566 }
Anand Doshibd67e872014-04-11 16:51:27 +0530567
Anand Doshi2168e392013-05-23 19:25:08 +0530568 // toggle columns
569 var item_grid = this.frm.fields_dict[this.fname].grid;
Anand Doshibd67e872014-04-11 16:51:27 +0530570 var show = (this.frm.doc.currency != company_currency) ||
571 ((cur_frm.doc.other_charges || []).filter(
Rushabh Mehtaaa355af2014-03-26 18:24:30 +0530572 function(d) { return d.included_in_print_rate===1}).length);
Anand Doshibd67e872014-04-11 16:51:27 +0530573
Nabin Hait1eb56012014-02-10 19:20:15 +0530574 $.each(["base_rate", "base_price_list_rate", "base_amount"], function(i, fname) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530575 if(frappe.meta.get_docfield(item_grid.doctype, fname))
Anand Doshi2168e392013-05-23 19:25:08 +0530576 item_grid.set_column_disp(fname, show);
577 });
Anand Doshibd67e872014-04-11 16:51:27 +0530578
Anand Doshi2168e392013-05-23 19:25:08 +0530579 // set labels
580 var $wrapper = $(this.frm.wrapper);
581 $.each(field_label_map, function(fname, label) {
Anand Doshi5013dcb2013-08-05 12:16:04 +0530582 fname = fname.split("-");
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530583 var df = frappe.meta.get_docfield(fname[0], fname[1], me.frm.doc.name);
Anand Doshi5013dcb2013-08-05 12:16:04 +0530584 if(df) df.label = label;
Anand Doshi2168e392013-05-23 19:25:08 +0530585 });
Nabin Haitcfc6bb12012-07-11 13:14:52 +0530586 }
Nabin Hait0b157552014-06-24 17:02:45 +0530587});
Anand Doshi43f087c2014-08-26 14:25:53 +0530588
589frappe.ui.form.on(cur_frm.doctype,"project_name", function(frm) {
590 frappe.call({
Anand Doshi43f087c2014-08-26 14:25:53 +0530591 method:'erpnext.projects.doctype.project.project.get_cost_center_name' ,
Neil Trini Lasradod6d71e82014-08-27 18:48:57 +0530592 args: { project_name: frm.doc.project_name },
Anand Doshi43f087c2014-08-26 14:25:53 +0530593 callback: function(r, rt) {
Neil Trini Lasradod6d71e82014-08-27 18:48:57 +0530594 if(!r.exc) {
595 $.each(frm.doc[cur_frm.cscript.fname] || [], function(i, row) {
Anand Doshi43f087c2014-08-26 14:25:53 +0530596 frappe.model.set_value(row.doctype, row.name, "cost_center", r.message);
Neil Trini Lasradod6d71e82014-08-27 18:48:57 +0530597 msgprint(__("Cost Center For Item with Item Code '"+row.item_name+"' has been Changed to "+ r.message));
Anand Doshi43f087c2014-08-26 14:25:53 +0530598 })
599 }
600 }
601 })
602})