Browse Source

Merge pull request #366 from yelizariev/8.0-cleanup-2

commit is created by 👷‍♂️ Merge Bot: https://odoo-devops.readthedocs.io/en/latest/git/github-merge-bot.html
8.0
Mitchell Admin 3 years ago
committed by GitHub
parent
commit
69fb85f9dc
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 29
      mail_partner_lang/README.rst
  2. 2
      mail_partner_lang/__init__.py
  3. 13
      mail_partner_lang/__openerp__.py
  4. 4
      mail_partner_lang/doc/changelog.rst
  5. 13
      mail_partner_lang/doc/index.rst
  6. 88
      mail_partner_lang/models.py
  7. BIN
      mail_partner_lang/static/description/icon.png

29
mail_partner_lang/README.rst

@ -1,29 +0,0 @@
.. image:: https://itpp.dev/images/infinity-readme.png
:alt: Tested and maintained by IT Projects Labs
:target: https://itpp.dev
==============================
Use partner language in mail
==============================
FIXME: there is issue with frozen dict in new odoo.
Questions?
==========
To get an assistance on this module contact us by email :arrow_right: help@itpp.dev
Contributors
============
* `Ivan Yelizariev <https://it-projects.info/team/yelizariev>`__
The module is not maintained since Odoo 9.0.
Further information
===================
Odoo Apps Store: https://apps.odoo.com/apps/modules/8.0/mail_partner_lang/
Tested on `Odoo 8.0 <https://github.com/odoo/odoo/commit/ab7b5d7732a7c222a0aea45bd173742acd47242d>`_

2
mail_partner_lang/__init__.py

@ -1,2 +0,0 @@
# -*- coding: utf-8 -*-
from . import models

13
mail_partner_lang/__openerp__.py

@ -1,13 +0,0 @@
# -*- coding: utf-8 -*-
{
'name': 'Use partner language in mail',
'version': '1.0.0',
'author': 'IT-Projects LLC, Ivan Yelizariev',
'license': 'GPL-3',
"category": "Discuss",
'website': 'https://yelizariev.github.io',
'depends': ['mail'],
'data': [],
'installable': False,
}

4
mail_partner_lang/doc/changelog.rst

@ -1,4 +0,0 @@
`1.0.0`
-------
- Init version

13
mail_partner_lang/doc/index.rst

@ -1,13 +0,0 @@
==============================
Use partner language in mail
==============================
Installation
============
* `Install <https://odoo-development.readthedocs.io/en/latest/odoo/usage/install-module.html>`__ this module in a usual way
Configuration
=============
This module do not need any special configuration.

88
mail_partner_lang/models.py

@ -1,88 +0,0 @@
# -*- coding: utf-8 -*-
from openerp.osv import osv
class MailThread(osv.Model):
_inherit = "mail.thread"
def message_track(self, cr, uid, ids, tracked_fields, initial_values, context={}):
def convert_for_display(value, col_info):
if not value and col_info['type'] == 'boolean':
return 'False'
if not value:
return ''
if col_info['type'] == 'many2one':
return value.name_get()[0][1]
if col_info['type'] == 'selection':
return dict(col_info['selection'])[value]
return value
def format_message(message_description, tracked_values):
message = ''
if message_description:
message = '<span>%s</span>' % message_description
for name, change in tracked_values.items():
message += '<div> &nbsp; &nbsp; &bull; <b>%s</b>: ' % change.get('col_info')
if change.get('old_value'):
message += '%s &rarr; ' % change.get('old_value')
message += '%s</div>' % change.get('new_value')
return message
if not tracked_fields:
return True
update_fields = [f for f in tracked_fields]
for browse_record in self.browse(cr, uid, ids, context=context):
p = getattr(browse_record, 'partner_id', None)
if p:
browse_record._context.update({'lang': p.lang})
initial = initial_values[browse_record.id]
changes = set()
tracked_values = {}
# update translation
tracked_fields = self._get_tracked_fields(cr, uid, update_fields, browse_record._context)
# generate tracked_values data structure: {'col_name': {col_info, new_value, old_value}}
for col_name, col_info in tracked_fields.items():
initial_value = initial[col_name]
record_value = getattr(browse_record, col_name)
if record_value == initial_value and getattr(self._all_columns[col_name].column, 'track_visibility', None) == 'always':
tracked_values[col_name] = dict(col_info=col_info['string'],
new_value=convert_for_display(record_value, col_info))
elif record_value != initial_value and (record_value or initial_value): # because browse null != False
if getattr(self._all_columns[col_name].column, 'track_visibility', None) in ['always', 'onchange']:
tracked_values[col_name] = dict(col_info=col_info['string'],
old_value=convert_for_display(initial_value, col_info),
new_value=convert_for_display(record_value, col_info))
if col_name in tracked_fields:
changes.add(col_name)
if not changes:
continue
# find subtypes and post messages or log if no subtype found
subtypes = []
for field, track_info in self._track.items():
if field not in changes:
continue
for subtype, method in track_info.items():
if method(self, cr, uid, browse_record, context):
subtypes.append(subtype)
posted = False
for subtype in subtypes:
subtype_rec = self.pool.get('ir.model.data').xmlid_to_object(cr, uid, subtype, context=context)
if not (subtype_rec and subtype_rec.exists()):
_logger.debug('subtype %s not found' % subtype)
continue
message = format_message(subtype_rec.description if subtype_rec.description else subtype_rec.name, tracked_values)
self.message_post(cr, uid, browse_record.id, body=message, subtype=subtype, context=context)
posted = True
if not posted:
message = format_message('', tracked_values)
self.message_post(cr, uid, browse_record.id, body=message, context=context)
return True

BIN
mail_partner_lang/static/description/icon.png

Before

Width: 100  |  Height: 100  |  Size: 2.1 KiB

Loading…
Cancel
Save