我可以在点击时禁用日历视图中的quick_add,但它会打开“表单视图”,用户可以创建任务。
我的代码段如下
<!-- Calendar View Begins-->
<record id="pms_view_task_calendar" model="ir.ui.view">
<field name="name">project.task.calendar</field>
<field name="model">project.task</field>
<field name="inherit_id" ref="project.view_task_calendar"/>
<field name="arch" type="xml">
<calendar position="attributes">
<attribute name="quick_add">false</attribute>
</calendar>
</field>
</record>
<!-- Calendar View Ends-->
如何在点击日历时禁用日历视图中的创建选项
答案 0 :(得分:3)
最后,我通过继承JS来从日历视图中删除了创建选项。
odoo.define('module_name.calender_view', function (require) {
"use strict";
var calenderView = require('web_calendar.CalendarView');
calenderView.include({
open_quick_create: function(){
if (this.model != 'model.name') {
this._super();
}
}
});
});
答案 1 :(得分:1)
Odoo 11的更新以及如何使日历视图对于特定模型完全只读:
JS文件:
odoo.define('your_module.CalendarView', function (require) {
"use strict";
var CalendarView = require('web.CalendarView');
CalendarView.include({
init: function (viewInfo, params) {
this._super.apply(this, arguments);
if (this.controllerParams.modelName == 'your.model.name') {
this.loadParams.editable = false;
this.loadParams.creatable = false;
}
},
});
return CalendarView;
});
并且不要忘记通过您的xml“包含” js:
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<template id="assets_backend" name="handling assets" inherit_id="web.assets_backend">
<xpath expr="." position="inside">
<script type="text/javascript" src="/your_module/static/src/js/your_javascript_file_name.js"/>
</xpath>
</template>
</odoo>
答案 2 :(得分:0)
Vigneshwaran's回答很有效。 我修改了他的答案来设置多个模型。
var calenderView = require('web_calendar.CalendarView');
calenderView.include({
open_quick_create: function(){
var calendar_models = ['project.task', 'sale.order', 'crm.lead'];
if (!(calendar_models.includes(this.model))) {
this._super();
}
}
});