Daniel Reis
11 years ago
12 changed files with 471 additions and 0 deletions
-
1base_optional_quick_create/AUTHORS.txt
-
20base_optional_quick_create/__init__.py
-
43base_optional_quick_create/__openerp__.py
-
60base_optional_quick_create/model.py
-
14base_optional_quick_create/model_view.xml
-
31dbfilter_from_header/__init__.py
-
52dbfilter_from_header/__openerp__.py
-
1email_template_template/__init__.py
-
96email_template_template/__openerp__.py
-
21email_template_template/model/__init__.py
-
61email_template_template/model/email_template.py
-
71email_template_template/view/email_template.xml
@ -0,0 +1 @@ |
|||
Lorenzo Battistini <lorenzo.battistini@agilebg.com> |
@ -0,0 +1,20 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# Copyright (C) 2013 Agile Business Group sagl (<http://www.agilebg.com>) |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as published |
|||
# by the Free Software Foundation, either version 3 of the License, or |
|||
# (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
import model |
@ -0,0 +1,43 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# Copyright (C) 2013 Agile Business Group sagl (<http://www.agilebg.com>) |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as published |
|||
# by the Free Software Foundation, either version 3 of the License, or |
|||
# (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
|
|||
{ |
|||
'name': "Optional quick create", |
|||
'version': '0.1', |
|||
'category': 'Tools', |
|||
'description': """ |
|||
This module allows to avoid to 'quick create' new records, through many2one fields, for a specific model. |
|||
You can configure which models should allow 'quick create'. When specified, the 'quick create' option will always open the standard create form. |
|||
|
|||
Got the idea from https://twitter.com/nbessi/status/337869826028605441 |
|||
""", |
|||
'author': 'Agile Business Group', |
|||
'website': 'http://www.agilebg.com', |
|||
'license': 'AGPL-3', |
|||
"depends": ['base'], |
|||
"data": [ |
|||
'model_view.xml', |
|||
], |
|||
"demo": [], |
|||
'test': [ |
|||
], |
|||
"active": False, |
|||
"installable": True |
|||
} |
@ -0,0 +1,60 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# Copyright (C) 2013 Agile Business Group sagl (<http://www.agilebg.com>) |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as published |
|||
# by the Free Software Foundation, either version 3 of the License, or |
|||
# (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
|
|||
from openerp.osv import orm, fields |
|||
from openerp import SUPERUSER_ID |
|||
from openerp.tools.translate import _ |
|||
|
|||
class ir_model(orm.Model): |
|||
|
|||
_inherit = 'ir.model' |
|||
|
|||
_columns = { |
|||
'avoid_quick_create': fields.boolean('Avoid quick create'), |
|||
} |
|||
|
|||
def _wrap_name_create(self, old_create, model): |
|||
def wrapper(cr, uid, name, context=None): |
|||
raise orm.except_orm(_('Error'), _("Can't create quickly. Opening create form")) |
|||
return wrapper |
|||
|
|||
def _register_hook(self, cr, ids=None): |
|||
if ids is None: |
|||
ids = self.search(cr, SUPERUSER_ID, []) |
|||
for model in self.browse(cr, SUPERUSER_ID, ids): |
|||
if model.avoid_quick_create: |
|||
model_name = model.model |
|||
model_obj = self.pool.get(model_name) |
|||
if not hasattr(model_obj, 'check_quick_create'): |
|||
model_obj.name_create = self._wrap_name_create(model_obj.name_create, model_name) |
|||
model_obj.check_quick_create = True |
|||
return True |
|||
|
|||
def create(self, cr, uid, vals, context=None): |
|||
res_id = super(ir_model, self).create(cr, uid, vals, context=context) |
|||
self._register_hook(cr, [res_id]) |
|||
return res_id |
|||
|
|||
def write(self, cr, uid, ids, vals, context=None): |
|||
if isinstance(ids, (int, long)): |
|||
ids = [ids] |
|||
super(ir_model, self).write(cr, uid, ids, vals, context=context) |
|||
self._register_hook(cr, ids) |
|||
return True |
@ -0,0 +1,14 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<openerp> |
|||
<data> |
|||
<record id="view_model_form" model="ir.ui.view"> |
|||
<field name="model">ir.model</field> |
|||
<field name="inherit_id" ref="base.view_model_form"></field> |
|||
<field name="arch" type="xml"> |
|||
<field name="osv_memory" position="after"> |
|||
<field name="avoid_quick_create"></field> |
|||
</field> |
|||
</field> |
|||
</record> |
|||
</data> |
|||
</openerp> |
@ -0,0 +1,31 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
import re |
|||
from openerp.addons.web.controllers import main as web_main |
|||
|
|||
db_list_org = web_main.db_list |
|||
|
|||
def db_list(req, force=False): |
|||
db_filter = req.httprequest.environ.get('HTTP_X_OPENERP_DBFILTER', '.*') |
|||
dbs = db_list_org(req, force=force) |
|||
return [db for db in dbs if re.match(db_filter, db)] |
|||
|
|||
web_main.db_list = db_list |
@ -0,0 +1,52 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
{ |
|||
"name" : "dbfilter_from_header", |
|||
"version" : "1.0", |
|||
"author" : "Therp BV", |
|||
"complexity": "normal", |
|||
"description": """ |
|||
This addon lets you pass a dbfilter as a HTTP header. |
|||
|
|||
This is interesting for setups where database names can't be mapped to |
|||
proxied host names. |
|||
|
|||
In nginx, use |
|||
proxy_set_header X-OpenERP-dbfilter [your filter]; |
|||
|
|||
The addon has to be loaded as server-wide module. |
|||
""", |
|||
"category" : "Tools", |
|||
"depends" : [ |
|||
'web', |
|||
], |
|||
"data" : [ |
|||
], |
|||
"js": [ |
|||
], |
|||
"css": [ |
|||
], |
|||
"auto_install": False, |
|||
"installable": True, |
|||
"external_dependencies" : { |
|||
'python' : [], |
|||
}, |
|||
} |
@ -0,0 +1 @@ |
|||
import model |
@ -0,0 +1,96 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
{ |
|||
"name": "Templates for email templates", |
|||
"version": "1.0", |
|||
"author": "Therp BV", |
|||
"category": 'Tools', |
|||
'complexity': "expert", |
|||
"description": """If an organisation's email layout is a bit more |
|||
complicated, changes can be tedious when having to do that across several email |
|||
templates. So this addon allows to define templates for mails that is referenced |
|||
by other mail templates. |
|||
This way we can put the layout parts into the template template and only content |
|||
in the other templates. Changing the layout is then only a matter of changing |
|||
the template template. |
|||
|
|||
|
|||
Usage: |
|||
Create an email template with the related document model 'Email Templates'. Now |
|||
most of the fields gray out and you can only edit body_text and body_html. Be |
|||
sure to use ${body_text} and ${body_html} respectively in your template |
|||
template. |
|||
|
|||
Then select this newly created template templates in one of your actual |
|||
templates. |
|||
|
|||
For example, create a template template |
|||
----- |
|||
Example Corp logo |
|||
Example Corp header |
|||
${object.body_text} <- this gets evaluated to the body_text of a template using this template template |
|||
Example Corp |
|||
Example street 42 |
|||
Example city |
|||
Example Corp footer |
|||
----- |
|||
|
|||
Then in your template you write |
|||
|
|||
----- |
|||
Dear ${object.partner_id.name}, |
|||
|
|||
Your order has been booked on date ${object.date} for a total amount of ${object.sum}. |
|||
----- |
|||
|
|||
And it will be evaluated to |
|||
|
|||
----- |
|||
Example Corp logo |
|||
Example Corp header |
|||
Dear Jane Doe, |
|||
|
|||
Your order has been booked on date 04/17/2013 for a total amount of 42. |
|||
Example Corp |
|||
Example street 42 |
|||
Example city |
|||
Example Corp footer |
|||
----- |
|||
|
|||
Given the way evaluation works internally (body_text of the template template is evaluated two times, first with the instance of email.template of your own template, then with the object your template refers to), you can do some trickery if you know that a template template is always used with the same kind of model (that is, models that have the same field name): |
|||
|
|||
In your template template: |
|||
|
|||
------ |
|||
Dear ${'${object.name}'}, <-- gets evaluated to "${object.name}" in the first step, then to the content of object.name |
|||
${object.body_html} |
|||
Best, |
|||
Example Corp |
|||
------""", |
|||
'website': 'http://therp.nl', |
|||
'images': [], |
|||
'depends': ['email_template'], |
|||
'data': [ |
|||
'view/email_template.xml', |
|||
], |
|||
"license": 'AGPL-3', |
|||
} |
|||
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: |
@ -0,0 +1,21 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
import email_template |
@ -0,0 +1,61 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
from openerp.osv.orm import Model |
|||
from openerp.osv import fields |
|||
from openerp.addons.email_template.email_template import mako_template_env |
|||
|
|||
|
|||
class email_template(Model): |
|||
_inherit = 'email.template' |
|||
|
|||
def _get_is_template_template(self, cr, uid, ids, fields_name, arg, |
|||
context=None): |
|||
cr.execute('''select |
|||
id, (select count(*) > 0 from email_template e |
|||
where email_template_id=email_template.id) |
|||
from email_template |
|||
where id in %s''', (tuple(ids),)) |
|||
return dict(cr.fetchall()) |
|||
|
|||
_columns = { |
|||
'email_template_id': fields.many2one('email.template', 'Template'), |
|||
'is_template_template': fields.function( |
|||
_get_is_template_template, type='boolean', |
|||
string='Is a template template'), |
|||
} |
|||
|
|||
def get_email_template(self, cr, uid, template_id=False, record_id=None, |
|||
context=None): |
|||
this = super(email_template, self).get_email_template( |
|||
cr, uid, template_id, record_id, context) |
|||
|
|||
if this.email_template_id and not this.is_template_template: |
|||
for field in ['body_html']: |
|||
if this[field] and this.email_template_id[field]: |
|||
try: |
|||
mako_template_env.autoescape = False |
|||
this._data[this.id][field] = self.render_template( |
|||
cr, uid, this.email_template_id[field], |
|||
this.email_template_id.model, |
|||
this.id, this._context) |
|||
finally: |
|||
mako_template_env.autoescape = True |
|||
return this |
@ -0,0 +1,71 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<openerp> |
|||
<data> |
|||
<record id="email_template_form" model="ir.ui.view"> |
|||
<field name="name">email.template.form</field> |
|||
<field name="model">email.template</field> |
|||
<field name="inherit_id" ref="email_template.email_template_form" /> |
|||
<field name="type">form</field> |
|||
<field name="arch" type="xml"> |
|||
<data> |
|||
<field name="name" position="after"> |
|||
<field name="is_template_template" invisible="1" /> |
|||
<field name="email_template_id" domain="[('email_template_id', '=', False), ('model_id', '=', %(email_template.model_email_template)s)]" |
|||
attrs="{'readonly': [('is_template_template','=',True), ('email_template_id','=',False)]}" |
|||
context="{'default_model_id': %(email_template.model_email_template)s}" |
|||
/> |
|||
|
|||
</field> |
|||
<field name="model_id" position="attributes"> |
|||
<attribute name="attrs"> |
|||
{'readonly': [('is_template_template','=',True)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="email_from" position="attributes"> |
|||
<attribute name="required">0</attribute> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="email_to" position="attributes"> |
|||
<attribute name="required">0</attribute> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="email_cc" position="attributes"> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="email_recipients" position="attributes"> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="reply_to" position="attributes"> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="lang" position="attributes"> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="user_signature" position="attributes"> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
<field name="subject" position="attributes"> |
|||
<attribute name="required">0</attribute> |
|||
<attribute name="attrs"> |
|||
{'readonly': ['|',('is_template_template','=',True),('model_id', '=', %(email_template.model_email_template)s)]} |
|||
</attribute> |
|||
</field> |
|||
</data> |
|||
</field> |
|||
</record> |
|||
</data> |
|||
</openerp> |
Write
Preview
Loading…
Cancel
Save
Reference in new issue