Přejít na obsah
Menu
You need to be registered to interact with the community.
This question has been flagged
1 Odpovědět
3504 Zobrazení

I know how to override any Js class or functions or methods. The question is how can i do it dynamically?

Requirement is to use both existing class/functions and overriden class/functions as per choice in the same odoo database. Let say I add a field (Boolean). When it is unchecked (False), then the override should not be done on class/function and only existing class/function should be used and if checked (True) then overrided class/functions should be used.

Avatar
Zrušit
Nejlepší odpověď

Hi,

To dynamically switch between the original and custom JavaScript, extend the original JavaScript class with a custom implementation.

For example:


/** @odoo-module **/

import { registry } from "@web/core/registry";

import { useService } from "@web/core/utils/hooks";

import { OriginalComponent } from "@original/module/path";


// Extend the OriginalComponent to add a custom implementation

class CustomComponent extends OriginalComponent {

    setup() {

        super.setup();

        this.orm = useService("orm"); // Initialize the ORM service for data access

    }


    async someMethod(...args) {

        // Fetch a configuration value from the model to decide which implementation to use

        const [configValue] = await this.orm.read(

            'your.model',     // Model name

            [1],              // Record ID

            ['field_name']    // Field to check for custom usage

        );

       

        if (configValue.use_custom_js) {

            // Custom code block if custom_js is enabled

            console.log("Field is enabled..");

            // Add custom logic here as needed

        } else {

            // Fallback to the original method implementation

            return super.someMethod(...args);

        }

    }

}


// Register your component in the registry to make it available in Odoo

registry.category("views").add("custom_component", CustomComponent);


Hope it helps

Avatar
Zrušit
Related Posts Odpovědi Zobrazení Aktivita
0
lis 24
3272
2
čvn 22
12309
0
čvc 19
3915
0
srp 25
1621
2
říj 25
2636