Browse Source

Mar 20 : [UPDT] Bug Fixed 'employee_dynamic_fields'

pull/249/merge
AjmalCybro 2 years ago
parent
commit
2c32fb9183
  1. 14
      employee_dynamic_fields/__init__.py
  2. 1
      employee_dynamic_fields/__manifest__.py
  3. 64
      employee_dynamic_fields/wizard/employee_fields.py
  4. 52
      employee_dynamic_fields/wizard/employee_fields_view.xml

14
employee_dynamic_fields/__init__.py

@ -23,3 +23,17 @@
from . import models from . import models
from . import wizard from . import wizard
from odoo import api, SUPERUSER_ID
def uninstall_hook(cr, registry):
env = api.Environment(cr, SUPERUSER_ID, {})
fields = env['employee.dynamic.fields'].search([])
for field in fields:
print(field.form_view_id,'new')
field.form_view_id.active = False
print(field.form_view_id,'old')
query = """delete FROM ir_model_fields WHERE name = %s"""
env.cr.execute(query, [field.name])
fields.unlink()

1
employee_dynamic_fields/__manifest__.py

@ -45,4 +45,5 @@
'installable': True, 'installable': True,
'auto_install': False, 'auto_install': False,
'application': False, 'application': False,
'uninstall_hook': 'uninstall_hook',
} }

64
employee_dynamic_fields/wizard/employee_fields.py

@ -30,6 +30,8 @@ class EmployeeDynamicFields(models.TransientModel):
_description = 'Dynamic Fields' _description = 'Dynamic Fields'
_inherit = 'ir.model.fields' _inherit = 'ir.model.fields'
form_view_id = fields.Many2one('ir.ui.view', string="Form View ID")
@api.model @api.model
def get_possible_field_types(self): def get_possible_field_types(self):
"""Return all available field types other than 'one2many' and 'reference' fields.""" """Return all available field types other than 'one2many' and 'reference' fields."""
@ -43,16 +45,17 @@ class EmployeeDynamicFields(models.TransientModel):
view_id = self.env.ref('hr.view_employee_form') view_id = self.env.ref('hr.view_employee_form')
view_arch = str(view_id.arch_base) view_arch = str(view_id.arch_base)
doc = xee.fromstring(view_arch) doc = xee.fromstring(view_arch)
print("doc===", doc)
field_list = [] field_list = []
for tag in doc.findall('.//field'): for tag in doc.findall('.//field'):
print("tag==", tag)
field_list.append(tag.attrib['name']) field_list.append(tag.attrib['name'])
model_id = self.env['ir.model'].sudo().search([('model', '=', 'hr.employee')]) model_id = self.env['ir.model'].sudo().search(
return [('model_id', '=', model_id.id), ('state', '=', 'base'), ('name', 'in', field_list)] [('model', '=', 'hr.employee')])
return [('model_id', '=', model_id.id), ('state', '=', 'base'),
('name', 'in', field_list)]
def _set_default(self): def _set_default(self):
model_id = self.env['ir.model'].sudo().search([('model', '=', 'hr.employee')]) model_id = self.env['ir.model'].sudo().search(
[('model', '=', 'hr.employee')])
return [('id', '=', model_id.id)] return [('id', '=', model_id.id)]
def create_fields(self): def create_fields(self):
@ -76,41 +79,51 @@ class EmployeeDynamicFields(models.TransientModel):
'<field name="%s" position="%s">' '<field name="%s" position="%s">'
'<field name="%s"/>' '<field name="%s"/>'
'</field>' '</field>'
'</data>') % (self.position_field.name, self.position, self.name) '</data>') % (
self.position_field.name, self.position, self.name)
if self.widget: if self.widget:
arch_base = _('<?xml version="1.0"?>' arch_base = _('<?xml version="1.0"?>'
'<data>' '<data>'
'<field name="%s" position="%s">' '<field name="%s" position="%s">'
'<field name="%s" widget="%s"/>' '<field name="%s" widget="%s"/>'
'</field>' '</field>'
'</data>') % (self.position_field.name, self.position, self.name, self.widget.name) '</data>') % (
self.position_field.name, self.position, self.name,
self.widget.name)
self.env['ir.ui.view'].sudo().create({'name': 'employee.dynamic.fields', self.form_view_id = self.env['ir.ui.view'].sudo().create(
'type': 'form', {'name': 'employee.dynamic.fields',
'model': 'hr.employee', 'type': 'form',
'mode': 'extension', 'model': 'hr.employee',
'inherit_id': inherit_id.id, 'mode': 'extension',
'arch_base': arch_base, 'inherit_id': inherit_id.id,
'active': True}) 'arch_base': arch_base,
'active': True})
return { return {
'type': 'ir.actions.client', 'type': 'ir.actions.client',
'tag': 'reload', 'tag': 'reload',
} }
position_field = fields.Many2one('ir.model.fields', string='Field Name', position_field = fields.Many2one('ir.model.fields', string='Field Name',
domain=set_domain, required=True) domain=set_domain, required=True,
ondelete='cascade')
position = fields.Selection([('before', 'Before'), position = fields.Selection([('before', 'Before'),
('after', 'After')], string='Position', required=True) ('after', 'After')], string='Position',
model_id = fields.Many2one('ir.model', string='Model', required=True, index=True, ondelete='cascade', required=True)
help="The model this field belongs to", domain=_set_default) model_id = fields.Many2one('ir.model', string='Model', required=True,
index=True, ondelete='cascade',
help="The model this field belongs to",
domain=_set_default)
ref_model_id = fields.Many2one('ir.model', string='Model', index=True) ref_model_id = fields.Many2one('ir.model', string='Model', index=True)
# In odoo 13 the field 'selection' is deprecated, so adding a new field to get the selection values. # In odoo 13 the field 'selection' is deprecated, so adding a new field to get the selection values.
selection_field = fields.Char(string="Selection Options") selection_field = fields.Char(string="Selection Options")
rel_field = fields.Many2one('ir.model.fields', string='Related Field') rel_field = fields.Many2one('ir.model.fields', string='Related Field')
field_type = fields.Selection(selection='get_possible_field_types', string='Field Type', required=True) field_type = fields.Selection(selection='get_possible_field_types',
string='Field Type', required=True)
ttype = fields.Selection(string="Field Type", related='field_type') ttype = fields.Selection(string="Field Type", related='field_type')
widget = fields.Many2one('employee.field.widgets', string='Widget') widget = fields.Many2one('employee.field.widgets', string='Widget')
groups = fields.Many2many('res.groups', 'employee_dynamic_fields_group_rel', 'field_id', 'group_id') groups = fields.Many2many('res.groups', 'employee_dynamic_fields_group_rel',
'field_id', 'group_id')
extra_features = fields.Boolean(string="Show Extra Properties") extra_features = fields.Boolean(string="Show Extra Properties")
@api.depends('field_type') @api.depends('field_type')
@ -120,7 +133,8 @@ class EmployeeDynamicFields(models.TransientModel):
if self.field_type == 'binary': if self.field_type == 'binary':
return {'domain': {'widget': [('name', '=', 'image')]}} return {'domain': {'widget': [('name', '=', 'image')]}}
elif self.field_type == 'many2many': elif self.field_type == 'many2many':
return {'domain': {'widget': [('name', 'in', ['many2many_tags', 'binary'])]}} return {'domain': {
'widget': [('name', 'in', ['many2many_tags', 'binary'])]}}
elif self.field_type == 'selection': elif self.field_type == 'selection':
return {'domain': { return {'domain': {
'widget': [('name', 'in', ['radio', 'priority'])]}} 'widget': [('name', 'in', ['radio', 'priority'])]}}
@ -132,6 +146,14 @@ class EmployeeDynamicFields(models.TransientModel):
return {'domain': {'widget': [('id', '=', False)]}} return {'domain': {'widget': [('id', '=', False)]}}
return {'domain': {'widget': [('id', '=', False)]}} return {'domain': {'widget': [('id', '=', False)]}}
def unlink(self):
if self.form_view_id:
self.form_view_id.active = False
for field in self:
query = """delete FROM ir_model_fields WHERE name = %s"""
self.env.cr.execute(query, [field.name])
return super(EmployeeDynamicFields, self).unlink()
class Employee(models.Model): class Employee(models.Model):
_description = 'Employee' _description = 'Employee'

52
employee_dynamic_fields/wizard/employee_fields_view.xml

@ -11,14 +11,19 @@
<group string="Field Info"> <group string="Field Info">
<field name="name"/> <field name="name"/>
<field name="field_description"/> <field name="field_description"/>
<field name="state" readonly="1" groups="base.group_no_one"/> <field name="state" readonly="1"
<field name="model_id" options='{"no_open": True, "no_create": True}'/> groups="base.group_no_one"/>
<field name="model_id"
options='{"no_open": True, "no_create": True}'/>
<field name="field_type"/> <field name="field_type"/>
<field name="selection_field" placeholder="[('blue', 'Blue'),('yellow', 'Yellow')]" <field name="selection_field"
placeholder="[('blue', 'Blue'),('yellow', 'Yellow')]"
attrs="{'required': [('field_type','in',['selection','reference'])], attrs="{'required': [('field_type','in',['selection','reference'])],
'readonly': [('field_type','not in',['selection','reference'])], 'readonly': [('field_type','not in',['selection','reference'])],
'invisible': [('field_type','not in',['selection','reference'])]}"/> 'invisible': [('field_type','not in',['selection','reference'])]}"/>
<field name="ref_model_id" options='{"no_open": True, "no_create": True}' attrs="{'required': [('field_type','in',['many2one','many2many'])], <field name="ref_model_id"
options='{"no_open": True, "no_create": True}'
attrs="{'required': [('field_type','in',['many2one','many2many'])],
'readonly': [('field_type','not in',['many2one','many2many'])], 'readonly': [('field_type','not in',['many2one','many2many'])],
'invisible': [('field_type','not in',['many2one','many2many'])]}"/> 'invisible': [('field_type','not in',['many2one','many2many'])]}"/>
<field name="widget" widget="selection" <field name="widget" widget="selection"
@ -26,7 +31,8 @@
<field name="required"/> <field name="required"/>
</group> </group>
<group string="Position"> <group string="Position">
<field name="position_field" options='{"no_open": True, "no_create": True}'/> <field name="position_field"
options='{"no_open": True, "no_create": True}'/>
<field name="position"/> <field name="position"/>
</group> </group>
</group> </group>
@ -46,7 +52,8 @@
</group> </group>
</sheet> </sheet>
<footer> <footer>
<button name="create_fields" string="Create Fields" type="object" class="oe_highlight"/> <button name="create_fields" string="Create Fields"
type="object" class="oe_highlight"/>
or or
<button string="Cancel" class="oe_link" special="cancel"/> <button string="Cancel" class="oe_link" special="cancel"/>
</footer> </footer>
@ -54,6 +61,18 @@
</field> </field>
</record> </record>
<record model='ir.ui.view' id='wizard_employee_dynamic_fields_tree'>
<field name="name">employee.dynamic.fields.tree</field>
<field name="model">employee.dynamic.fields</field>
<field name="arch" type="xml">
<tree create="false">
<field name="name"></field>
<field name="field_description"></field>
<field name="ttype"></field>
</tree>
</field>
</record>
<record model='ir.actions.act_window' id='action_employee_dynamic_fields'> <record model='ir.actions.act_window' id='action_employee_dynamic_fields'>
<field name="name">Create Custom Fields</field> <field name="name">Create Custom Fields</field>
<field name="res_model">employee.dynamic.fields</field> <field name="res_model">employee.dynamic.fields</field>
@ -62,6 +81,19 @@
<field name="target">new</field> <field name="target">new</field>
</record> </record>
<record id="action_employee_dynamic_fields_delete"
model="ir.actions.act_window">
<field name="name">Delete Fields</field>
<field name="res_model">employee.dynamic.fields</field>
<field name="view_mode">tree</field>
<field name="view_id" ref="wizard_employee_dynamic_fields_tree"/>
<field name="help" type="html">
<p class="o_view_nocontent_smiling_face">
Delete created custom fields
</p>
</field>
</record>
<!-- Menu Item in Employee to create fields --> <!-- Menu Item in Employee to create fields -->
<menuitem <menuitem
id="menu_create_employee_fields" id="menu_create_employee_fields"
@ -71,4 +103,12 @@
groups="employee_dynamic_fields.group_add_employee_custom_fields" groups="employee_dynamic_fields.group_add_employee_custom_fields"
sequence="10"/> sequence="10"/>
<menuitem id="menu_delete_employee_fields"
name="Delete Fields"
parent="hr.menu_hr_employee_payroll"
action="action_employee_dynamic_fields_delete"
groups="employee_dynamic_fields.group_add_employee_custom_fields"
sequence="12"/>
</odoo> </odoo>

Loading…
Cancel
Save