@ -327,6 +327,62 @@ function pos_pricelist_models(instance, module) {
}
}
return version ;
return version ;
} ,
} ,
/ * *
* Check if a pricelist rule can be used
* @ param item
* @ param product
* @ param version
* @ returns { boolean }
* /
rule_match : function ( db , item , product , qty , version ) {
// get categories
var categ_ids = [ ] ;
if ( product . categ_id ) {
categ_ids . push ( product . categ_id [ 0 ] ) ;
categ_ids = categ_ids . concat (
db . product_category_ancestors [ product . categ_id [ 0 ] ]
) ;
}
var cond = true
var template_false = item . product_tmpl_id === false
var product_false = item . product_id === false
var template_match = (
! template_false &&
item . product_tmpl_id [ 0 ] === product . product_tmpl_id
)
var product_match = (
! product_false &&
item . product_id [ 0 ] === product . id
)
// Check if products/template combination is possible
cond = cond && (
( product_false && template_false ) ||
( product_match && ( template_false || template_match ) ) ||
( template_match && product_false )
)
// Check category
cond = cond && (
item . categ_id === false ||
categ_ids . indexOf ( item . categ_id [ 0 ] ) !== - 1
)
// Check version
cond = cond && (
item . price_version_id [ 0 ] === version . id
)
// Check product qty
cond = cond && (
! item . min_quantity ||
qty >= item . min_quantity
)
return cond
} ,
/ * *
/ * *
* compute the price for the given product
* compute the price for the given product
* @ param database
* @ param database
@ -351,25 +407,13 @@ function pos_pricelist_models(instance, module) {
return false ;
return false ;
}
}
// get categories
var categ_ids = [ ] ;
if ( product . categ_id ) {
categ_ids . push ( product . categ_id [ 0 ] ) ;
categ_ids = categ_ids . concat (
db . product_category_ancestors [ product . categ_id [ 0 ] ]
) ;
}
// find items
// find items
var items = [ ] , i , len ;
var items = [ ] , i , len ;
for ( i = 0 , len = db . pricelist_item_sorted . length ; i < len ; i ++ ) {
for ( i = 0 , len = db . pricelist_item_sorted . length ; i < len ; i ++ ) {
var item = db . pricelist_item_sorted [ i ] ;
var item = db . pricelist_item_sorted [ i ] ;
if ( ( item . product_id === false
|| item . product_id [ 0 ] === product . id ) &&
( item . categ_id === false
|| categ_ids . indexOf ( item . categ_id [ 0 ] ) !== - 1 ) &&
( item . price_version_id [ 0 ] === version . id ) ) {
items . push ( item ) ;
if ( this . rule_match ( db , item , product , qty , version ) ) {
items . push ( item )
}
}
}
}
@ -382,13 +426,6 @@ function pos_pricelist_models(instance, module) {
for ( i = 0 , len = items . length ; i < len ; i ++ ) {
for ( i = 0 , len = items . length ; i < len ; i ++ ) {
var rule = items [ i ] ;
var rule = items [ i ] ;
if ( rule . min_quantity && qty < rule . min_quantity ) {
continue ;
}
if ( rule . product_id && rule . product_id [ 0 ]
&& product . id != rule . product_id [ 0 ] ) {
continue ;
}
if ( rule . categ_id ) {
if ( rule . categ_id ) {
var cat_id = product . categ_id [ 0 ] ;
var cat_id = product . categ_id [ 0 ] ;
while ( cat_id ) {
while ( cat_id ) {
@ -401,6 +438,7 @@ function pos_pricelist_models(instance, module) {
continue ;
continue ;
}
}
}
}
// Based on field
// Based on field
switch ( rule . base ) {
switch ( rule . base ) {
case - 1 :
case - 1 :