Skip to content

Commit

Permalink
pos_receipt_replace_user_by_trigram: Drop compute function
Browse files Browse the repository at this point in the history
The compute function does not allow any customization on how the
trigram had to be generated, and there a multiple ways to define
how trigram must be generated.

Moreover, the compute did generate duplicates and there was no way
to fix manually since the field was not stored. Also, making it
stored but still computed did risk unwanted updates in case name
was updated.

Having a basic stored field allows each company to customize how
trigram can be generated using a server action. The logic previously
provided is then moved to a cron that can be customized to suit
trigram generation for each company.
  • Loading branch information
grindtildeath committed Dec 10, 2024
1 parent 5c70694 commit a2aee40
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 20 deletions.
2 changes: 1 addition & 1 deletion pos_receipt_replace_user_by_trigram/__manifest__.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@
"version": "16.0.1.0.0",
"depends": [
"point_of_sale",
"partner_firstname",
],
"assets": {
"point_of_sale.assets": [
Expand All @@ -22,6 +21,7 @@
],
},
"data": [
"data/ir_cron.xml",
"views/res_config_settings.xml",
"views/res_users.xml",
],
Expand Down
30 changes: 30 additions & 0 deletions pos_receipt_replace_user_by_trigram/data/ir_cron.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo noupdate="1">
<record forcecreate="True" id="ir_cron_generate_pos_trigram" model="ir.cron">
<field name="name">POS: generate user trigram</field>
<field name="model_id" ref="base.model_res_partner"/>
<field name="state">code</field>
<field eval="False" name="active" />
<field name="user_id" ref="base.user_root" />
<field name="interval_number">1</field>
<field name="interval_type">hours</field>
<field name="numbercall">1</field>
<field name="code">
def get_trigram(*args):
valid = [x.strip() for x in args if x and x.strip()]
if valid:
if len(valid) &gt; 1:
trigram = valid[0][:1] + valid[1][:2]
else:
trigram = valid[0][:3]
else:
trigram = ""
return trigram

partners = model.search([('pos_trigram', '=', ''), ('user_ids', '=', True)])
for partner in partners:
firstname, lastname = partner.split(' ', 1)
partner.write({'pos_trigram': get_trigram(firstname, lastname)})
</field>
</record>
</odoo>
9 changes: 1 addition & 8 deletions pos_receipt_replace_user_by_trigram/models/res_partner.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,8 @@

from odoo import api, fields, models

from .. import utils


class ResPartner(models.Model):
_inherit = "res.partner"

pos_trigram = fields.Char(compute="_compute_pos_trigram")

@api.depends("firstname", "lastname")
def _compute_pos_trigram(self):
for partner in self:
partner.pos_trigram = utils.get_trigram(partner.firstname, partner.lastname)
pos_trigram = fields.Char()
11 changes: 0 additions & 11 deletions pos_receipt_replace_user_by_trigram/utils.py

This file was deleted.

0 comments on commit a2aee40

Please sign in to comment.