我正在尝试自定义calendar.event
模型的日历视图,其代码为:
<record id="view_calendar_event_calendar" model="ir.ui.view">
<field name="name">calendar.event.calendar</field>
<field name="model">calendar.event</field>
<field name="priority" eval="2"/>
<field name="arch" type="xml">
<calendar string="Meetings" date_start="start" date_stop="stop" date_delay="duration" all_day="allday"
display="[name]" color="color_partner_id" attendee="partner_ids" avatar_model="res.partner"
use_contacts="True" event_open_popup="%(calendar.view_calendar_event_form_popup)s">
<field name="name"/>
<field name="user_id"/>
<field name="color_partner_id"/>
<field name="partner_ids"/>
</calendar>
</field>
</record>
我想显示一些新字段并使背景颜色依赖于名为color_confirmed
的新字段。完美的方法是将日历视图中显示的看板替换为自定义的看板。 Odoo文档(https://www.odoo.com/documentation/11.0/reference/views.html#calendar)表示以下内容:
模板
定义QWeb模板日历框。为了清楚起见,卡的定义可以分为多个模板,每条记录将呈现一次。
看板视图使用大多数标准的javascript qweb并提供以下上下文变量:
...
我正在尝试使用该 templates 属性,但是我不知道如何使用,并且无法在已下载的所有可用模块中找到示例。我的尝试之一:
<record id="view_calendar_event_calendar" model="ir.ui.view">
<field name="name">calendar.event.calendar</field>
<field name="model">calendar.event</field>
<field name="inherit_id" ref="calendar.view_calendar_event_calendar"/>
<field name="arch" type="xml">
<xpath expr="//calendar[1]" position="replace">
<calendar string="Meetings" date_start="start" date_stop="stop" date_delay="duration"
all_day="allday" display="[color_confirmed]" color="color_confirmed" attendee="partner_ids"
avatar_model="res.partner" use_contacts="False" event_open_popup="%(calendar.view_calendar_event_form_popup)s" mode="month">
<field name="name"/>
<templates>
<t t-name="calendar-box">
<div class="oe_kanban_global_click">
<div class="oe_kanban_details">
<strong class="oe_partner_heading"><field name="name"/></strong>
<ul>
<li>TEST ITEM 1</li>
<li>TEST ITEM 2</li>
</ul>
</div>
</div>
</t>
</templates>
</calendar>
</xpath>
</field>
</record>
如预期的那样,它将引发JS错误。我已经尝试了几种方法,但在这样的一项任务上浪费了很多时间。有谁知道它是如何工作的? (或者是达到目的的更好方法)。