Browse Source

[Fix][8.0] Fix the way pricelists are selected when a template_id is set as rule of pricelist (#100)

Added a method to match rules.

It can be inherited which allow other modules to extend the way the
pricelists are chosen.

Also a rule in the while loop could be removed as it duplicated
one of the tests when choosing the available pricelists.
pull/255/head
Loïc Faure-Lacroix 7 years ago
committed by Pedro M. Baeza
parent
commit
e8b5508fa4
  1. 80
      pos_pricelist/static/src/js/models.js

80
pos_pricelist/static/src/js/models.js

@ -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:

Loading…
Cancel
Save