Skip to Content
OWL data_display

Selection Box

Odoo 19 OWL component — Selection Box (views)

Live preview Interactive
Source excerpt web/static/src/views/view_components/selection_box.js
import { Component } from "@odoo/owl";

export class SelectionBox extends Component {
    static components = {};
    static template = "web.SelectionBox";
    static props = {
        root: { type: Object },
    };
    setup() {
        this.root = this.props.root;
    }
    get nbSelected() {
        return this.selectedRecords.length;
    }
    get nbTotal() {
        return this.root.isGrouped ? this.root.recordCount : this.root.count;
    }
    get hasLimitedCount() {
        return this.root.hasLimitedCount;
    }
    get isDomainSelected() {
        return this.root.isDomainSelected;
    }
    get isPageSelected() {
        return (
            this.nbSelected === this.root.records.length &&
            (!this.isRecordCountTrustable || this.nbTotal > this.selectedRecords.length)
        );
    }
    get isRecordCountTrustable() {
        return this.root.isRecordCountTrustable;
    }
    get selectedRecords() {
        return this.root.selection;
    }
    onUnselectAll() {
        this.selectedRecords.forEach((record) => {
            record.toggleSelection(false);
        });
        this.root.selectDomain(false);
    }
    onSelectDomain() {
        this.root.selectDomain(true);
    }
}
Registry / API
Registry name
SelectionBox
Category
Module
web
Slug
selection-box
Nav group
data_display