mirror of https://github.com/OCA/social.git
[FIX] pre-commit run -a
parent
32dcec55c7
commit
c8849785d5
|
@ -12,38 +12,57 @@
|
|||
<field name="arch" type="xml">
|
||||
<form string="Activity Form" create="false" edit="false" delete="false">
|
||||
<sheet string="Activity">
|
||||
<button name="open_origin" type="object" class="centre oe_link" nolabel="1">
|
||||
<h1><field name="res_name"/></h1>
|
||||
<button
|
||||
name="open_origin"
|
||||
type="object"
|
||||
class="centre oe_link"
|
||||
nolabel="1"
|
||||
>
|
||||
<h1><field name="res_name" /></h1>
|
||||
</button>
|
||||
<field name="activity_category" invisible="1" />
|
||||
<field name="res_model" invisible="1"/>
|
||||
<field name="res_model_id" invisible="1"/>
|
||||
<field name="res_id" invisible="1"/>
|
||||
<field name="res_model" invisible="1" />
|
||||
<field name="res_model_id" invisible="1" />
|
||||
<field name="res_id" invisible="1" />
|
||||
<group>
|
||||
<group>
|
||||
<field name="activity_type_id" required="1" options="{'no_create': True, 'no_open': True}"/>
|
||||
<field name="res_model_id_name"/>
|
||||
<field name="calendar_event_id" invisible="1"/>
|
||||
<field name="create_date" invisible="1"/>
|
||||
<field
|
||||
name="activity_type_id"
|
||||
required="1"
|
||||
options="{'no_create': True, 'no_open': True}"
|
||||
/>
|
||||
<field name="res_model_id_name" />
|
||||
<field name="calendar_event_id" invisible="1" />
|
||||
<field name="create_date" invisible="1" />
|
||||
</group>
|
||||
<group>
|
||||
<field name="date_deadline"
|
||||
attrs="{'invisible': [('activity_category', '=', 'meeting')]}"/>
|
||||
<field name="calendar_event_id_start" string="Start meeting"
|
||||
attrs="{'invisible': [('calendar_event_id','=', False)]}"/>
|
||||
<field name="duration" widget="float_time"
|
||||
attrs="{'invisible': ['|',('duration', '=', False),
|
||||
('calendar_event_id','=', False)]}"/>
|
||||
<field name="user_id" options="{'no_open': True}"/>
|
||||
<field
|
||||
name="date_deadline"
|
||||
attrs="{'invisible': [('activity_category', '=', 'meeting')]}"
|
||||
/>
|
||||
<field
|
||||
name="calendar_event_id_start"
|
||||
string="Start meeting"
|
||||
attrs="{'invisible': [('calendar_event_id','=', False)]}"
|
||||
/>
|
||||
<field
|
||||
name="duration"
|
||||
widget="float_time"
|
||||
attrs="{'invisible': ['|',('duration', '=', False),
|
||||
('calendar_event_id','=', False)]}"
|
||||
/>
|
||||
<field name="user_id" options="{'no_open': True}" />
|
||||
|
||||
</group>
|
||||
</group>
|
||||
<group attrs="{'invisible': ['|',('calendar_event_id','=', False),('calendar_event_id_partner_ids','=', False)]}">
|
||||
<field name="calendar_event_id_partner_ids" mode="kanban"/>
|
||||
<group
|
||||
attrs="{'invisible': ['|',('calendar_event_id','=', False),('calendar_event_id_partner_ids','=', False)]}"
|
||||
>
|
||||
<field name="calendar_event_id_partner_ids" mode="kanban" />
|
||||
</group>
|
||||
<group>
|
||||
<field name="summary" placeholder="e.g. Discuss proposal"/>
|
||||
<field name="note" placeholder="Log a note..."/>
|
||||
<field name="summary" placeholder="e.g. Discuss proposal" />
|
||||
<field name="note" placeholder="Log a note..." />
|
||||
</group>
|
||||
</sheet>
|
||||
</form>
|
||||
|
@ -55,13 +74,19 @@
|
|||
<record id="mail_activity_view_tree" model="ir.ui.view">
|
||||
<field name="name">mail.activity.boards.view.tree</field>
|
||||
<field name="model">mail.activity</field>
|
||||
<field name="inherit_id" ref="mail.mail_activity_view_tree"/>
|
||||
<field name="inherit_id" ref="mail.mail_activity_view_tree" />
|
||||
<field name="arch" type="xml">
|
||||
<xpath expr="//tree" position="attributes">
|
||||
<attribute name="default_order"/>
|
||||
<attribute name="decoration-danger">(date_deadline < current_date)</attribute>
|
||||
<attribute name="decoration-warning">(date_deadline == current_date)</attribute>
|
||||
<attribute name="decoration-success">(date_deadline > current_date)</attribute>
|
||||
<attribute name="default_order" />
|
||||
<attribute
|
||||
name="decoration-danger"
|
||||
>(date_deadline < current_date)</attribute>
|
||||
<attribute
|
||||
name="decoration-warning"
|
||||
>(date_deadline == current_date)</attribute>
|
||||
<attribute
|
||||
name="decoration-success"
|
||||
>(date_deadline > current_date)</attribute>
|
||||
</xpath>
|
||||
|
||||
</field>
|
||||
|
@ -72,66 +97,103 @@
|
|||
<record id="mail_activity_view_kanban" model="ir.ui.view">
|
||||
<field name="name">mail.activity.boards.view.kanban</field>
|
||||
<field name="model">mail.activity</field>
|
||||
<field name="priority" eval="10"/>
|
||||
<field name="priority" eval="10" />
|
||||
<field name="arch" type="xml">
|
||||
<kanban default_group_by="activity_type_id" class="_kanban_small_column o_opportunity_kanban" create="0" _order="date_deadline"
|
||||
group_create="false" group_delete="false" group_edit="false">
|
||||
<field name="user_id"/>
|
||||
<field name="res_id"/>
|
||||
<field name="res_name"/>
|
||||
<field name="res_model"/>
|
||||
<field name="summary"/>
|
||||
<field name="date_deadline"/>
|
||||
<field name="state"/>
|
||||
<field name="icon"/>
|
||||
<field name="activity_type_id"/>
|
||||
<field name="activity_category"/>
|
||||
<kanban
|
||||
default_group_by="activity_type_id"
|
||||
class="_kanban_small_column o_opportunity_kanban"
|
||||
create="0"
|
||||
_order="date_deadline"
|
||||
group_create="false"
|
||||
group_delete="false"
|
||||
group_edit="false"
|
||||
>
|
||||
<field name="user_id" />
|
||||
<field name="res_id" />
|
||||
<field name="res_name" />
|
||||
<field name="res_model" />
|
||||
<field name="summary" />
|
||||
<field name="date_deadline" />
|
||||
<field name="state" />
|
||||
<field name="icon" />
|
||||
<field name="activity_type_id" />
|
||||
<field name="activity_category" />
|
||||
<templates>
|
||||
<t t-name="kanban-box">
|
||||
<div t-attf-class="oe_kanban_content oe_kanban_global_click">
|
||||
<div class="oe_kanban_content">
|
||||
<div>
|
||||
<strong class="o_kanban_record_subtitle">
|
||||
<span t-attf-class="fa #{record.icon.raw_value}" />
|
||||
<field name="summary"/>
|
||||
<span
|
||||
t-attf-class="fa #{record.icon.raw_value}"
|
||||
/>
|
||||
<field name="summary" />
|
||||
</strong>
|
||||
</div>
|
||||
<div>
|
||||
<strong class="o_kanban_record_title"><field name="res_name"/></strong>
|
||||
<strong class="o_kanban_record_title"><field
|
||||
name="res_name"
|
||||
/></strong>
|
||||
</div>
|
||||
|
||||
<div class="o_kanban_record_bottom">
|
||||
<div class="oe_kanban_bottom_left">
|
||||
<t t-set="act_date" t-value="new Date(record.date_deadline.raw_value)"/>
|
||||
<t
|
||||
t-set="act_date"
|
||||
t-value="new Date(record.date_deadline.raw_value)"
|
||||
/>
|
||||
<t t-if="act_date < (new Date())">
|
||||
<span t-attf-class="text-danger"><i class="fa fa-clock-o"/></span>
|
||||
<t t-if="record.activity_category.raw_value!='meeting'">
|
||||
<span t-attf-class="text-danger"><i
|
||||
class="fa fa-clock-o"
|
||||
/></span>
|
||||
<t
|
||||
t-if="record.activity_category.raw_value!='meeting'"
|
||||
>
|
||||
<span t-attf-class="text-danger">
|
||||
<field name="date_deadline" t-options='{"widget": "date"}'/>
|
||||
<field
|
||||
name="date_deadline"
|
||||
t-options='{"widget": "date"}'
|
||||
/>
|
||||
</span>
|
||||
</t>
|
||||
<t t-else="">
|
||||
<span t-attf-class="text-danger">
|
||||
<field name="calendar_event_id_start" t-options='{"widget": "date"}'/>
|
||||
<field
|
||||
name="calendar_event_id_start"
|
||||
t-options='{"widget": "date"}'
|
||||
/>
|
||||
</span>
|
||||
</t>
|
||||
</t>
|
||||
<t t-else="">
|
||||
<span><i class="fa fa-clock-o"/></span>
|
||||
<t t-if="record.activity_category.raw_value!='meeting'">
|
||||
<span><i class="fa fa-clock-o" /></span>
|
||||
<t
|
||||
t-if="record.activity_category.raw_value!='meeting'"
|
||||
>
|
||||
<span>
|
||||
<field name="date_deadline" t-options='{"widget": "date"}'/>
|
||||
<field
|
||||
name="date_deadline"
|
||||
t-options='{"widget": "date"}'
|
||||
/>
|
||||
</span>
|
||||
</t>
|
||||
<t t-else="">
|
||||
<field name="calendar_event_id_start" t-options='{"widget": "date"}'/>
|
||||
<field
|
||||
name="calendar_event_id_start"
|
||||
t-options='{"widget": "date"}'
|
||||
/>
|
||||
</t>
|
||||
</t>
|
||||
</div>
|
||||
<div class="oe_kanban_bottom_right">
|
||||
<img t-att-src="kanban_image('res.users', 'image_small', record.user_id.raw_value)"
|
||||
t-att-title="record.user_id.value"
|
||||
t-att-alt="record.user_id.value" width="24" height="24" class="oe_kanban_avatar"/>
|
||||
<img
|
||||
t-att-src="kanban_image('res.users', 'image_small', record.user_id.raw_value)"
|
||||
t-att-title="record.user_id.value"
|
||||
t-att-alt="record.user_id.value"
|
||||
width="24"
|
||||
height="24"
|
||||
class="oe_kanban_avatar"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -147,28 +209,42 @@
|
|||
<record id="mail_activity_view_search" model="ir.ui.view">
|
||||
<field name="name">mail.activity.boards.view.search</field>
|
||||
<field name="model">mail.activity</field>
|
||||
<field name="inherit_id" ref="mail.mail_activity_view_search"/>
|
||||
<field name="priority" eval="2"/>
|
||||
<field name="inherit_id" ref="mail.mail_activity_view_search" />
|
||||
<field name="priority" eval="2" />
|
||||
<field name="mode">primary</field>
|
||||
<field name="arch" type="xml">
|
||||
<xpath expr='//field[@name="res_model_id"]' position='before'>
|
||||
<field name="user_id"/>
|
||||
<field name="res_name" string="Origin"/>
|
||||
<field name="user_id" />
|
||||
<field name="res_name" string="Origin" />
|
||||
</xpath>
|
||||
|
||||
<xpath expr='//filter[@name="activities_overdue"]' position='before'>
|
||||
<filter string="Act. next month" name="activities_month"
|
||||
domain="[('date_deadline', '<', (context_today()+datetime.timedelta(days=30)).strftime('%Y-%m-%d'))]"
|
||||
help="Show activities scheduled for next month."/>
|
||||
<filter string="Act. next 6 months" name="activities_6_month"
|
||||
domain="[('date_deadline', '<', (context_today()+datetime.timedelta(days=180)).strftime('%Y-%m-%d'))]"
|
||||
help="Show activities scheduled for next 6 months."/>
|
||||
<separator/>
|
||||
<filter
|
||||
string="Act. next month"
|
||||
name="activities_month"
|
||||
domain="[('date_deadline', '<', (context_today()+datetime.timedelta(days=30)).strftime('%Y-%m-%d'))]"
|
||||
help="Show activities scheduled for next month."
|
||||
/>
|
||||
<filter
|
||||
string="Act. next 6 months"
|
||||
name="activities_6_month"
|
||||
domain="[('date_deadline', '<', (context_today()+datetime.timedelta(days=180)).strftime('%Y-%m-%d'))]"
|
||||
help="Show activities scheduled for next 6 months."
|
||||
/>
|
||||
<separator />
|
||||
</xpath>
|
||||
|
||||
<xpath expr='//search/group' position='inside'>
|
||||
<filter string="User" name='assigned_user' context="{'group_by':'user_id'}"/>
|
||||
<filter string="Origin" name='origin' context="{'group_by': 'res_model_id'}"/>
|
||||
<filter
|
||||
string="User"
|
||||
name='assigned_user'
|
||||
context="{'group_by':'user_id'}"
|
||||
/>
|
||||
<filter
|
||||
string="Origin"
|
||||
name='origin'
|
||||
context="{'group_by': 'res_model_id'}"
|
||||
/>
|
||||
</xpath>
|
||||
|
||||
</field>
|
||||
|
@ -184,15 +260,17 @@
|
|||
<field name="view_mode">kanban,form</field>
|
||||
<field name="domain">[]</field>
|
||||
<field name="context">{}</field>
|
||||
<field name="view_ids"
|
||||
eval="[(5, 0, 0),
|
||||
<field
|
||||
name="view_ids"
|
||||
eval="[(5, 0, 0),
|
||||
(0, 0, {'view_mode': 'kanban', 'view_id': ref('mail_activity_view_kanban')}),
|
||||
(0, 0, {'view_mode': 'tree', 'view_id': ref('mail_activity_view_tree')}),
|
||||
(0, 0, {'view_mode': 'form', 'view_id': ref('mail_activity_view_form_board')}),
|
||||
(0, 0, {'view_mode': 'calendar'}),
|
||||
(0, 0, {'view_mode': 'pivot'}),
|
||||
(0, 0, {'view_mode': 'graph'})]"/>
|
||||
<field name="search_view_id" ref="mail_activity_view_search"/>
|
||||
(0, 0, {'view_mode': 'graph'})]"
|
||||
/>
|
||||
<field name="search_view_id" ref="mail_activity_view_search" />
|
||||
</record>
|
||||
|
||||
|
||||
|
@ -200,10 +278,11 @@
|
|||
Menus
|
||||
-->
|
||||
<menuitem
|
||||
id="board_menu_activities"
|
||||
name="Activities"
|
||||
parent="base.menu_board_root"
|
||||
action="open_boards_activities"
|
||||
sequence="1"/>
|
||||
id="board_menu_activities"
|
||||
name="Activities"
|
||||
parent="base.menu_board_root"
|
||||
action="open_boards_activities"
|
||||
sequence="1"
|
||||
/>
|
||||
|
||||
</odoo>
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<!-- Copyright 2014-2015 Grupo ESOC <http://www.grupoesoc.es>License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). -->
|
||||
<odoo>
|
||||
<record id="mail_message_view_form" model="ir.ui.view">
|
||||
|
@ -8,18 +8,18 @@
|
|||
<field name="arch" type="xml">
|
||||
<form string="Message">
|
||||
<group>
|
||||
<field name="author_id" readonly="1"/>
|
||||
<field name="email_from" readonly="1"/>
|
||||
<field name="date" readonly="1"/>
|
||||
<field name="partner_ids" readonly="1" widget="many2many_tags"/>
|
||||
<field name="author_id" readonly="1" />
|
||||
<field name="email_from" readonly="1" />
|
||||
<field name="date" readonly="1" />
|
||||
<field name="partner_ids" readonly="1" widget="many2many_tags" />
|
||||
</group>
|
||||
<h1>
|
||||
<field name="subject" readonly="1"/>
|
||||
<field name="subject" readonly="1" />
|
||||
</h1>
|
||||
<field name="body" readonly="1"/>
|
||||
<field name="attachment_ids" readonly="1" widget="many2many_binary"/>
|
||||
<field name="body" readonly="1" />
|
||||
<field name="attachment_ids" readonly="1" widget="many2many_binary" />
|
||||
<footer>
|
||||
<button class="btn-secondary" special="cancel" string="Close"/>
|
||||
<button class="btn-secondary" special="cancel" string="Close" />
|
||||
</footer>
|
||||
</form>
|
||||
</field>
|
||||
|
@ -28,7 +28,7 @@
|
|||
<field name="name">Read Full Email</field>
|
||||
<field name="res_model">mail.message</field>
|
||||
<field name="type">ir.actions.act_window</field>
|
||||
<field name="view_id" ref="mail_message_view_form"/>
|
||||
<field name="view_id" ref="mail_message_view_form" />
|
||||
<field name="view_mode">form</field>
|
||||
<field name="target">new</field>
|
||||
</record>
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<!-- Copyright 2016 Antonio Espinosa - <antonio.espinosa@tecnativa.com>
|
||||
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). -->
|
||||
<odoo>
|
||||
|
@ -7,26 +7,32 @@
|
|||
<field name="name">Partner Form with tracking emails</field>
|
||||
<field name="model">res.partner</field>
|
||||
<field name="priority">46</field>
|
||||
<field name="inherit_id" ref="base.view_partner_form"/>
|
||||
<field name="inherit_id" ref="base.view_partner_form" />
|
||||
<field name="arch" type="xml">
|
||||
<div name="button_box" position="inside">
|
||||
<button name="%(mail_tracking.action_view_mail_tracking_email)d"
|
||||
<button
|
||||
name="%(mail_tracking.action_view_mail_tracking_email)d"
|
||||
context="{'search_default_recipient': email,
|
||||
'default_recipient': email}"
|
||||
type="action"
|
||||
class="oe_stat_button"
|
||||
icon="fa-envelope-o"
|
||||
attrs="{'invisible': [('email', '=', False)]}">
|
||||
<field name="tracking_emails_count"
|
||||
widget="statinfo"
|
||||
string="Tracking emails"/>
|
||||
attrs="{'invisible': [('email', '=', False)]}"
|
||||
>
|
||||
<field
|
||||
name="tracking_emails_count"
|
||||
widget="statinfo"
|
||||
string="Tracking emails"
|
||||
/>
|
||||
</button>
|
||||
</div>
|
||||
<xpath expr="//field[@name='email']/.." position="after">
|
||||
<field name="email_score" widget="progressbar"
|
||||
attrs="{'invisible': [('email', '=', False)]}"/>
|
||||
<field name="email_bounced"
|
||||
attrs="{'invisible': [('email', '=', False)]}"/>
|
||||
<field
|
||||
name="email_score"
|
||||
widget="progressbar"
|
||||
attrs="{'invisible': [('email', '=', False)]}"
|
||||
/>
|
||||
<field name="email_bounced" attrs="{'invisible': [('email', '=', False)]}" />
|
||||
</xpath>
|
||||
</field>
|
||||
</record>
|
||||
|
@ -34,12 +40,15 @@
|
|||
<record model="ir.ui.view" id="view_res_partner_filter">
|
||||
<field name="name">Filter bounced partners</field>
|
||||
<field name="model">res.partner</field>
|
||||
<field name="inherit_id" ref="base.view_res_partner_filter"/>
|
||||
<field name="inherit_id" ref="base.view_res_partner_filter" />
|
||||
<field name="arch" type="xml">
|
||||
<filter name="type_company" position="after">
|
||||
<separator/>
|
||||
<filter string="Email bounced" name="email_bounced"
|
||||
domain="[('email', '!=' , False), ('email_bounced', '=', True)]"/>
|
||||
<separator />
|
||||
<filter
|
||||
string="Email bounced"
|
||||
name="email_bounced"
|
||||
domain="[('email', '!=' , False), ('email_bounced', '=', True)]"
|
||||
/>
|
||||
</filter>
|
||||
</field>
|
||||
</record>
|
||||
|
|
Loading…
Reference in New Issue