blob: 3a01811ba85cdc07270d3fc150cc8c00dc9cd780 [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
Nabin Haitccd9fd32014-11-14 14:27:24 +0530344 this.frm.doc.grand_total = flt(tax_count ? this.frm.tax_doclist[tax_count - 1].total : this.frm.doc.net_total);
Nabin Hait2244ac42015-01-12 17:35:14 +0530345 this.frm.doc.grand_total_export = flt(this.frm.doc.grand_total / this.frm.doc.conversion_rate);
Anand Doshibd67e872014-04-11 16:51:27 +0530346
Anand Doshif3096132013-05-21 19:35:06 +0530347 this.frm.doc.other_charges_total = flt(this.frm.doc.grand_total - this.frm.doc.net_total,
348 precision("other_charges_total"));
Anand Doshibd67e872014-04-11 16:51:27 +0530349 this.frm.doc.other_charges_total_export = flt(this.frm.doc.grand_total_export -
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530350 this.frm.doc.net_total_export + flt(this.frm.doc.discount_amount),
Anand Doshif3096132013-05-21 19:35:06 +0530351 precision("other_charges_total_export"));
Anand Doshibd67e872014-04-11 16:51:27 +0530352
Nabin Haitccd9fd32014-11-14 14:27:24 +0530353 this.frm.doc.grand_total = flt(this.frm.doc.grand_total, precision("grand_total"));
354 this.frm.doc.grand_total_export = flt(this.frm.doc.grand_total_export, precision("grand_total_export"));
355
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) {
Nabin Hait2244ac42015-01-12 17:35:14 +0530365 this.frm.set_value("base_discount_amount",
366 flt(this.frm.doc.discount_amount * this.frm.doc.conversion_rate, precision("base_discount_amount")))
367
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530368 var grand_total_for_discount_amount = this.get_grand_total_for_discount_amount();
369 // calculate item amount after Discount Amount
370 if (grand_total_for_discount_amount) {
371 $.each(this.frm.item_doclist, function(i, item) {
Nabin Hait2244ac42015-01-12 17:35:14 +0530372 distributed_amount = flt(me.frm.doc.base_discount_amount) * item.base_amount / grand_total_for_discount_amount;
Nabin Hait1eb56012014-02-10 19:20:15 +0530373 item.base_amount = flt(item.base_amount - distributed_amount, precision("base_amount", item));
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530374 });
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530375
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530376 this.discount_amount_applied = true;
377 this._calculate_taxes_and_totals();
378 }
Nabin Hait2244ac42015-01-12 17:35:14 +0530379 } else {
380 this.frm.set_value("base_discount_amount", 0);
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530381 }
382 },
383
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530384 get_grand_total_for_discount_amount: function() {
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530385 var me = this;
386 var total_actual_tax = 0.0;
387 var actual_taxes_dict = {};
388
389 $.each(this.frm.tax_doclist, function(i, tax) {
390 if (tax.charge_type == "Actual")
391 actual_taxes_dict[tax.idx] = tax.tax_amount;
392 else if (actual_taxes_dict[tax.row_id] !== null) {
393 actual_tax_amount = flt(actual_taxes_dict[tax.row_id]) * flt(tax.rate) / 100;
394 actual_taxes_dict[tax.idx] = actual_tax_amount;
395 }
396 });
397
398 $.each(actual_taxes_dict, function(key, value) {
399 if (value)
400 total_actual_tax += value;
401 });
402
Anand Doshibd67e872014-04-11 16:51:27 +0530403 grand_total_for_discount_amount = flt(this.frm.doc.grand_total - total_actual_tax,
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530404 precision("grand_total"));
Akhilesh Darjee57738a02014-01-03 18:15:07 +0530405 return grand_total_for_discount_amount;
Akhilesh Darjeed203aea2013-12-27 17:49:57 +0530406 },
Anand Doshibd67e872014-04-11 16:51:27 +0530407
Anand Doshi652bc072014-04-16 15:21:46 +0530408 calculate_outstanding_amount: function(update_paid_amount) {
Anand Doshibd67e872014-04-11 16:51:27 +0530409 // NOTE:
Akhilesh Darjee38e8f982013-09-05 12:59:33 +0530410 // paid_amount and write_off_amount is only for POS Invoice
Anand Doshi923d41d2013-05-28 17:23:36 +0530411 // total_advance is only for non POS Invoice
Anand Doshi29ea5d02013-07-05 17:23:14 +0530412 if(this.frm.doc.doctype == "Sales Invoice" && this.frm.doc.docstatus==0) {
Nabin Hait54106802014-03-13 17:26:41 +0530413 frappe.model.round_floats_in(this.frm.doc, ["grand_total", "total_advance", "write_off_amount",
414 "paid_amount"]);
Anand Doshibd67e872014-04-11 16:51:27 +0530415 var total_amount_to_pay = this.frm.doc.grand_total - this.frm.doc.write_off_amount
Nabin Hait54106802014-03-13 17:26:41 +0530416 - this.frm.doc.total_advance;
Nabin Hait0c9d4222014-03-25 19:35:41 +0530417 if(this.frm.doc.is_pos) {
Anand Doshi652bc072014-04-16 15:21:46 +0530418 if(!this.frm.doc.paid_amount || update_paid_amount===undefined || update_paid_amount) {
419 this.frm.doc.paid_amount = flt(total_amount_to_pay);
420 }
Nabin Hait0c9d4222014-03-25 19:35:41 +0530421 } else {
422 this.frm.doc.paid_amount = 0
423 }
Nabin Hait482ffac2014-03-13 16:32:43 +0530424
Anand Doshibd67e872014-04-11 16:51:27 +0530425 this.frm.set_value("outstanding_amount", flt(total_amount_to_pay
Nabin Hait54106802014-03-13 17:26:41 +0530426 - this.frm.doc.paid_amount, precision("outstanding_amount")));
Anand Doshifc777182013-05-27 19:29:07 +0530427 }
428 },
Anand Doshibd67e872014-04-11 16:51:27 +0530429
Anand Doshif3096132013-05-21 19:35:06 +0530430 calculate_commission: function() {
Anand Doshi923d41d2013-05-28 17:23:36 +0530431 if(this.frm.fields_dict.commission_rate) {
432 if(this.frm.doc.commission_rate > 100) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530433 var msg = __(frappe.meta.get_label(this.frm.doc.doctype, "commission_rate", this.frm.doc.name)) +
434 " " + __("cannot be greater than 100");
Anand Doshi923d41d2013-05-28 17:23:36 +0530435 msgprint(msg);
436 throw msg;
437 }
Anand Doshibd67e872014-04-11 16:51:27 +0530438
Anand Doshi923d41d2013-05-28 17:23:36 +0530439 this.frm.doc.total_commission = flt(this.frm.doc.net_total * this.frm.doc.commission_rate / 100.0,
440 precision("total_commission"));
441 }
Anand Doshif3096132013-05-21 19:35:06 +0530442 },
Anand Doshibd67e872014-04-11 16:51:27 +0530443
Anand Doshif3096132013-05-21 19:35:06 +0530444 calculate_contribution: function() {
Anand Doshi2168e392013-05-23 19:25:08 +0530445 var me = this;
Rushabh Mehtaaa355af2014-03-26 18:24:30 +0530446 $.each(this.frm.doc.doctype.sales_team || [], function(i, sales_person) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530447 frappe.model.round_floats_in(sales_person);
Anand Doshif3096132013-05-21 19:35:06 +0530448 if(sales_person.allocated_percentage) {
449 sales_person.allocated_amount = flt(
450 me.frm.doc.net_total * sales_person.allocated_percentage / 100.0,
451 precision("allocated_amount", sales_person));
452 }
453 });
454 },
Anand Doshibd67e872014-04-11 16:51:27 +0530455
Anand Doshif3096132013-05-21 19:35:06 +0530456 _cleanup: function() {
Anand Doshi3543f302013-05-24 19:25:01 +0530457 this._super();
458 this.frm.doc.in_words = this.frm.doc.in_words_export = "";
Anand Doshif3096132013-05-21 19:35:06 +0530459 },
Anand Doshi2168e392013-05-23 19:25:08 +0530460
Anand Doshicefccb92013-07-15 18:28:14 +0530461 shipping_rule: function() {
462 var me = this;
463 if(this.frm.doc.shipping_rule) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530464 return this.frm.call({
Anand Doshicefccb92013-07-15 18:28:14 +0530465 doc: this.frm.doc,
466 method: "apply_shipping_rule",
467 callback: function(r) {
468 if(!r.exc) {
469 me.calculate_taxes_and_totals();
470 }
471 }
472 })
473 }
474 },
Anand Doshibd67e872014-04-11 16:51:27 +0530475
Anand Doshi2168e392013-05-23 19:25:08 +0530476 set_dynamic_labels: function() {
Anand Doshi61a2f682013-06-21 17:55:31 +0530477 this._super();
Nabin Hait0b157552014-06-24 17:02:45 +0530478 this.set_sales_bom_help(this.frm.doc);
479 },
480
481 set_sales_bom_help: function(doc) {
482 if(!cur_frm.fields_dict.packing_list) return;
483 if ((doc.packing_details || []).length) {
484 $(cur_frm.fields_dict.packing_list.row.wrapper).toggle(true);
485
486 if (inList(['Delivery Note', 'Sales Invoice'], doc.doctype)) {
487 help_msg = "<div class='alert alert-warning'>" +
Nabin Hait60c48fe2014-06-24 17:34:52 +0530488 __("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 +0530489 "</div>";
490 frappe.meta.get_docfield(doc.doctype, 'sales_bom_help', doc.name).options = help_msg;
491 }
492 } else {
493 $(cur_frm.fields_dict.packing_list.row.wrapper).toggle(false);
494 if (inList(['Delivery Note', 'Sales Invoice'], doc.doctype)) {
495 frappe.meta.get_docfield(doc.doctype, 'sales_bom_help', doc.name).options = '';
496 }
497 }
498 refresh_field('sales_bom_help');
Anand Doshi2168e392013-05-23 19:25:08 +0530499 },
Anand Doshibd67e872014-04-11 16:51:27 +0530500
Anand Doshi2168e392013-05-23 19:25:08 +0530501 change_form_labels: function(company_currency) {
502 var me = this;
503 var field_label_map = {};
Anand Doshibd67e872014-04-11 16:51:27 +0530504
Anand Doshi2168e392013-05-23 19:25:08 +0530505 var setup_field_label_map = function(fields_list, currency) {
506 $.each(fields_list, function(i, fname) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530507 var docfield = frappe.meta.docfield_map[me.frm.doc.doctype][fname];
Anand Doshi2168e392013-05-23 19:25:08 +0530508 if(docfield) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530509 var label = __(docfield.label || "").replace(/\([^\)]*\)/g, "");
Anand Doshi2168e392013-05-23 19:25:08 +0530510 field_label_map[fname] = label.trim() + " (" + currency + ")";
511 }
512 });
513 };
Nabin Hait2244ac42015-01-12 17:35:14 +0530514 setup_field_label_map(["net_total", "other_charges_total", "base_discount_amount", "grand_total",
Anand Doshi2168e392013-05-23 19:25:08 +0530515 "rounded_total", "in_words",
516 "outstanding_amount", "total_advance", "paid_amount", "write_off_amount"],
517 company_currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530518
Nabin Hait2244ac42015-01-12 17:35:14 +0530519 setup_field_label_map(["net_total_export", "other_charges_total_export", "discount_amount", "grand_total_export",
Anand Doshi2168e392013-05-23 19:25:08 +0530520 "rounded_total_export", "in_words_export"], this.frm.doc.currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530521
522 cur_frm.set_df_property("conversion_rate", "description", "1 " + this.frm.doc.currency
Rushabh Mehtaef584552013-11-02 14:47:11 +0530523 + " = [?] " + company_currency)
Anand Doshibd67e872014-04-11 16:51:27 +0530524
Anand Doshi2168e392013-05-23 19:25:08 +0530525 if(this.frm.doc.price_list_currency && this.frm.doc.price_list_currency!=company_currency) {
Anand Doshibd67e872014-04-11 16:51:27 +0530526 cur_frm.set_df_property("plc_conversion_rate", "description", "1 " + this.frm.doc.price_list_currency
Rushabh Mehtaef584552013-11-02 14:47:11 +0530527 + " = [?] " + company_currency)
Anand Doshi2168e392013-05-23 19:25:08 +0530528 }
Anand Doshibd67e872014-04-11 16:51:27 +0530529
Anand Doshi2168e392013-05-23 19:25:08 +0530530 // toggle fields
Anand Doshibd67e872014-04-11 16:51:27 +0530531 this.frm.toggle_display(["conversion_rate", "net_total", "other_charges_total",
Nabin Hait2244ac42015-01-12 17:35:14 +0530532 "grand_total", "rounded_total", "in_words", "base_discount_amount"],
Anand Doshi2168e392013-05-23 19:25:08 +0530533 this.frm.doc.currency != company_currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530534
535 this.frm.toggle_display(["plc_conversion_rate", "price_list_currency"],
Anand Doshi2168e392013-05-23 19:25:08 +0530536 this.frm.doc.price_list_currency != company_currency);
Anand Doshibd67e872014-04-11 16:51:27 +0530537
Anand Doshi2168e392013-05-23 19:25:08 +0530538 // set labels
539 $.each(field_label_map, function(fname, label) {
540 me.frm.fields_dict[fname].set_label(label);
541 });
542 },
Anand Doshibd67e872014-04-11 16:51:27 +0530543
Anand Doshi2168e392013-05-23 19:25:08 +0530544 change_grid_labels: function(company_currency) {
545 var me = this;
546 var field_label_map = {};
Anand Doshibd67e872014-04-11 16:51:27 +0530547
Anand Doshi2168e392013-05-23 19:25:08 +0530548 var setup_field_label_map = function(fields_list, currency, parentfield) {
549 var grid_doctype = me.frm.fields_dict[parentfield].grid.doctype;
550 $.each(fields_list, function(i, fname) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530551 var docfield = frappe.meta.docfield_map[grid_doctype][fname];
Anand Doshi2168e392013-05-23 19:25:08 +0530552 if(docfield) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530553 var label = __(docfield.label || "").replace(/\([^\)]*\)/g, "");
Anand Doshibd67e872014-04-11 16:51:27 +0530554 field_label_map[grid_doctype + "-" + fname] =
Anand Doshi2168e392013-05-23 19:25:08 +0530555 label.trim() + " (" + currency + ")";
556 }
557 });
558 }
Anand Doshibd67e872014-04-11 16:51:27 +0530559
Nabin Hait1eb56012014-02-10 19:20:15 +0530560 setup_field_label_map(["base_rate", "base_price_list_rate", "base_amount"],
Anand Doshi2168e392013-05-23 19:25:08 +0530561 company_currency, this.fname);
Anand Doshibd67e872014-04-11 16:51:27 +0530562
Nabin Hait1eb56012014-02-10 19:20:15 +0530563 setup_field_label_map(["rate", "price_list_rate", "amount"],
Anand Doshi2168e392013-05-23 19:25:08 +0530564 this.frm.doc.currency, this.fname);
Anand Doshibd67e872014-04-11 16:51:27 +0530565
Anand Doshi2168e392013-05-23 19:25:08 +0530566 setup_field_label_map(["tax_amount", "total"], company_currency, "other_charges");
Anand Doshibd67e872014-04-11 16:51:27 +0530567
Anand Doshi2168e392013-05-23 19:25:08 +0530568 if(this.frm.fields_dict["advance_allocation_details"]) {
569 setup_field_label_map(["advance_amount", "allocated_amount"], company_currency,
570 "advance_allocation_details");
571 }
Anand Doshibd67e872014-04-11 16:51:27 +0530572
Anand Doshi2168e392013-05-23 19:25:08 +0530573 // toggle columns
574 var item_grid = this.frm.fields_dict[this.fname].grid;
Anand Doshibd67e872014-04-11 16:51:27 +0530575 var show = (this.frm.doc.currency != company_currency) ||
576 ((cur_frm.doc.other_charges || []).filter(
Rushabh Mehtaaa355af2014-03-26 18:24:30 +0530577 function(d) { return d.included_in_print_rate===1}).length);
Anand Doshibd67e872014-04-11 16:51:27 +0530578
Nabin Hait1eb56012014-02-10 19:20:15 +0530579 $.each(["base_rate", "base_price_list_rate", "base_amount"], function(i, fname) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530580 if(frappe.meta.get_docfield(item_grid.doctype, fname))
Anand Doshi2168e392013-05-23 19:25:08 +0530581 item_grid.set_column_disp(fname, show);
582 });
Anand Doshibd67e872014-04-11 16:51:27 +0530583
Anand Doshi2168e392013-05-23 19:25:08 +0530584 // set labels
585 var $wrapper = $(this.frm.wrapper);
586 $.each(field_label_map, function(fname, label) {
Anand Doshi5013dcb2013-08-05 12:16:04 +0530587 fname = fname.split("-");
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530588 var df = frappe.meta.get_docfield(fname[0], fname[1], me.frm.doc.name);
Anand Doshi5013dcb2013-08-05 12:16:04 +0530589 if(df) df.label = label;
Anand Doshi2168e392013-05-23 19:25:08 +0530590 });
Nabin Haitcfc6bb12012-07-11 13:14:52 +0530591 }
Nabin Hait0b157552014-06-24 17:02:45 +0530592});
Anand Doshi43f087c2014-08-26 14:25:53 +0530593
594frappe.ui.form.on(cur_frm.doctype,"project_name", function(frm) {
Nabin Hait10b155a2014-10-23 13:18:59 +0530595 if(in_list(["Delivery Note", "Sales Invoice"], frm.doc.doctype)) {
596 frappe.call({
597 method:'erpnext.projects.doctype.project.project.get_cost_center_name' ,
598 args: { project_name: frm.doc.project_name },
599 callback: function(r, rt) {
600 if(!r.exc) {
601 $.each(frm.doc[cur_frm.cscript.fname] || [], function(i, row) {
602 frappe.model.set_value(row.doctype, row.name, "cost_center", r.message);
603 msgprint(__("Cost Center For Item with Item Code '"+row.item_name+"' has been Changed to "+ r.message));
604 })
605 }
Anand Doshi43f087c2014-08-26 14:25:53 +0530606 }
Nabin Hait10b155a2014-10-23 13:18:59 +0530607 })
608 }
Anand Doshi43f087c2014-08-26 14:25:53 +0530609})