2018-01-16 18:21:36 +05:30
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
from flectra import api, fields, models
|
2018-06-29 15:27:41 +05:30
|
|
|
from flectra import SUPERUSER_ID
|
2018-01-29 11:35:08 +00:00
|
|
|
# from flectra.exceptions import ValidationError
|
2018-01-16 18:21:36 +05:30
|
|
|
|
2018-06-29 15:27:41 +05:30
|
|
|
def migrate_company_branch(cr, registry):
|
|
|
|
env = api.Environment(cr, SUPERUSER_ID, {})
|
|
|
|
company = env.ref('base.main_company')
|
|
|
|
company.write({'branch_id': env.ref('base_branch_company.data_branch_1').id})
|
|
|
|
cr.commit()
|
|
|
|
user_ids = env['res.users'].search([])
|
|
|
|
for user_id in user_ids:
|
|
|
|
if not user_id.user_has_groups('base_branch_company.group_multi_branch'):
|
|
|
|
user_id.sudo().write({'default_branch_id': user_id.company_id.branch_id.id,
|
|
|
|
'branch_ids': [(6, 0, [user_id.company_id.branch_id.id])]})
|
|
|
|
cr.commit()
|
2018-01-16 18:21:36 +05:30
|
|
|
|
2018-08-10 14:35:39 +05:30
|
|
|
|
2018-01-16 18:21:36 +05:30
|
|
|
class Company(models.Model):
|
|
|
|
_name = "res.company"
|
|
|
|
_inherit = ["res.company"]
|
|
|
|
|
2018-10-18 14:52:13 +05:30
|
|
|
branch_id = fields.Many2one('res.branch', 'Branch', ondelete="cascade")
|
2018-01-16 18:21:36 +05:30
|
|
|
|
|
|
|
@api.model
|
|
|
|
def create(self, vals):
|
|
|
|
branch = self.env['res.branch'].create({
|
|
|
|
'name': vals['name'],
|
|
|
|
'code': vals['name'],
|
|
|
|
})
|
|
|
|
vals['branch_id'] = branch.id
|
|
|
|
self.clear_caches()
|
|
|
|
company = super(Company, self).create(vals)
|
|
|
|
branch.write({'partner_id': company.partner_id.id,
|
|
|
|
'company_id': company.id})
|
|
|
|
return company
|
|
|
|
|
2018-01-29 11:35:08 +00:00
|
|
|
|
2018-01-16 18:21:36 +05:30
|
|
|
class ResBranch(models.Model):
|
|
|
|
_name = "res.branch"
|
|
|
|
|
|
|
|
name = fields.Char(string='Name', required=True)
|
|
|
|
code = fields.Char(string='Code', required=True)
|
|
|
|
active = fields.Boolean(string='Active', default=True)
|
|
|
|
partner_id = fields.Many2one('res.partner', string='Partner',
|
|
|
|
ondelete='restrict')
|
|
|
|
company_id = fields.Many2one(
|
|
|
|
'res.company', string="Company",
|
|
|
|
default=lambda self: self.env.user.company_id, required=True)
|
|
|
|
street = fields.Char()
|
|
|
|
street2 = fields.Char()
|
|
|
|
zip = fields.Char(change_default=True)
|
|
|
|
city = fields.Char()
|
|
|
|
state_id = fields.Many2one("res.country.state", string='State',
|
|
|
|
ondelete='restrict')
|
|
|
|
country_id = fields.Many2one('res.country', string='Country',
|
|
|
|
ondelete='restrict')
|
|
|
|
email = fields.Char()
|
|
|
|
phone = fields.Char()
|
|
|
|
mobile = fields.Char()
|
|
|
|
|
2018-01-29 11:35:08 +00:00
|
|
|
_sql_constraints = [('branch_code_company_uniq',
|
|
|
|
'unique (code,company_id)',
|
2018-01-16 18:21:36 +05:30
|
|
|
'The branch code must be unique per company!')]
|
|
|
|
|
|
|
|
@api.model
|
|
|
|
def create(self, vals):
|
|
|
|
res = super(ResBranch, self).create(vals)
|
|
|
|
vals.pop("name", None)
|
|
|
|
vals.pop("code", None)
|
|
|
|
vals.pop("partner_id", None)
|
|
|
|
vals.update({'branch_id': res.id})
|
|
|
|
res.partner_id.write(vals)
|
|
|
|
return res
|
|
|
|
|
|
|
|
@api.multi
|
|
|
|
def write(self, vals):
|
|
|
|
res = super(ResBranch, self).write(vals)
|
|
|
|
vals.pop("name", None)
|
|
|
|
vals.pop("code", None)
|
|
|
|
vals.pop("company_id", None)
|
|
|
|
vals.pop("partner_id", None)
|
|
|
|
ctx = self.env.context.copy()
|
|
|
|
if 'branch' not in ctx:
|
2018-10-18 14:52:13 +05:30
|
|
|
for record in self:
|
|
|
|
record.partner_id.write(vals)
|
2018-01-16 18:21:36 +05:30
|
|
|
return res
|
|
|
|
|
|
|
|
|
|
|
|
class Users(models.Model):
|
|
|
|
|
|
|
|
_inherit = "res.users"
|
|
|
|
|
2018-11-20 10:37:43 +05:30
|
|
|
@api.multi
|
|
|
|
def read(self, fields=None, load='_classic_read'):
|
|
|
|
result = super(Users, self).read(fields, load=load)
|
|
|
|
self.with_context({'check_branch': True}).check_missing_branch()
|
|
|
|
return result
|
|
|
|
|
|
|
|
@api.multi
|
|
|
|
def check_missing_branch(self):
|
|
|
|
for user_id in self:
|
|
|
|
if self._context.get('check_branch', False) and user_id.company_id.branch_id and not user_id.default_branch_id:
|
|
|
|
user_id.default_branch_id = user_id.company_id.branch_id.id
|
|
|
|
user_id.branch_ids = [(4, user_id.company_id.branch_id.id)]
|
|
|
|
|
2018-01-16 18:21:36 +05:30
|
|
|
@api.model
|
|
|
|
def branch_default_get(self, user):
|
|
|
|
if not user:
|
|
|
|
user = self._uid
|
|
|
|
branch_id = self.env['res.users'].browse(user).default_branch_id
|
|
|
|
if not branch_id:
|
|
|
|
branch_id = \
|
|
|
|
self.env['res.users'].browse(user).company_id.branch_id
|
|
|
|
return branch_id
|
|
|
|
|
2018-01-18 15:27:39 +05:30
|
|
|
@api.model
|
|
|
|
def _get_branch(self):
|
|
|
|
return self.env.user.default_branch_id
|
|
|
|
|
2018-01-16 18:21:36 +05:30
|
|
|
@api.model
|
|
|
|
def _get_default_branch(self):
|
|
|
|
return self.branch_default_get(self._uid)
|
|
|
|
|
2018-01-18 15:27:39 +05:30
|
|
|
def _branches_count(self):
|
|
|
|
return self.env['res.branch'].sudo().search_count([])
|
|
|
|
|
2018-01-16 18:21:36 +05:30
|
|
|
branch_ids = fields.Many2many('res.branch',
|
|
|
|
'res_branch_users_rel',
|
|
|
|
'user_id',
|
|
|
|
'branch_id',
|
2018-01-18 15:27:39 +05:30
|
|
|
'Branches', default=_get_branch,
|
|
|
|
domain="[('company_id','=',company_id)]")
|
2018-01-16 18:21:36 +05:30
|
|
|
default_branch_id = fields.Many2one('res.branch', 'Default branch',
|
2018-01-18 15:27:39 +05:30
|
|
|
default=_get_branch,
|
2018-01-16 18:21:36 +05:30
|
|
|
domain="[('company_id','=',company_id)"
|
|
|
|
"]")
|
2018-01-29 11:35:08 +00:00
|
|
|
branches_count = fields.Integer(
|
|
|
|
compute='_compute_branches_count',
|
|
|
|
string="Number of Companies", default=_branches_count)
|
|
|
|
|
2018-06-29 15:27:41 +05:30
|
|
|
@api.onchange('company_id')
|
2018-08-10 14:35:39 +05:30
|
|
|
def _onchange_company_id(self):
|
2018-10-18 14:52:13 +05:30
|
|
|
if self.company_id.branch_id:
|
|
|
|
self.default_branch_id = self.company_id.branch_id.id
|
|
|
|
self.branch_ids = [(4, self.company_id.branch_id.id)]
|
2018-06-29 15:27:41 +05:30
|
|
|
|
2018-01-29 11:35:08 +00:00
|
|
|
# To do : Check with all base module test cases
|
|
|
|
# @api.multi
|
|
|
|
# @api.constrains('default_branch_id', 'branch_ids')
|
|
|
|
# def _check_branches(self):
|
|
|
|
# for user in self:
|
|
|
|
# if user.branch_ids \
|
|
|
|
# and user.default_branch_id not in user.branch_ids:
|
|
|
|
# raise ValidationError(_('The selected Default Branch (%s) '
|
|
|
|
# 'is not in the Branches!') % (
|
|
|
|
# user.default_branch_id.name))
|
2018-01-16 18:21:36 +05:30
|
|
|
|
2018-01-18 15:27:39 +05:30
|
|
|
@api.multi
|
|
|
|
def _compute_branches_count(self):
|
|
|
|
branches_count = self._branches_count()
|
|
|
|
for user in self:
|
|
|
|
user.branches_count = branches_count
|
2018-10-25 16:46:20 +05:30
|
|
|
|
|
|
|
@api.model
|
|
|
|
def create(self, vals):
|
|
|
|
res = super(Users, self).create(vals)
|
|
|
|
if 'company_id' in vals:
|
|
|
|
vals.update({
|
|
|
|
'default_branch_id': self.company_id.branch_id.id,
|
|
|
|
})
|
|
|
|
return res
|
|
|
|
|
|
|
|
@api.multi
|
|
|
|
def write(self, vals):
|
|
|
|
res = super(Users, self).write(vals)
|
|
|
|
if 'company_id' in vals:
|
|
|
|
self.default_branch_id = self.company_id.branch_id.id
|
|
|
|
return res
|