mirror of
https://github.com/OCA/server-backend.git
synced 2025-02-18 09:52:42 +02:00
[IMP] server_action_navigate: black, isort, prettier
This commit is contained in:
@@ -13,25 +13,29 @@ class IrActionsServer(models.Model):
|
||||
|
||||
navigate_action_id = fields.Many2one(
|
||||
string="Navigation Action",
|
||||
comodel_name='ir.actions.act_window',
|
||||
comodel_name="ir.actions.act_window",
|
||||
domain="[('res_model', '=', max_navigate_line_model)]",
|
||||
help="Define here the action used when the navigation will be executed"
|
||||
" if empty, a generic action will be used.")
|
||||
" if empty, a generic action will be used.",
|
||||
)
|
||||
|
||||
navigate_line_ids = fields.One2many(
|
||||
comodel_name="ir.actions.server.navigate.line",
|
||||
string="Navigate Lines", inverse_name="action_id")
|
||||
string="Navigate Lines",
|
||||
inverse_name="action_id",
|
||||
)
|
||||
|
||||
max_navigate_line_sequence = fields.Integer(
|
||||
string='Max Navigate sequence in lines',
|
||||
compute='_compute_max_navigate_line',
|
||||
store=True
|
||||
string="Max Navigate sequence in lines",
|
||||
compute="_compute_max_navigate_line",
|
||||
store=True,
|
||||
)
|
||||
|
||||
max_navigate_line_model = fields.Char(
|
||||
string="Max Navigate Model in lines",
|
||||
compute="_compute_max_navigate_line",
|
||||
store=True)
|
||||
store=True,
|
||||
)
|
||||
|
||||
@api.depends("navigate_line_ids", "model_id")
|
||||
def _compute_max_navigate_line(self):
|
||||
@@ -43,11 +47,13 @@ class IrActionsServer(models.Model):
|
||||
"""
|
||||
for action in self:
|
||||
action.max_navigate_line_sequence = (
|
||||
max(action.mapped('navigate_line_ids.sequence') or [0]) + 1)
|
||||
action.max_navigate_line_model =\
|
||||
action.navigate_line_ids\
|
||||
and action.navigate_line_ids[-1].field_model\
|
||||
max(action.mapped("navigate_line_ids.sequence") or [0]) + 1
|
||||
)
|
||||
action.max_navigate_line_model = (
|
||||
action.navigate_line_ids
|
||||
and action.navigate_line_ids[-1].field_model
|
||||
or action.model_id.model
|
||||
)
|
||||
|
||||
def delete_last_line(self):
|
||||
self.ensure_one()
|
||||
@@ -56,34 +62,34 @@ class IrActionsServer(models.Model):
|
||||
|
||||
@api.model
|
||||
def run_action_navigate_multi(self, action, eval_context=None):
|
||||
IrModel = self.env['ir.model']
|
||||
IrModel = self.env["ir.model"]
|
||||
lines = action.navigate_line_ids
|
||||
if not lines:
|
||||
raise UserError(_(
|
||||
"The Action Server %s is not correctly set\n"
|
||||
" : No fields defined"))
|
||||
raise UserError(
|
||||
_("The Action Server %s is not correctly set\n" " : No fields defined")
|
||||
)
|
||||
mapped_field_value = ".".join(lines.mapped("field_id.name"))
|
||||
|
||||
item_ids = eval_context['records'].mapped(mapped_field_value).ids
|
||||
domain = "[('id','in',[" + ','.join(map(str, item_ids)) + "])]"
|
||||
item_ids = eval_context["records"].mapped(mapped_field_value).ids
|
||||
domain = "[('id','in',[" + ",".join(map(str, item_ids)) + "])]"
|
||||
|
||||
# Use Defined action if defined
|
||||
if action.navigate_action_id:
|
||||
return_action = action.navigate_action_id
|
||||
result = return_action.read()[0]
|
||||
result['domain'] = domain
|
||||
result["domain"] = domain
|
||||
else:
|
||||
# Otherwise, return a default action
|
||||
model_name = action.max_navigate_line_model
|
||||
model = IrModel.search([('model', '=', model_name)])
|
||||
view_mode = 'tree,form'
|
||||
model = IrModel.search([("model", "=", model_name)])
|
||||
view_mode = "tree,form"
|
||||
result = {
|
||||
'name': model.name,
|
||||
'domain': domain,
|
||||
'res_model': model_name,
|
||||
'target': 'current',
|
||||
'type': 'ir.actions.act_window',
|
||||
'view_mode': view_mode,
|
||||
"name": model.name,
|
||||
"domain": domain,
|
||||
"res_model": model_name,
|
||||
"target": "current",
|
||||
"type": "ir.actions.act_window",
|
||||
"view_mode": view_mode,
|
||||
}
|
||||
|
||||
return result
|
||||
|
||||
Reference in New Issue
Block a user