Ir al contenido
Menú
Se marcó esta pregunta

I would like to add 2 or more separate dynamic filters into a view loaded from JS module.

But the problem is that all of this dynamic filters are treated as one filter group and if activated more or them simultaneously they're combined with an or instead of an and.

For example if I'd like to add a couple of dynamic filters on the Quotations/Orders selection in pos_sale module:

import { ControlButtons } from "@point_of_sale/app/screens/product_screen/control_buttons/control_buttons";
import { _t } from "@web/core/l10n/translation";
import { patch } from "@web/core/utils/patch";
import { SelectCreateDialog } from "@web/views/view_dialogs/select_create_dialog";

patch(ControlButtons.prototype, {
// full override to add dynamic filters
onClickQuotation() {
const dynamicFilters = [{
description: _t("Filter 1"),
domain: [['field_one', '=', 'something']],
}, {
description: _t("Filter 2"),
domain: [['field_two', '=', 'something else']],
}];

this.dialog.add(SelectCreateDialog, {
      resModel: "sale.order",
      noCreate: true,
      multiSelect: false,
      domain: [
        ["state", "!=", "cancel"],
        ["invoice_status", "!=", "invoiced"],
        ["currency_id", "=", this.pos.currency.id],
      ],
      dynamicFilters,
      onSelected: async (resIds) => {
        await this.pos.onClickSaleOrder(resIds[0]);
      },
  });
}
}

This will end up in "Filter 1 or Filter 2" instead of "Filter 1" and "Filter 2"

Avatar
Descartar
Autor

By the end I've overridden _createGroupOfDynamicFilters in search model in order to support multiple groups

Publicaciones relacionadas Respuestas Vistas Actividad
0
jul 25
370
1
jul 25
5229
0
jul 25
766
0
jun 25
832
1
jun 25
994