コンテンツへスキップ
メニュー
この質問にフラグが付けられました
1 返信
2772 ビュー

Hello!


I am planning to insert a dynamic html called (approval_workflow_actions) using Widget.

The way it described on the Odoo 16 documentation is really straight forward but for some reason it is not working when Im using widget.appendTo($('.target-element')) but if I use widget.appendTo(document.body) the element successfully inserted.

https://www.odoo.com/documentation/16.0/developer/reference/frontend/javascript_reference.html#widgets

The way I see it is the classname .target-element is not yet loaded thats why appendTo is not working.


Can someone help me?


Sample Code:

------------------------------------------

approval_workflow_actions.js

------------------------------------------

odoo.define('mod_approval_workflow.approval_workflow_actions', function(require){

'use strict'
 
var core = require('web.core');
 
var Widget = require('web.Widget');
 
 
var ActionsWidget = Widget.extend({
 
​template:"temp_approval_workflow.approval_workflow_actions",
 
​init: function (parent) {
this._super(parent);
},
 
});

​// Create the instance
​var actions = new ActionsWidget(this);
 
//Working here
//​actions.appendTo(document.body);
 
​//Not working if I used the classname
​actions.appendTo(".o_control_panel");
 
});

------------------------------------------

temp_approval_workflow.xml

------------------------------------------

xml version="1.0" encoding="UTF-8"?>
<templates>
<div t-name="temp_approval_workflow.approval_workflow_actions">
<buttonclass="btn btn-sm btn-primary">APPROVEbutton>
<buttonclass="btn btn-sm btn-danger">REJECTbutton>

templates>

Thanks you,


Sigmund


アバター
破棄
最善の回答

Hi,

Try using the following code

In Js:

/** @odoo-module */

import { ControlPanel } from "@web/search/control_panel/control_panel";

export class MyComponent extends Component {
// Your js code
}
MyComponent.template = "module.MyComponent";

ControlPanel.components = {...ControlPanel.components, MyComponent}

in Xml (QWeb):

<?xml version="1.0" encoding="utf-8"?>
<templates xml:space="preserve">
    <t t-name="module.MyComponent" owl="1">
          <!--        Xml code here-->
    </t>
    <t t-inherit="web.ControlPanel" t-inherit-mode="extension" owl="1">
        <xpath expr="//div[hasclass('o_control_panel')]" position="inside">
            <MyComponent/>
        </xpath>
    </t>
</templates>


Regards

アバター
破棄
関連投稿 返信 ビュー 活動
1
2月 24
4527
2
6月 23
3926
0
5月 23
2317
1
1月 19
5914
2
7月 18
9037