blob: a29111f42a672407e23b0e949e71fbcef9b94bca [file] [log] [blame]
Anand Doshi885e0742015-03-03 14:55:30 +05301// Copyright (c) 2015, Frappe 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
Nabin Hait613d0812015-02-23 11:58:15 +05305cur_frm.cscript.tax_table = "Sales Taxes and Charges";
Rushabh Mehta009378e2015-05-06 22:59:00 +05306{% include 'accounts/doctype/sales_taxes_and_charges_template/sales_taxes_and_charges_template.js' %}
Nabin Hait613d0812015-02-23 11:58:15 +05307
Rushabh Mehta793ba6b2014-02-14 15:47:51 +05308frappe.provide("erpnext.selling");
Nabin Haitb4a3dfa2015-01-22 17:13:13 +05309frappe.require("assets/erpnext/js/controllers/transaction.js");
Rushabh Mehtab09d9da2014-01-02 11:47:23 +053010
Rushabh Mehtae10cf022014-09-12 13:09:41 +053011cur_frm.email_field = "contact_email";
12
Anand Doshi3543f302013-05-24 19:25:01 +053013erpnext.selling.SellingController = erpnext.TransactionController.extend({
Anand Doshi9b496142013-07-11 19:13:58 +053014 onload: function() {
15 this._super();
Anand Doshi9b496142013-07-11 19:13:58 +053016 this.setup_queries();
17 },
Anand Doshibd67e872014-04-11 16:51:27 +053018
Anand Doshi9b496142013-07-11 19:13:58 +053019 setup_queries: function() {
Anand Doshi99100a42013-07-04 17:13:53 +053020 var me = this;
Anand Doshibd67e872014-04-11 16:51:27 +053021
Anand Doshif3096132013-05-21 19:35:06 +053022 this.frm.add_fetch("sales_partner", "commission_rate", "commission_rate");
Anand Doshibd67e872014-04-11 16:51:27 +053023
24 $.each([["customer_address", "customer_filter"],
Anand Doshid5d39ac2013-07-29 13:28:37 +053025 ["shipping_address_name", "customer_filter"],
Anand Doshibd67e872014-04-11 16:51:27 +053026 ["contact_person", "customer_filter"],
27 ["customer", "customer"],
28 ["lead", "lead"]],
Anand Doshid5d39ac2013-07-29 13:28:37 +053029 function(i, opts) {
Anand Doshibd67e872014-04-11 16:51:27 +053030 if(me.frm.fields_dict[opts[0]])
Anand Doshid5d39ac2013-07-29 13:28:37 +053031 me.frm.set_query(opts[0], erpnext.queries[opts[1]]);
32 });
Anand Doshibd67e872014-04-11 16:51:27 +053033
Akhilesh Darjee4f721562014-01-29 16:31:38 +053034 if(this.frm.fields_dict.taxes_and_charges) {
35 this.frm.set_query("taxes_and_charges", function() {
Saurabhf52dc072013-07-10 13:07:49 +053036 return {
37 filters: [
Rushabh Mehtaab1ed012015-05-08 11:08:48 +053038 ['Sales Taxes and Charges Template', 'company', '=', me.frm.doc.company],
39 ['Sales Taxes and Charges Template', 'docstatus', '!=', 2]
Saurabhf52dc072013-07-10 13:07:49 +053040 ]
41 }
Anand Doshi99100a42013-07-04 17:13:53 +053042 });
43 }
Anand Doshi99100a42013-07-04 17:13:53 +053044
Rushabh Mehta4a404e92013-08-09 18:11:35 +053045 if(this.frm.fields_dict.selling_price_list) {
46 this.frm.set_query("selling_price_list", function() {
Nabin Haitdc15b4f2014-01-20 16:48:49 +053047 return { filters: { selling: 1 } };
Anand Doshi720a01a2013-07-26 11:32:02 +053048 });
Anand Doshi720a01a2013-07-26 11:32:02 +053049 }
Anand Doshibd67e872014-04-11 16:51:27 +053050
Nabin Haitdd38a262014-12-26 13:15:21 +053051 if(!this.frm.fields_dict["items"]) {
Anand Doshi99100a42013-07-04 17:13:53 +053052 return;
53 }
Anand Doshibd67e872014-04-11 16:51:27 +053054
Nabin Haitdd38a262014-12-26 13:15:21 +053055 if(this.frm.fields_dict["items"].grid.get_field('item_code')) {
56 this.frm.set_query("item_code", "items", function() {
Anand Doshi9b496142013-07-11 19:13:58 +053057 return {
Rushabh Mehta6de403f2013-12-13 14:10:14 +053058 query: "erpnext.controllers.queries.item_query",
Anand Doshi01de9452016-01-26 16:22:50 +053059 filters: {'is_sales_item': 1}
Anand Doshi9b496142013-07-11 19:13:58 +053060 }
Anand Doshi99100a42013-07-04 17:13:53 +053061 });
62 }
Anand Doshibd67e872014-04-11 16:51:27 +053063
Nabin Haitdd38a262014-12-26 13:15:21 +053064 if(this.frm.fields_dict["items"].grid.get_field('batch_no')) {
65 this.frm.set_query("batch_no", "items", function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +053066 var item = frappe.get_doc(cdt, cdn);
Anand Doshi99100a42013-07-04 17:13:53 +053067 if(!item.item_code) {
Pratik Vyasb52618c2014-04-14 16:25:30 +053068 frappe.throw(__("Please enter Item Code to get batch no"));
Anand Doshi99100a42013-07-04 17:13:53 +053069 } else {
Nabin Haitd1fd1e22013-10-18 12:29:11 +053070 filters = {
71 'item_code': item.item_code,
Neil Trini Lasradoebb60f52015-07-08 14:36:09 +053072 'posting_date': me.frm.doc.posting_date || nowdate(),
Nabin Haitd1fd1e22013-10-18 12:29:11 +053073 }
74 if(item.warehouse) filters["warehouse"] = item.warehouse
Anand Doshibd67e872014-04-11 16:51:27 +053075
Nabin Haitd1fd1e22013-10-18 12:29:11 +053076 return {
Akhilesh Darjee4f721562014-01-29 16:31:38 +053077 query : "erpnext.controllers.queries.get_batch_no",
Nabin Haitd1fd1e22013-10-18 12:29:11 +053078 filters: filters
Anand Doshi99100a42013-07-04 17:13:53 +053079 }
80 }
81 });
82 }
Anand Doshi1dde46a2013-05-15 21:15:57 +053083 },
Anand Doshibd67e872014-04-11 16:51:27 +053084
Anand Doshic4a54fe2013-08-01 18:19:51 +053085 refresh: function() {
86 this._super();
Anand Doshibd67e872014-04-11 16:51:27 +053087 this.frm.toggle_display("customer_name",
Akhilesh Darjee5ce1b8b2013-12-09 16:29:04 +053088 (this.frm.doc.customer_name && this.frm.doc.customer_name!==this.frm.doc.customer));
Nabin Haite7d15362014-12-25 16:01:55 +053089 if(this.frm.fields_dict.packed_items) {
90 var packing_list_exists = (this.frm.doc.packed_items || []).length;
Anand Doshic4a54fe2013-08-01 18:19:51 +053091 this.frm.toggle_display("packing_list", packing_list_exists ? true : false);
92 }
Nabin Hait2029ea92015-04-16 17:55:35 +053093 this.toggle_editable_price_list_rate();
Rushabh Mehta8aded132013-07-04 12:50:52 +053094 },
Anand Doshibd67e872014-04-11 16:51:27 +053095
Anand Doshi3543f302013-05-24 19:25:01 +053096 customer: function() {
Nabin Haita3dd72a2014-05-28 12:49:20 +053097 var me = this;
98 erpnext.utils.get_party_details(this.frm, null, null, function(){me.apply_pricing_rule()});
Anand Doshi3543f302013-05-24 19:25:01 +053099 },
Anand Doshibd67e872014-04-11 16:51:27 +0530100
Nabin Haita279d782013-07-15 13:04:33 +0530101 customer_address: function() {
Rushabh Mehtab09d9da2014-01-02 11:47:23 +0530102 erpnext.utils.get_address_display(this.frm, "customer_address");
Nabin Haita279d782013-07-15 13:04:33 +0530103 },
Anand Doshibd67e872014-04-11 16:51:27 +0530104
Nabin Hait9d1f0772014-02-19 17:43:24 +0530105 shipping_address_name: function() {
106 erpnext.utils.get_address_display(this.frm, "shipping_address_name", "shipping_address");
107 },
Anand Doshibd67e872014-04-11 16:51:27 +0530108
Nabin Haita3dd72a2014-05-28 12:49:20 +0530109 sales_partner: function() {
110 this.apply_pricing_rule();
111 },
112
113 campaign: function() {
114 this.apply_pricing_rule();
115 },
116
Rushabh Mehta4a404e92013-08-09 18:11:35 +0530117 selling_price_list: function() {
Anand Doshidffec8f2014-07-01 17:45:15 +0530118 this.apply_price_list();
Anand Doshif3096132013-05-21 19:35:06 +0530119 },
Anand Doshibd67e872014-04-11 16:51:27 +0530120
Nabin Haita7f757a2014-02-10 17:54:04 +0530121 price_list_rate: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530122 var item = frappe.get_doc(cdt, cdn);
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530123 frappe.model.round_floats_in(item, ["price_list_rate", "discount_percentage"]);
Anand Doshibd67e872014-04-11 16:51:27 +0530124
Nabin Hait7979f7e2014-02-10 18:26:49 +0530125 item.rate = flt(item.price_list_rate * (1 - item.discount_percentage / 100.0),
126 precision("rate", item));
Saurabhd3135532016-02-25 18:59:20 +0530127
128 this.gross_profit(item);
Anand Doshif3096132013-05-21 19:35:06 +0530129 this.calculate_taxes_and_totals();
130 },
Anand Doshibd67e872014-04-11 16:51:27 +0530131
Nabin Haita7f757a2014-02-10 17:54:04 +0530132 discount_percentage: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530133 var item = frappe.get_doc(cdt, cdn);
Nabin Haita7f757a2014-02-10 17:54:04 +0530134 if(!item.price_list_rate) {
135 item.discount_percentage = 0.0;
Anand Doshi923d41d2013-05-28 17:23:36 +0530136 } else {
Nabin Haita7f757a2014-02-10 17:54:04 +0530137 this.price_list_rate(doc, cdt, cdn);
Anand Doshi923d41d2013-05-28 17:23:36 +0530138 }
Saurabhd3135532016-02-25 18:59:20 +0530139 this.gross_profit(item);
Anand Doshif3096132013-05-21 19:35:06 +0530140 },
Anand Doshibd67e872014-04-11 16:51:27 +0530141
Anand Doshif3096132013-05-21 19:35:06 +0530142 commission_rate: function() {
143 this.calculate_commission();
144 refresh_field("total_commission");
145 },
Anand Doshibd67e872014-04-11 16:51:27 +0530146
Anand Doshif3096132013-05-21 19:35:06 +0530147 total_commission: function() {
Nabin Hait5690be12015-02-12 16:09:11 +0530148 if(this.frm.doc.base_net_total) {
149 frappe.model.round_floats_in(this.frm.doc, ["base_net_total", "total_commission"]);
Anand Doshibd67e872014-04-11 16:51:27 +0530150
Nabin Hait5690be12015-02-12 16:09:11 +0530151 if(this.frm.doc.base_net_total < this.frm.doc.total_commission) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530152 var msg = (__("[Error]") + " " +
153 __(frappe.meta.get_label(this.frm.doc.doctype, "total_commission",
Anand Doshibd67e872014-04-11 16:51:27 +0530154 this.frm.doc.name)) + " > " +
Nabin Hait5690be12015-02-12 16:09:11 +0530155 __(frappe.meta.get_label(this.frm.doc.doctype, "base_net_total", this.frm.doc.name)));
Anand Doshif3096132013-05-21 19:35:06 +0530156 msgprint(msg);
157 throw msg;
158 }
Anand Doshibd67e872014-04-11 16:51:27 +0530159
160 this.frm.set_value("commission_rate",
Nabin Hait5690be12015-02-12 16:09:11 +0530161 flt(this.frm.doc.total_commission * 100.0 / this.frm.doc.base_net_total));
Anand Doshif3096132013-05-21 19:35:06 +0530162 }
163 },
Anand Doshibd67e872014-04-11 16:51:27 +0530164
Anand Doshif3096132013-05-21 19:35:06 +0530165 allocated_percentage: function(doc, cdt, cdn) {
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530166 var sales_person = frappe.get_doc(cdt, cdn);
Anand Doshibd67e872014-04-11 16:51:27 +0530167
Anand Doshif3096132013-05-21 19:35:06 +0530168 if(sales_person.allocated_percentage) {
169 sales_person.allocated_percentage = flt(sales_person.allocated_percentage,
170 precision("allocated_percentage", sales_person));
Nabin Hait5690be12015-02-12 16:09:11 +0530171 sales_person.allocated_amount = flt(this.frm.doc.base_net_total *
Anand Doshibd67e872014-04-11 16:51:27 +0530172 sales_person.allocated_percentage / 100.0,
Anand Doshif3096132013-05-21 19:35:06 +0530173 precision("allocated_amount", sales_person));
174
175 refresh_field(["allocated_percentage", "allocated_amount"], sales_person.name,
176 sales_person.parentfield);
177 }
178 },
Anand Doshibd67e872014-04-11 16:51:27 +0530179
Anand Doshifc777182013-05-27 19:29:07 +0530180 warehouse: function(doc, cdt, cdn) {
Sambhaji Kolate98dbccd2015-03-10 15:04:28 +0530181 var me = this;
Rushabh Mehta66d52b52014-03-27 14:17:33 +0530182 var item = frappe.get_doc(cdt, cdn);
Saurabhd3135532016-02-25 18:59:20 +0530183
Anand Doshi1dc95ed2013-07-23 13:36:38 +0530184 if(item.item_code && item.warehouse) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530185 return this.frm.call({
Saurabhd3135532016-02-25 18:59:20 +0530186 method: "erpnext.stock.get_item_details.get_bin_details",
Anand Doshifc777182013-05-27 19:29:07 +0530187 child: item,
188 args: {
189 item_code: item.item_code,
Anand Doshi1dc95ed2013-07-23 13:36:38 +0530190 warehouse: item.warehouse,
Anand Doshifc777182013-05-27 19:29:07 +0530191 },
Saurabhd3135532016-02-25 18:59:20 +0530192 callback:function(r){
193 if (inList(['Delivery Note', 'Sales Invoice'], doc.doctype)) {
194 me.batch_no(doc, cdt, cdn);
195 }
196 }
Anand Doshifc777182013-05-27 19:29:07 +0530197 });
198 }
199 },
Anand Doshibd67e872014-04-11 16:51:27 +0530200
Anand Doshi33fe8672013-08-02 12:39:10 +0530201 toggle_editable_price_list_rate: function() {
Nabin Haitdd38a262014-12-26 13:15:21 +0530202 var df = frappe.meta.get_docfield(this.frm.doc.doctype + " Item", "price_list_rate", this.frm.doc.name);
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530203 var editable_price_list_rate = cint(frappe.defaults.get_default("editable_price_list_rate"));
Anand Doshibd67e872014-04-11 16:51:27 +0530204
Anand Doshi33fe8672013-08-02 12:39:10 +0530205 if(df && editable_price_list_rate) {
206 df.read_only = 0;
207 }
208 },
Anand Doshibd67e872014-04-11 16:51:27 +0530209
Anand Doshif3096132013-05-21 19:35:06 +0530210 calculate_commission: function() {
Anand Doshi923d41d2013-05-28 17:23:36 +0530211 if(this.frm.fields_dict.commission_rate) {
212 if(this.frm.doc.commission_rate > 100) {
Pratik Vyasb52618c2014-04-14 16:25:30 +0530213 var msg = __(frappe.meta.get_label(this.frm.doc.doctype, "commission_rate", this.frm.doc.name)) +
214 " " + __("cannot be greater than 100");
Anand Doshi923d41d2013-05-28 17:23:36 +0530215 msgprint(msg);
216 throw msg;
217 }
Anand Doshibd67e872014-04-11 16:51:27 +0530218
Nabin Hait5690be12015-02-12 16:09:11 +0530219 this.frm.doc.total_commission = flt(this.frm.doc.base_net_total * this.frm.doc.commission_rate / 100.0,
Anand Doshi923d41d2013-05-28 17:23:36 +0530220 precision("total_commission"));
221 }
Anand Doshif3096132013-05-21 19:35:06 +0530222 },
Anand Doshibd67e872014-04-11 16:51:27 +0530223
Anand Doshif3096132013-05-21 19:35:06 +0530224 calculate_contribution: function() {
Anand Doshi2168e392013-05-23 19:25:08 +0530225 var me = this;
Rushabh Mehtaaa355af2014-03-26 18:24:30 +0530226 $.each(this.frm.doc.doctype.sales_team || [], function(i, sales_person) {
Rushabh Mehta793ba6b2014-02-14 15:47:51 +0530227 frappe.model.round_floats_in(sales_person);
Anand Doshif3096132013-05-21 19:35:06 +0530228 if(sales_person.allocated_percentage) {
229 sales_person.allocated_amount = flt(
Nabin Hait5690be12015-02-12 16:09:11 +0530230 me.frm.doc.base_net_total * sales_person.allocated_percentage / 100.0,
Anand Doshif3096132013-05-21 19:35:06 +0530231 precision("allocated_amount", sales_person));
232 }
233 });
234 },
Anand Doshibd67e872014-04-11 16:51:27 +0530235
Anand Doshicefccb92013-07-15 18:28:14 +0530236 shipping_rule: function() {
237 var me = this;
238 if(this.frm.doc.shipping_rule) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530239 return this.frm.call({
Anand Doshicefccb92013-07-15 18:28:14 +0530240 doc: this.frm.doc,
241 method: "apply_shipping_rule",
242 callback: function(r) {
243 if(!r.exc) {
244 me.calculate_taxes_and_totals();
245 }
246 }
247 })
248 }
249 },
Anand Doshibd67e872014-04-11 16:51:27 +0530250
Sambhaji Kolate98dbccd2015-03-10 15:04:28 +0530251 batch_no: function(doc, cdt, cdn) {
252 var me = this;
253 var item = frappe.get_doc(cdt, cdn);
Nabin Hait2ed71ba2015-03-20 15:06:30 +0530254
Sambhaji Kolatea4fa96c2015-03-30 16:04:55 +0530255 if(item.warehouse && item.item_code && item.batch_no) {
Sambhaji Kolatefeff40a2015-03-11 11:50:28 +0530256 return this.frm.call({
257 method: "erpnext.stock.get_item_details.get_batch_qty",
258 child: item,
259 args: {
260 "batch_no": item.batch_no,
261 "warehouse": item.warehouse,
262 "item_code": item.item_code
263 },
264 "fieldname": "actual_batch_qty"
265 });
266 }
Sambhaji Kolate98dbccd2015-03-10 15:04:28 +0530267 },
268
Anand Doshi2168e392013-05-23 19:25:08 +0530269 set_dynamic_labels: function() {
Anand Doshi61a2f682013-06-21 17:55:31 +0530270 this._super();
Neil Trini Lasradoed8cecb2015-07-07 13:59:23 +0530271 this.set_product_bundle_help(this.frm.doc);
Nabin Hait0b157552014-06-24 17:02:45 +0530272 },
273
Neil Trini Lasradoed8cecb2015-07-07 13:59:23 +0530274 set_product_bundle_help: function(doc) {
Nabin Hait0b157552014-06-24 17:02:45 +0530275 if(!cur_frm.fields_dict.packing_list) return;
Nabin Haite7d15362014-12-25 16:01:55 +0530276 if ((doc.packed_items || []).length) {
Nabin Hait0b157552014-06-24 17:02:45 +0530277 $(cur_frm.fields_dict.packing_list.row.wrapper).toggle(true);
278
279 if (inList(['Delivery Note', 'Sales Invoice'], doc.doctype)) {
280 help_msg = "<div class='alert alert-warning'>" +
Neil Trini Lasradoed8cecb2015-07-07 13:59:23 +0530281 __("For 'Product Bundle' 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 'Product Bundle' 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 +0530282 "</div>";
Neil Trini Lasradoed8cecb2015-07-07 13:59:23 +0530283 frappe.meta.get_docfield(doc.doctype, 'product_bundle_help', doc.name).options = help_msg;
Nabin Hait0b157552014-06-24 17:02:45 +0530284 }
285 } else {
286 $(cur_frm.fields_dict.packing_list.row.wrapper).toggle(false);
287 if (inList(['Delivery Note', 'Sales Invoice'], doc.doctype)) {
Neil Trini Lasradoed8cecb2015-07-07 13:59:23 +0530288 frappe.meta.get_docfield(doc.doctype, 'product_bundle_help', doc.name).options = '';
Nabin Hait0b157552014-06-24 17:02:45 +0530289 }
290 }
Neil Trini Lasradoed8cecb2015-07-07 13:59:23 +0530291 refresh_field('product_bundle_help');
Saurabheba7aa42015-12-16 09:57:59 +0530292 },
Anand Doshi01de9452016-01-26 16:22:50 +0530293
Saurabheba7aa42015-12-16 09:57:59 +0530294 make_payment_request: function() {
Saurabheba7aa42015-12-16 09:57:59 +0530295 frappe.call({
296 method:"erpnext.accounts.doctype.payment_request.payment_request.make_payment_request",
297 args: {
298 "dt": cur_frm.doc.doctype,
299 "dn": cur_frm.doc.name,
Saurabhb109ee92015-12-16 20:48:40 +0530300 "recipient_id": cur_frm.doc.contact_email
Saurabheba7aa42015-12-16 09:57:59 +0530301 },
302 callback: function(r) {
Saurabhcb98d9e2015-12-17 09:48:44 +0530303 if(!r.exc){
Saurabh3ba22672015-12-21 18:24:49 +0530304 var doc = frappe.model.sync(r.message);
305 console.log(r.message)
306 frappe.set_route("Form", r.message.doctype, r.message.name);
Saurabhcb98d9e2015-12-17 09:48:44 +0530307 }
Saurabheba7aa42015-12-16 09:57:59 +0530308 }
309 })
Nabin Haitcfc6bb12012-07-11 13:14:52 +0530310 }
Nabin Hait0b157552014-06-24 17:02:45 +0530311});
Anand Doshi43f087c2014-08-26 14:25:53 +0530312
313frappe.ui.form.on(cur_frm.doctype,"project_name", function(frm) {
Nabin Hait10b155a2014-10-23 13:18:59 +0530314 if(in_list(["Delivery Note", "Sales Invoice"], frm.doc.doctype)) {
315 frappe.call({
316 method:'erpnext.projects.doctype.project.project.get_cost_center_name' ,
317 args: { project_name: frm.doc.project_name },
318 callback: function(r, rt) {
319 if(!r.exc) {
Nabin Haitdd38a262014-12-26 13:15:21 +0530320 $.each(frm.doc["items"] || [], function(i, row) {
Neil Trini Lasrado6fc28212014-10-28 14:36:26 +0530321 frappe.model.set_value(row.doctype, row.name, "cost_center", r.message);
322 msgprint(__("Cost Center For Item with Item Code '"+row.item_name+"' has been Changed to "+ r.message));
Nabin Hait10b155a2014-10-23 13:18:59 +0530323 })
324 }
Anand Doshi43f087c2014-08-26 14:25:53 +0530325 }
Nabin Hait10b155a2014-10-23 13:18:59 +0530326 })
327 }
Anand Doshi43f087c2014-08-26 14:25:53 +0530328})