Merge pull request #10697 from rohitwaghchaure/customer_search_optimization

[Fix] Customer search optimization for the offline POS
This commit is contained in:
rohitwaghchaure 2017-09-11 16:23:15 +05:30 committed by GitHub
commit e2149cb46f

View File

@ -732,7 +732,12 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
input = input.toLowerCase(); input = input.toLowerCase();
item = this.get_item(item.value); item = this.get_item(item.value);
return item.searchtext.includes(input) result = item ? item.searchtext.includes(input) : '';
if(!result) {
me.prepare_customer_mapper(input);
} else {
return result;
}
}, },
item: function (item, input) { item: function (item, input) {
var d = this.get_item(item.value); var d = this.get_item(item.value);
@ -753,6 +758,9 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
this.party_field.$input this.party_field.$input
.on('input', function (e) { .on('input', function (e) {
if(me.customers_mapper.length <= 1) {
me.prepare_customer_mapper(e.target.value);
}
me.party_field.awesomeplete.list = me.customers_mapper; me.party_field.awesomeplete.list = me.customers_mapper;
}) })
.on('awesomplete-select', function (e) { .on('awesomplete-select', function (e) {
@ -793,12 +801,41 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
}); });
}, },
prepare_customer_mapper: function() { prepare_customer_mapper: function(key) {
var me = this; var me = this;
var customer_data = '';
this.customers_mapper = this.customers.map(function (c) { if (key) {
key = key.toLowerCase().trim();
var re = new RegExp('%', 'g');
var reg = new RegExp(key.replace(re, '\\w*\\s*[a-zA-Z0-9]*'));
customer_data = $.grep(this.customers, function(data) {
contact = me.contacts[data.name];
if(reg.test(data.name.toLowerCase())
|| reg.test(data.customer_name.toLowerCase())
|| (contact && reg.test(contact["mobile_no"]))
|| (contact && reg.test(contact["phone"]))
|| (data.customer_group && reg.test(data.customer_group.toLowerCase()))){
return data;
}
})
} else {
customer_data = this.customers;
}
this.customers_mapper = [];
customer_data.forEach(function (c, index) {
if(index < 30) {
contact = me.contacts[c.name]; contact = me.contacts[c.name];
return { if(contact && !c['phone']) {
c["phone"] = contact["phone"];
c["email_id"] = contact["email_id"];
c["mobile_no"] = contact["mobile_no"];
}
me.customers_mapper.push({
label: c.name, label: c.name,
value: c.name, value: c.name,
customer_name: c.customer_name, customer_name: c.customer_name,
@ -807,10 +844,13 @@ erpnext.pos.PointOfSale = erpnext.taxes_and_totals.extend({
phone: contact ? contact["phone"] : '', phone: contact ? contact["phone"] : '',
mobile_no: contact ? contact["mobile_no"] : '', mobile_no: contact ? contact["mobile_no"] : '',
email_id: contact ? contact["email_id"] : '', email_id: contact ? contact["email_id"] : '',
searchtext: ['customer_name', 'customer_group', 'value', searchtext: ['customer_name', 'customer_group', 'name', 'value',
'label', 'email_id', 'phone', 'mobile_no'] 'label', 'email_id', 'phone', 'mobile_no']
.map(key => c[key]).join(' ') .map(key => c[key]).join(' ')
.toLowerCase() .toLowerCase()
});
} else {
return;
} }
}); });