Skip to Content
Menu
Musisz się zarejestrować, aby móc wchodzić w interakcje z tą społecznością.
To pytanie dostało ostrzeżenie
1 Odpowiedz
3090 Widoki

Hello! I'm somewhat new to odoo and I have this problem:

I need to show a confirmation dialog box when there is no email in a specific model when saving a form, I achieved this by modifying the "saveButtonClicked" function and creating "saveConfirmationDialogProps" as shown below:


get saveConfirmationDialogProps() {

        return {            

​body: this.env._t("¿Estas seguro que quieres guardar este registro sin ​email?"), 

           ​ confirm: async () => {                                

​const record = this.model.root;

​let saved = false;               

​ if (this.props.saveRecord) {                    

​saved = await this.props.saveRecord(record, params);       

​} else {                   

​ saved = await record.save();               

​}                

​if (saved && this.props.onSave) {     

​this.props.onSave(record, params);                

​}            

​},            

​cancel: () => {},        

​};   

 }


async saveButtonClicked(params = {}) {       

​ const record = this.model.root;        

​ let saved = false;        

​ console.log(record);        

​ if (record.resModel === "res.partner" && record.data.email === "") {            ​this.dialogService.add(ConfirmationDialog, ​this.saveConfirmationDialogProps);        

​} else {             

​if (this.props.saveRecord) {                

​saved = await this.props.saveRecord(record, params);            

​} else {               

​ saved = await record.save();            

​}           

​ if (saved && this.props.onSave) {                

​this.props.onSave(record, params);            

​}        

​}       

​ return true;    

}  


This in the form_controller.js file in this path: "C:\Program Files\Odoo 16\server\odoo\addons\web\static\src\views\form\form_controller.js" where I have odoo installed


But I should not modify the odoo source file, I should overwrite it from a script that is in my custom module that is located in another path.


This is the code I implemented:


odoo.define('felsv_parameter.custom_script', function (require) {   

​"use strict";

    ​const FormController = require('web.FormController');   

​const ConfirmationDialog=require('@web/core/confirmation_dialog/confirmation_dialog');    ​alert("Script works")

    ​var CustomFormController = FormController.include({

  ​async saveButtonClicked(params = {}) {            

​alert("save works")            

​​const record = this.model.root;            

​​let saved = false;            

​​if (record.resModel === "res.partner" && record.data.email === "") {         

​​const confirmationDialogProps = {                   

​​body: this.env._t("¿Estás seguro de que deseas guardar este registro sin ​correo ​​electrónico?"),                    

​​ ​confirm: async () => {

​​if (this.props.saveRecord) {                            

​​saved = await this.props.saveRecord(record, params);                

​} else {                            

​saved = await record.save();                        

​​}                        

​​​if (saved && this.props.onSave) {                            

​​this.props.onSave(record, params);                        

​​​}                    

​​​},                    

​​cancel: () => {},                

​​​};                

​​​this.dialogService.add(ConfirmationDialog, confirmationDialogProps);            

​​} else { 

​​if (this.props.saveRecord) {                    

​​saved = await this.props.saveRecord(record, params);                

​​} else {                    

​​saved = await record.save();                

​​}                

​​if (saved && this.props.onSave) {                    

​​this.props.onSave(record, params);                

​​}            

​​}            

​​return true;        

​},    

​});   

​console.log("finish");    

​return CustomFormController;

});


The script is executed because it shows me the alert and the console.log at the end but it doesn't overwrite the function because it doesn't show me the second alert("save works") and it doesn't have the behavior that I initially achieved by modifying the odoo file, I have already tried replacing "include" with "extend" but it still doesn't work. 

Does anyone know what I can do?


 




Awatar
Odrzuć
Najlepsza odpowiedź

Hi,

Try this : export default class CustomFormController extends FormController {

        async saveButtonClicked(params = {}) {            


alert("save works")            


const record = this.model.root;            


let saved = false;            


if (record.resModel === "res.partner" && record.data.email === "") {        


const confirmationDialogProps = {                  


body: this.env._t("¿Estás seguro de que deseas guardar este registro sin correo electrónico?"),                    


confirm: async () => {


if (this.props.saveRecord) {                            


saved = await this.props.saveRecord(record, params);                


} else {                            


saved = await record.save();                        


}                        


if (saved && this.props.onSave) {                            


this.props.onSave(record, params);                        


}                    


},                    


cancel: () => {},                


};                


this.dialogService.add(ConfirmationDialog, confirmationDialogProps);            


} else {


if (this.props.saveRecord) {                    


saved = await this.props.saveRecord(record, params);                


} else {                    


saved = await record.save();                


}                


if (saved && this.props.onSave) {                    


this.props.onSave(record, params);                


}            


}            


return true;        


},    


});    


console.log("finish");    


}


Hope it helps

Awatar
Odrzuć
Powiązane posty Odpowiedzi Widoki Czynność
3
cze 23
3057
1
maj 24
2140
1
wrz 23
2796
1
cze 23
4260
0
kwi 23
2254