2015-03-03 14:55:30 +05:30
// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
2013-08-05 14:59:54 +05:30
// License: GNU General Public License v3. See license.txt
2012-02-23 12:35:32 +05:30
2011-06-08 14:37:15 +05:30
2015-02-23 11:58:15 +05:30
cur _frm . cscript . tax _table = "Sales Taxes and Charges" ;
2015-05-06 22:59:00 +05:30
{ % include 'accounts/doctype/sales_taxes_and_charges_template/sales_taxes_and_charges_template.js' % }
2015-02-23 11:58:15 +05:30
2014-02-14 15:47:51 +05:30
frappe . provide ( "erpnext.selling" ) ;
2015-01-22 17:13:13 +05:30
frappe . require ( "assets/erpnext/js/controllers/transaction.js" ) ;
2014-01-02 11:47:23 +05:30
2014-09-12 13:09:41 +05:30
cur _frm . email _field = "contact_email" ;
2013-05-24 19:25:01 +05:30
erpnext . selling . SellingController = erpnext . TransactionController . extend ( {
2013-07-11 19:13:58 +05:30
onload : function ( ) {
this . _super ( ) ;
this . setup _queries ( ) ;
} ,
2014-04-11 16:51:27 +05:30
2013-07-11 19:13:58 +05:30
setup _queries : function ( ) {
2013-07-04 17:13:53 +05:30
var me = this ;
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
this . frm . add _fetch ( "sales_partner" , "commission_rate" , "commission_rate" ) ;
2014-04-11 16:51:27 +05:30
$ . each ( [ [ "customer_address" , "customer_filter" ] ,
2013-07-29 13:28:37 +05:30
[ "shipping_address_name" , "customer_filter" ] ,
2014-04-11 16:51:27 +05:30
[ "contact_person" , "customer_filter" ] ,
[ "customer" , "customer" ] ,
[ "lead" , "lead" ] ] ,
2013-07-29 13:28:37 +05:30
function ( i , opts ) {
2014-04-11 16:51:27 +05:30
if ( me . frm . fields _dict [ opts [ 0 ] ] )
2013-07-29 13:28:37 +05:30
me . frm . set _query ( opts [ 0 ] , erpnext . queries [ opts [ 1 ] ] ) ;
} ) ;
2014-04-11 16:51:27 +05:30
2014-01-29 16:31:38 +05:30
if ( this . frm . fields _dict . taxes _and _charges ) {
this . frm . set _query ( "taxes_and_charges" , function ( ) {
2013-07-10 13:07:49 +05:30
return {
filters : [
2015-05-08 11:08:48 +05:30
[ 'Sales Taxes and Charges Template' , 'company' , '=' , me . frm . doc . company ] ,
[ 'Sales Taxes and Charges Template' , 'docstatus' , '!=' , 2 ]
2013-07-10 13:07:49 +05:30
]
}
2013-07-04 17:13:53 +05:30
} ) ;
}
2013-08-09 18:11:35 +05:30
if ( this . frm . fields _dict . selling _price _list ) {
this . frm . set _query ( "selling_price_list" , function ( ) {
2014-01-07 18:37:38 +05:30
return { filters : { selling : 1 } } ;
2013-07-26 11:32:02 +05:30
} ) ;
}
2014-04-11 16:51:27 +05:30
2014-12-26 13:15:21 +05:30
if ( ! this . frm . fields _dict [ "items" ] ) {
2013-07-04 17:13:53 +05:30
return ;
}
2014-04-11 16:51:27 +05:30
2014-12-26 13:15:21 +05:30
if ( this . frm . fields _dict [ "items" ] . grid . get _field ( 'item_code' ) ) {
this . frm . set _query ( "item_code" , "items" , function ( ) {
2013-07-11 19:13:58 +05:30
return {
2013-12-13 14:10:14 +05:30
query : "erpnext.controllers.queries.item_query" ,
2013-07-11 19:13:58 +05:30
filters : ( me . frm . doc . order _type === "Maintenance" ?
2015-07-24 15:16:25 +05:30
{ 'is_service_item' : 1 } :
{ 'is_sales_item' : 1 } )
2013-07-11 19:13:58 +05:30
}
2013-07-04 17:13:53 +05:30
} ) ;
}
2014-04-11 16:51:27 +05:30
2014-12-26 13:15:21 +05:30
if ( this . frm . fields _dict [ "items" ] . grid . get _field ( 'batch_no' ) ) {
this . frm . set _query ( "batch_no" , "items" , function ( doc , cdt , cdn ) {
2014-03-27 14:17:33 +05:30
var item = frappe . get _doc ( cdt , cdn ) ;
2013-07-04 17:13:53 +05:30
if ( ! item . item _code ) {
2014-04-14 16:25:30 +05:30
frappe . throw ( _ _ ( "Please enter Item Code to get batch no" ) ) ;
2013-07-04 17:13:53 +05:30
} else {
2013-10-18 12:29:11 +05:30
filters = {
'item_code' : item . item _code ,
2015-07-08 14:36:09 +05:30
'posting_date' : me . frm . doc . posting _date || nowdate ( ) ,
2013-10-18 12:29:11 +05:30
}
if ( item . warehouse ) filters [ "warehouse" ] = item . warehouse
2014-04-11 16:51:27 +05:30
2013-10-18 12:29:11 +05:30
return {
2014-01-29 16:31:38 +05:30
query : "erpnext.controllers.queries.get_batch_no" ,
2013-10-18 12:29:11 +05:30
filters : filters
2013-07-04 17:13:53 +05:30
}
}
} ) ;
}
2014-04-11 16:51:27 +05:30
2013-07-23 15:16:50 +05:30
if ( this . frm . fields _dict . sales _team && this . frm . fields _dict . sales _team . grid . get _field ( "sales_person" ) ) {
2013-07-29 13:28:37 +05:30
this . frm . set _query ( "sales_person" , "sales_team" , erpnext . queries . not _a _group _filter ) ;
2013-07-23 15:16:50 +05:30
}
2013-05-15 21:15:57 +05:30
} ,
2014-04-11 16:51:27 +05:30
2013-08-01 18:19:51 +05:30
refresh : function ( ) {
this . _super ( ) ;
2014-04-11 16:51:27 +05:30
this . frm . toggle _display ( "customer_name" ,
2013-12-09 16:29:04 +05:30
( this . frm . doc . customer _name && this . frm . doc . customer _name !== this . frm . doc . customer ) ) ;
2014-12-25 16:01:55 +05:30
if ( this . frm . fields _dict . packed _items ) {
var packing _list _exists = ( this . frm . doc . packed _items || [ ] ) . length ;
2013-08-01 18:19:51 +05:30
this . frm . toggle _display ( "packing_list" , packing _list _exists ? true : false ) ;
}
2015-04-16 17:55:35 +05:30
this . toggle _editable _price _list _rate ( ) ;
2013-07-04 12:50:52 +05:30
} ,
2014-04-11 16:51:27 +05:30
2013-05-24 19:25:01 +05:30
customer : function ( ) {
2014-05-28 12:49:20 +05:30
var me = this ;
erpnext . utils . get _party _details ( this . frm , null , null , function ( ) { me . apply _pricing _rule ( ) } ) ;
2013-05-24 19:25:01 +05:30
} ,
2014-04-11 16:51:27 +05:30
2013-07-15 13:04:33 +05:30
customer _address : function ( ) {
2014-01-02 11:47:23 +05:30
erpnext . utils . get _address _display ( this . frm , "customer_address" ) ;
2013-07-15 13:04:33 +05:30
} ,
2014-04-11 16:51:27 +05:30
2014-02-19 17:43:24 +05:30
shipping _address _name : function ( ) {
erpnext . utils . get _address _display ( this . frm , "shipping_address_name" , "shipping_address" ) ;
} ,
2014-04-11 16:51:27 +05:30
2014-05-28 12:49:20 +05:30
sales _partner : function ( ) {
this . apply _pricing _rule ( ) ;
} ,
campaign : function ( ) {
this . apply _pricing _rule ( ) ;
} ,
2013-08-09 18:11:35 +05:30
selling _price _list : function ( ) {
2014-07-01 17:45:15 +05:30
this . apply _price _list ( ) ;
2013-05-21 19:35:06 +05:30
} ,
2014-04-11 16:51:27 +05:30
2014-02-10 17:54:04 +05:30
price _list _rate : function ( doc , cdt , cdn ) {
2014-03-27 14:17:33 +05:30
var item = frappe . get _doc ( cdt , cdn ) ;
2014-02-14 15:47:51 +05:30
frappe . model . round _floats _in ( item , [ "price_list_rate" , "discount_percentage" ] ) ;
2014-04-11 16:51:27 +05:30
2014-02-10 18:26:49 +05:30
item . rate = flt ( item . price _list _rate * ( 1 - item . discount _percentage / 100.0 ) ,
precision ( "rate" , item ) ) ;
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
this . calculate _taxes _and _totals ( ) ;
} ,
2014-04-11 16:51:27 +05:30
2014-02-10 17:54:04 +05:30
discount _percentage : function ( doc , cdt , cdn ) {
2014-03-27 14:17:33 +05:30
var item = frappe . get _doc ( cdt , cdn ) ;
2014-02-10 17:54:04 +05:30
if ( ! item . price _list _rate ) {
item . discount _percentage = 0.0 ;
2013-05-28 17:23:36 +05:30
} else {
2014-02-10 17:54:04 +05:30
this . price _list _rate ( doc , cdt , cdn ) ;
2013-05-28 17:23:36 +05:30
}
2013-05-21 19:35:06 +05:30
} ,
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
commission _rate : function ( ) {
this . calculate _commission ( ) ;
refresh _field ( "total_commission" ) ;
} ,
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
total _commission : function ( ) {
2015-02-12 16:09:11 +05:30
if ( this . frm . doc . base _net _total ) {
frappe . model . round _floats _in ( this . frm . doc , [ "base_net_total" , "total_commission" ] ) ;
2014-04-11 16:51:27 +05:30
2015-02-12 16:09:11 +05:30
if ( this . frm . doc . base _net _total < this . frm . doc . total _commission ) {
2014-04-14 16:25:30 +05:30
var msg = ( _ _ ( "[Error]" ) + " " +
_ _ ( frappe . meta . get _label ( this . frm . doc . doctype , "total_commission" ,
2014-04-11 16:51:27 +05:30
this . frm . doc . name ) ) + " > " +
2015-02-12 16:09:11 +05:30
_ _ ( frappe . meta . get _label ( this . frm . doc . doctype , "base_net_total" , this . frm . doc . name ) ) ) ;
2013-05-21 19:35:06 +05:30
msgprint ( msg ) ;
throw msg ;
}
2014-04-11 16:51:27 +05:30
this . frm . set _value ( "commission_rate" ,
2015-02-12 16:09:11 +05:30
flt ( this . frm . doc . total _commission * 100.0 / this . frm . doc . base _net _total ) ) ;
2013-05-21 19:35:06 +05:30
}
} ,
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
allocated _percentage : function ( doc , cdt , cdn ) {
2014-03-27 14:17:33 +05:30
var sales _person = frappe . get _doc ( cdt , cdn ) ;
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
if ( sales _person . allocated _percentage ) {
sales _person . allocated _percentage = flt ( sales _person . allocated _percentage ,
precision ( "allocated_percentage" , sales _person ) ) ;
2015-02-12 16:09:11 +05:30
sales _person . allocated _amount = flt ( this . frm . doc . base _net _total *
2014-04-11 16:51:27 +05:30
sales _person . allocated _percentage / 100.0 ,
2013-05-21 19:35:06 +05:30
precision ( "allocated_amount" , sales _person ) ) ;
refresh _field ( [ "allocated_percentage" , "allocated_amount" ] , sales _person . name ,
sales _person . parentfield ) ;
}
} ,
2014-04-11 16:51:27 +05:30
2013-05-27 19:29:07 +05:30
warehouse : function ( doc , cdt , cdn ) {
2015-03-10 15:04:28 +05:30
var me = this ;
this . batch _no ( doc , cdt , cdn ) ;
2014-03-27 14:17:33 +05:30
var item = frappe . get _doc ( cdt , cdn ) ;
2013-07-23 13:36:38 +05:30
if ( item . item _code && item . warehouse ) {
2013-07-29 19:30:39 +05:30
return this . frm . call ( {
2014-05-30 19:10:12 +05:30
method : "erpnext.stock.get_item_details.get_available_qty" ,
2013-05-27 19:29:07 +05:30
child : item ,
args : {
item _code : item . item _code ,
2013-07-23 13:36:38 +05:30
warehouse : item . warehouse ,
2013-05-27 19:29:07 +05:30
} ,
} ) ;
}
} ,
2014-04-11 16:51:27 +05:30
2013-08-02 12:39:10 +05:30
toggle _editable _price _list _rate : function ( ) {
2014-12-26 13:15:21 +05:30
var df = frappe . meta . get _docfield ( this . frm . doc . doctype + " Item" , "price_list_rate" , this . frm . doc . name ) ;
2014-02-14 15:47:51 +05:30
var editable _price _list _rate = cint ( frappe . defaults . get _default ( "editable_price_list_rate" ) ) ;
2014-04-11 16:51:27 +05:30
2013-08-02 12:39:10 +05:30
if ( df && editable _price _list _rate ) {
df . read _only = 0 ;
}
} ,
2014-04-11 16:51:27 +05:30
2014-04-16 15:21:46 +05:30
calculate _outstanding _amount : function ( update _paid _amount ) {
2014-04-11 16:51:27 +05:30
// NOTE:
2013-09-05 12:59:33 +05:30
// paid_amount and write_off_amount is only for POS Invoice
2013-05-28 17:23:36 +05:30
// total_advance is only for non POS Invoice
2015-07-17 15:19:02 +05:30
if ( this . frm . doc . doctype == "Sales Invoice" && this . frm . doc . docstatus == 0 && ! this . frm . doc . is _return ) {
2015-02-12 16:09:11 +05:30
frappe . model . round _floats _in ( this . frm . doc , [ "base_grand_total" , "total_advance" , "write_off_amount" ,
2014-03-13 17:26:41 +05:30
"paid_amount" ] ) ;
2015-02-12 16:09:11 +05:30
var total _amount _to _pay = this . frm . doc . base _grand _total - this . frm . doc . write _off _amount
2014-03-13 17:26:41 +05:30
- this . frm . doc . total _advance ;
2014-03-25 19:35:41 +05:30
if ( this . frm . doc . is _pos ) {
2014-04-16 15:21:46 +05:30
if ( ! this . frm . doc . paid _amount || update _paid _amount === undefined || update _paid _amount ) {
this . frm . doc . paid _amount = flt ( total _amount _to _pay ) ;
2015-01-06 17:14:13 +05:30
this . frm . refresh _field ( "paid_amount" ) ;
2014-04-16 15:21:46 +05:30
}
2014-03-25 19:35:41 +05:30
} else {
this . frm . doc . paid _amount = 0
2015-01-06 17:14:13 +05:30
this . frm . refresh _field ( "paid_amount" ) ;
2014-03-25 19:35:41 +05:30
}
2014-03-13 16:32:43 +05:30
2014-04-11 16:51:27 +05:30
this . frm . set _value ( "outstanding_amount" , flt ( total _amount _to _pay
2014-03-13 17:26:41 +05:30
- this . frm . doc . paid _amount , precision ( "outstanding_amount" ) ) ) ;
2013-05-27 19:29:07 +05:30
}
} ,
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
calculate _commission : function ( ) {
2013-05-28 17:23:36 +05:30
if ( this . frm . fields _dict . commission _rate ) {
if ( this . frm . doc . commission _rate > 100 ) {
2014-04-14 16:25:30 +05:30
var msg = _ _ ( frappe . meta . get _label ( this . frm . doc . doctype , "commission_rate" , this . frm . doc . name ) ) +
" " + _ _ ( "cannot be greater than 100" ) ;
2013-05-28 17:23:36 +05:30
msgprint ( msg ) ;
throw msg ;
}
2014-04-11 16:51:27 +05:30
2015-02-12 16:09:11 +05:30
this . frm . doc . total _commission = flt ( this . frm . doc . base _net _total * this . frm . doc . commission _rate / 100.0 ,
2013-05-28 17:23:36 +05:30
precision ( "total_commission" ) ) ;
}
2013-05-21 19:35:06 +05:30
} ,
2014-04-11 16:51:27 +05:30
2013-05-21 19:35:06 +05:30
calculate _contribution : function ( ) {
2013-05-23 19:25:08 +05:30
var me = this ;
2014-03-26 18:24:30 +05:30
$ . each ( this . frm . doc . doctype . sales _team || [ ] , function ( i , sales _person ) {
2014-02-14 15:47:51 +05:30
frappe . model . round _floats _in ( sales _person ) ;
2013-05-21 19:35:06 +05:30
if ( sales _person . allocated _percentage ) {
sales _person . allocated _amount = flt (
2015-02-12 16:09:11 +05:30
me . frm . doc . base _net _total * sales _person . allocated _percentage / 100.0 ,
2013-05-21 19:35:06 +05:30
precision ( "allocated_amount" , sales _person ) ) ;
}
} ) ;
} ,
2014-04-11 16:51:27 +05:30
2013-07-15 18:28:14 +05:30
shipping _rule : function ( ) {
var me = this ;
if ( this . frm . doc . shipping _rule ) {
2013-07-29 19:30:39 +05:30
return this . frm . call ( {
2013-07-15 18:28:14 +05:30
doc : this . frm . doc ,
method : "apply_shipping_rule" ,
callback : function ( r ) {
if ( ! r . exc ) {
me . calculate _taxes _and _totals ( ) ;
}
}
} )
}
} ,
2014-04-11 16:51:27 +05:30
2015-03-10 15:04:28 +05:30
batch _no : function ( doc , cdt , cdn ) {
var me = this ;
var item = frappe . get _doc ( cdt , cdn ) ;
2015-03-20 15:06:30 +05:30
2015-03-30 16:04:55 +05:30
if ( item . warehouse && item . item _code && item . batch _no ) {
2015-03-11 11:50:28 +05:30
return this . frm . call ( {
method : "erpnext.stock.get_item_details.get_batch_qty" ,
child : item ,
args : {
"batch_no" : item . batch _no ,
"warehouse" : item . warehouse ,
"item_code" : item . item _code
} ,
"fieldname" : "actual_batch_qty"
} ) ;
}
2015-03-10 15:04:28 +05:30
} ,
2013-05-23 19:25:08 +05:30
set _dynamic _labels : function ( ) {
2013-06-21 17:55:31 +05:30
this . _super ( ) ;
2015-07-07 13:59:23 +05:30
this . set _product _bundle _help ( this . frm . doc ) ;
2014-06-24 17:02:45 +05:30
} ,
2015-07-07 13:59:23 +05:30
set _product _bundle _help : function ( doc ) {
2014-06-24 17:02:45 +05:30
if ( ! cur _frm . fields _dict . packing _list ) return ;
2014-12-25 16:01:55 +05:30
if ( ( doc . packed _items || [ ] ) . length ) {
2014-06-24 17:02:45 +05:30
$ ( cur _frm . fields _dict . packing _list . row . wrapper ) . toggle ( true ) ;
if ( inList ( [ 'Delivery Note' , 'Sales Invoice' ] , doc . doctype ) ) {
help _msg = "<div class='alert alert-warning'>" +
2015-07-07 13:59:23 +05:30
_ _ ( "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." ) +
2014-06-24 17:02:45 +05:30
"</div>" ;
2015-07-07 13:59:23 +05:30
frappe . meta . get _docfield ( doc . doctype , 'product_bundle_help' , doc . name ) . options = help _msg ;
2014-06-24 17:02:45 +05:30
}
} else {
$ ( cur _frm . fields _dict . packing _list . row . wrapper ) . toggle ( false ) ;
if ( inList ( [ 'Delivery Note' , 'Sales Invoice' ] , doc . doctype ) ) {
2015-07-07 13:59:23 +05:30
frappe . meta . get _docfield ( doc . doctype , 'product_bundle_help' , doc . name ) . options = '' ;
2014-06-24 17:02:45 +05:30
}
}
2015-07-07 13:59:23 +05:30
refresh _field ( 'product_bundle_help' ) ;
2012-07-11 13:14:52 +05:30
}
2014-06-24 17:02:45 +05:30
} ) ;
2014-08-26 14:25:53 +05:30
frappe . ui . form . on ( cur _frm . doctype , "project_name" , function ( frm ) {
2014-10-23 13:18:59 +05:30
if ( in _list ( [ "Delivery Note" , "Sales Invoice" ] , frm . doc . doctype ) ) {
frappe . call ( {
method : 'erpnext.projects.doctype.project.project.get_cost_center_name' ,
args : { project _name : frm . doc . project _name } ,
callback : function ( r , rt ) {
if ( ! r . exc ) {
2014-12-26 13:15:21 +05:30
$ . each ( frm . doc [ "items" ] || [ ] , function ( i , row ) {
2014-10-28 14:36:26 +05:30
frappe . model . set _value ( row . doctype , row . name , "cost_center" , r . message ) ;
msgprint ( _ _ ( "Cost Center For Item with Item Code '" + row . item _name + "' has been Changed to " + r . message ) ) ;
2014-10-23 13:18:59 +05:30
} )
}
2014-08-26 14:25:53 +05:30
}
2014-10-23 13:18:59 +05:30
} )
}
2014-08-26 14:25:53 +05:30
} )