【问题标题】:Add client search criteria Odoo13's POS添加客户端搜索条件 Odoo13 的 POS
【发布时间】:2020-08-06 01:57:45
【问题描述】:

我已将一些自定义字段添加到 res.partner 的模型中,并且我想将此字段添加到 POS 的搜索条件中。我在我的 models.js 文件中添加的字段可以在以下代码中使用:

odoo.define('my_module.models', function (require) {
    "use strict";

    var models = require('point_of_sale.models');

    models.load_fields('res.partner', [
        'billing_name',
        'partner_billing_number'
    ]);

    models.load_models([{
        model: 'res.partner',
        fields: ['billing_name', 'partner_billing_number'],
        loaded: function(self, partners){self.db.add_partners(partners)},
    }]);

});

然后我尝试使用我的 db.js 文件使用以下代码将此字段添加到搜索条件:

odoo.define('my_module.db', function (require) {
    "use strict";

    var core = require('web.core');

    var PosDB = core.Class.extend({
        _partner_search_string: function(partner){
            var str = partner.name || '';
            if(partner.billing_name){
                str += '|' + partner.billing_name;
            }
            if(partner.partner_billing_number){
                str += '|' + partner.partner_billing_number;
            }
            str = partner.id + ':' +str.replace(/:/g,'') + '\n';
            return str;
        },

        add_partners:function (partners) {
            for(let i=0, len=partners.length; i < len; i++){
                var partner = partners[i];
                var search_string = this._partner_search_string(partner);
                this.partner_search_string[partner] += search_string;
            }
        }
    });

    return PosDB;

});

到目前为止,我无法将两个搜索字段都添加到搜索条件中,它甚至有点破坏了代码。我的代码中缺少什么?我怎样才能做到这一点?

【问题讨论】:

  • 检查第一个天气,您正在获取特定客户记录的该字段的值。
  • 正如我所说,我无法将它们添加到搜索条件中,因为 Odoo 不会返回我为测试此代码而创建的记录。你的意思是这个代码块应该可以工作?

标签: javascript odoo customization pos odoo-13


【解决方案1】:
odoo.define('my_module.models', function (require) {
    "use strict";

var PosDB = require('point_of_sale.DB');
var models = require('point_of_sale.models');
models.load_fields('res.partner', [
        'billing_name',
        'partner_billing_number'
    ]);

PosDB.include({
    _partner_search_string: function(partner){
        var str =  partner.name || '';
        if(partner.barcode){
            str += '|' + partner.barcode;
        }
        if(partner.address){
            str += '|' + partner.address;
        }
        if(partner.phone){
            str += '|' + partner.phone.split(' ').join('');
        }
        if(partner.mobile){
            str += '|' + partner.mobile.split(' ').join('');
        }
        if(partner.email){
            str += '|' + partner.email;
        }
        if(partner.vat){
            str += '|' + partner.vat;
        }
        if(partner.billing_name){
            str += '|' + partner.billing_name;
        }
        if(partner.partner_billing_number){
            str += '|' + partner.partner_billing_number;
        }
        str = '' + partner.id + ':' + str.replace(':','') + '\n';
        return str;
    },
});

});

仅使用一个文件,希望您能得到所需的输出。

【讨论】:

  • 谢谢大家,我从今天早上开始就一直在寻找它。
猜你喜欢
  • 1970-01-01
  • 2020-07-19
  • 2011-05-28
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多