Merge branch '10.0' of github.com:akretion/odoo-usability into 10.0
This commit is contained in:
@@ -23,6 +23,8 @@ This module has been written by Alexis de Lattre from Akretion <alexis.delattre@
|
|||||||
'depends': [
|
'depends': [
|
||||||
'account_financial_report_qweb',
|
'account_financial_report_qweb',
|
||||||
],
|
],
|
||||||
'data': [],
|
'data': [
|
||||||
|
'views/reports.xml',
|
||||||
|
'views/layouts.xml',],
|
||||||
'installable': True,
|
'installable': True,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,3 @@
|
|||||||
|
.list_table, .data_table, .totals_table, .list_table .act_as_row {
|
||||||
|
font-size:15px;
|
||||||
|
}
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<odoo>
|
||||||
|
<template id="assets_specific" inherit_id="account_financial_report_qweb.assets_specific">
|
||||||
|
<xpath expr="." position="inside">
|
||||||
|
<link href="/account_financial_report_qweb_usability/static/src/css/reports.css" rel="stylesheet"/>
|
||||||
|
</xpath>
|
||||||
|
</template>
|
||||||
|
</odoo>
|
||||||
32
account_financial_report_qweb_usability/views/reports.xml
Normal file
32
account_financial_report_qweb_usability/views/reports.xml
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
<record id="report_qweb_paperformat_horizontal" model="report.paperformat">
|
||||||
|
<field name="name">Account financial report qweb horizontal paperformat</field>
|
||||||
|
<field name="default" eval="True"/>
|
||||||
|
<field name="format">custom</field>
|
||||||
|
<field name="page_height">297</field>
|
||||||
|
<field name="page_width">210</field>
|
||||||
|
<field name="orientation">Landscape</field>
|
||||||
|
<field name="margin_top">12</field>
|
||||||
|
<field name="margin_bottom">8</field>
|
||||||
|
<field name="margin_left">5</field>
|
||||||
|
<field name="margin_right">5</field>
|
||||||
|
<field name="header_line" eval="False"/>
|
||||||
|
<field name="header_spacing">10</field>
|
||||||
|
<field name="dpi">110</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="account_financial_report_qweb.action_report_general_ledger_qweb" model="ir.actions.report.xml">
|
||||||
|
<field name="paperformat_id" ref="report_qweb_paperformat_horizontal"/>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="account_financial_report_qweb.action_report_journal_qweb" model="ir.actions.report.xml">
|
||||||
|
<field name="paperformat_id" ref="report_qweb_paperformat_horizontal"/>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="account_financial_report_qweb.action_report_open_items_qweb" model="ir.actions.report.xml">
|
||||||
|
<field name="paperformat_id" ref="report_qweb_paperformat_horizontal"/>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
</odoo>
|
||||||
1
link_tracker_usability/__init__.py
Normal file
1
link_tracker_usability/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
28
link_tracker_usability/__manifest__.py
Normal file
28
link_tracker_usability/__manifest__.py
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright 2019 Akretion (http://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
{
|
||||||
|
'name': 'Link Tracker Usability',
|
||||||
|
'version': '10.0.1.0.0',
|
||||||
|
'category': 'Marketing',
|
||||||
|
'license': 'AGPL-3',
|
||||||
|
'summary': 'Improve usability for link tracker',
|
||||||
|
'description': """
|
||||||
|
Link Tracker Usability
|
||||||
|
======================
|
||||||
|
|
||||||
|
Several small usability improvements.
|
||||||
|
|
||||||
|
This module has been written by Alexis de Lattre from Akretion
|
||||||
|
<alexis.delattre@akretion.com>.
|
||||||
|
""",
|
||||||
|
'author': 'Akretion',
|
||||||
|
'website': 'http://www.akretion.com',
|
||||||
|
'depends': ['link_tracker'],
|
||||||
|
'data': [
|
||||||
|
'link_tracker_view.xml',
|
||||||
|
],
|
||||||
|
'installable': True,
|
||||||
|
}
|
||||||
54
link_tracker_usability/link_tracker_view.xml
Normal file
54
link_tracker_usability/link_tracker_view.xml
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright 2019 Akretion (http://www.akretion.com/)
|
||||||
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
-->
|
||||||
|
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
|
||||||
|
<record id="link_tracker.action_view_click_statistics" model="ir.actions.act_window">
|
||||||
|
<field name="view_mode">graph,tree,form</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="view_link_tracker_click_tree" model="ir.ui.view">
|
||||||
|
<field name="name">usability.link.tracker.click.tree</field>
|
||||||
|
<field name="model">link.tracker.click</field>
|
||||||
|
<field name="inherit_id" ref="link_tracker.view_link_tracker_click_tree"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="country_id" position="after">
|
||||||
|
<field name="create_date" string="Click Date"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="view_link_tracker_click_form" model="ir.ui.view">
|
||||||
|
<field name="name">usability.link.tracker.click.form</field>
|
||||||
|
<field name="model">link.tracker.click</field>
|
||||||
|
<field name="inherit_id" ref="link_tracker.view_link_tracker_click_form"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="country_id" position="after">
|
||||||
|
<field name="create_date" string="Click Date"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<!-- There is no native search form -->
|
||||||
|
<record id="link_tracker_click_search" model="ir.ui.view">
|
||||||
|
<field name="name">usability.link.tracker.click.search</field>
|
||||||
|
<field name="model">link.tracker.click</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<search>
|
||||||
|
<field name="link_id"/>
|
||||||
|
<group name="groupby">
|
||||||
|
<filter name="create_date_groupby" string="Click Date" context="{'group_by': 'create_date'}"/>
|
||||||
|
<filter name="link_groupby" string="Link" context="{'group_by': 'link_id'}"/>
|
||||||
|
<filter name="country_groupby" string="Country" context="{'group_by': 'country_id'}"/>
|
||||||
|
</group>
|
||||||
|
</search>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
|
||||||
|
</odoo>
|
||||||
@@ -14,6 +14,7 @@ class ResPartner(models.Model):
|
|||||||
selection_add=[
|
selection_add=[
|
||||||
('all_except_notification', 'All Messages Except Notifications')],
|
('all_except_notification', 'All Messages Except Notifications')],
|
||||||
default='all_except_notification')
|
default='all_except_notification')
|
||||||
|
opt_out = fields.Boolean(track_visibility='onchange')
|
||||||
|
|
||||||
def _should_be_notify_by_email(self, message):
|
def _should_be_notify_by_email(self, message):
|
||||||
if message.message_type == 'notification':
|
if message.message_type == 'notification':
|
||||||
|
|||||||
4
mass_mailing_usability/__init__.py
Normal file
4
mass_mailing_usability/__init__.py
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
from . import mail_mail_statistics
|
||||||
|
from . import link_tracker
|
||||||
30
mass_mailing_usability/__manifest__.py
Normal file
30
mass_mailing_usability/__manifest__.py
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright 2019 Akretion (http://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
{
|
||||||
|
'name': 'Mass Mailing Campaigns Usability',
|
||||||
|
'version': '10.0.1.0.0',
|
||||||
|
'category': 'Marketing',
|
||||||
|
'license': 'AGPL-3',
|
||||||
|
'summary': 'Improve usability of mass mailing campaigns',
|
||||||
|
'description': """
|
||||||
|
Mass Mailing Campaigns Usability
|
||||||
|
================================
|
||||||
|
|
||||||
|
Several small usability improvements on the module mass_mailing:
|
||||||
|
|
||||||
|
* show fields on link.tracker.click that are not displayed by default
|
||||||
|
|
||||||
|
This module has been written by Alexis de Lattre from Akretion
|
||||||
|
<alexis.delattre@akretion.com>.
|
||||||
|
""",
|
||||||
|
'author': 'Akretion',
|
||||||
|
'website': 'http://www.akretion.com',
|
||||||
|
'depends': ['mass_mailing'],
|
||||||
|
'data': [
|
||||||
|
'link_tracker_view.xml',
|
||||||
|
],
|
||||||
|
'installable': True,
|
||||||
|
}
|
||||||
14
mass_mailing_usability/link_tracker.py
Normal file
14
mass_mailing_usability/link_tracker.py
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright 2019 Akretion (http://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
|
||||||
|
from odoo import fields, models
|
||||||
|
|
||||||
|
|
||||||
|
class LinkTrackerClick(models.Model):
|
||||||
|
_inherit = 'link.tracker.click'
|
||||||
|
|
||||||
|
mail_stat_recipient = fields.Char(
|
||||||
|
related='mail_stat_id.recipient', store=True)
|
||||||
48
mass_mailing_usability/link_tracker_view.xml
Normal file
48
mass_mailing_usability/link_tracker_view.xml
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright 2019 Akretion (http://www.akretion.com/)
|
||||||
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
-->
|
||||||
|
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
|
||||||
|
<record id="view_link_tracker_click_tree" model="ir.ui.view">
|
||||||
|
<field name="name">mm.usability.link.tracker.click.tree</field>
|
||||||
|
<field name="model">link.tracker.click</field>
|
||||||
|
<field name="inherit_id" ref="link_tracker.view_link_tracker_click_tree"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="country_id" position="after">
|
||||||
|
<field name="mass_mailing_id"/>
|
||||||
|
<field name="mail_stat_recipient"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="view_link_tracker_click_form" model="ir.ui.view">
|
||||||
|
<field name="name">mm.usability.link.tracker.click.form</field>
|
||||||
|
<field name="model">link.tracker.click</field>
|
||||||
|
<field name="inherit_id" ref="link_tracker.view_link_tracker_click_form"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="country_id" position="after">
|
||||||
|
<field name="mass_mailing_id"/>
|
||||||
|
<field name="mass_mailing_campaign_id"/>
|
||||||
|
<field name="mail_stat_id"/>
|
||||||
|
<field name="mail_stat_recipient"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="link_tracker_click_search" model="ir.ui.view">
|
||||||
|
<field name="name">mm.usability.link.tracker.click.search</field>
|
||||||
|
<field name="model">link.tracker.click</field>
|
||||||
|
<field name="inherit_id" ref="link_tracker_usability.link_tracker_click_search"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="link_id" position="after">
|
||||||
|
<field name="mail_stat_recipient"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
</odoo>
|
||||||
18
mass_mailing_usability/mail_mail_statistics.py
Normal file
18
mass_mailing_usability/mail_mail_statistics.py
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright 2019 Akretion (http://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
|
||||||
|
from odoo import api, fields, models
|
||||||
|
|
||||||
|
|
||||||
|
class MailMailStatistics(models.Model):
|
||||||
|
_inherit = 'mail.mail.statistics'
|
||||||
|
|
||||||
|
recipient = fields.Char(store=True)
|
||||||
|
|
||||||
|
# add invalidation for 'recipient' field
|
||||||
|
@api.depends('res_id', 'model')
|
||||||
|
def _compute_recipient(self):
|
||||||
|
return super(MailMailStatistics, self)._compute_recipient()
|
||||||
@@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
|
|
||||||
<menuitem id="product_template_special_context_menu"
|
<menuitem id="product_template_special_context_menu"
|
||||||
action="product_template_special_context_action" parent="product.prod_config_main"
|
action="product_template_special_context_action" parent="sale.prod_config_main"
|
||||||
groups="base.group_no_one" sequence="100"/>
|
groups="base.group_no_one" sequence="100"/>
|
||||||
|
|
||||||
</data>
|
</data>
|
||||||
|
|||||||
@@ -353,7 +353,7 @@ should be able to access it. So I add a menu entry under Inventory Control. -->
|
|||||||
<!-- Add shortcut to inventory lines on product form -->
|
<!-- Add shortcut to inventory lines on product form -->
|
||||||
<act_window
|
<act_window
|
||||||
id="product_product_stock_inventory_line_action"
|
id="product_product_stock_inventory_line_action"
|
||||||
name="Show Inventory Lines"
|
name="Inventory Lines"
|
||||||
context="{'search_default_product_id': [active_id], 'stock_inventory_line_main_view': True}"
|
context="{'search_default_product_id': [active_id], 'stock_inventory_line_main_view': True}"
|
||||||
res_model="stock.inventory.line"
|
res_model="stock.inventory.line"
|
||||||
src_model="product.product"
|
src_model="product.product"
|
||||||
|
|||||||
Reference in New Issue
Block a user