clinic/netforce_clinic/models/select_company.py

104 lines
3.8 KiB
Python
Raw Normal View History

2015-02-09 16:47:59 +00:00
from netforce.model import Model, fields, get_model
from netforce.access import get_active_user, set_active_user
class SelectCompany(Model):
_inherit="select.company"
_fields={
"department": fields.Selection([],"Deparment")
}
def _get_department(self,context={}):
user_id=get_active_user()
dpt_name=None
for staff in get_model("clinic.staff").search_browse([['user_id','=',user_id]]):
dpt=staff.department_id
dpt_name=dpt.name
return dpt_name
_defaults={
'department': _get_department,
}
2015-03-12 11:04:43 +00:00
def _get_departments(self,context={}):
2015-02-09 16:47:59 +00:00
user_id=get_active_user()
2015-02-10 01:28:30 +00:00
user=get_model('base.user').browse(user_id)
dom=[]
if user.department_profile_id:
set_active_user(1)
dpt_ids=[]
for dpt in user.department_profile_id.departments:
dpt_ids.append(dpt.id)
if dpt_ids:
dom.append(['id','in',dpt_ids])
res=get_model("clinic.department").search_read(dom,["name"])
2015-02-09 16:47:59 +00:00
set_active_user(user_id)
return [(r["name"],r["name"]) for r in res]
2015-03-12 11:04:43 +00:00
def _select(self,ids,context={}):
2015-02-09 16:47:59 +00:00
obj=self.browse(ids)[0]
if obj.department:
user_id=get_active_user()
2015-02-10 01:28:30 +00:00
user=get_model('base.user').browse(user_id)
2015-02-09 16:47:59 +00:00
set_active_user(1)
2015-02-10 01:28:30 +00:00
staff=None
2015-02-09 16:47:59 +00:00
for dpt in get_model("clinic.department").search_browse([["name","=",obj.department]]):
for staff in get_model("clinic.staff").search_browse([['user_id','=',user_id]]):
staff.write({
'department_id': dpt.id,
'branch_id': dpt.branch_id.id,
})
2015-02-10 01:28:30 +00:00
if not staff:
raise Exception("No staff match with user %s"%user.name)
pf_id=None
if dpt.branch_id.code=='LS':
for pf in get_model("profile").search_browse([['name','=','Nurse Laksi']]):
pf_id=pf.id
elif dpt.branch_id.code=='SS':
for pf in get_model("profile").search_browse([['name','=','Nurse Samsan']]):
pf_id=pf.id
if pf_id:
user=get_model("base.user").browse(user_id)
user.write({
'profile_id': pf_id,
})
2015-02-09 16:47:59 +00:00
set_active_user(user_id)
res=super().select(ids,context)
return res
2015-03-12 11:04:43 +00:00
def get_departments(self,context={}):
user_id=get_active_user()
dpt_ids=[]
for st in get_model("clinic.staff").search_browse(['user_id','=',user_id]):
for dpt in st.departments:
dpt_ids.append(dpt.id)
dom=[]
if dpt_ids:
dom.append(['id','in',dpt_ids])
res=get_model("clinic.department").search_read(dom,["name"])
set_active_user(user_id)
return [(r["name"],r["name"]) for r in res]
def select(self,ids,context={}):
user_id=get_active_user()
if user_id==1:
return
obj=self.browse(ids)[0]
if obj.department:
user=get_model('base.user').browse(user_id)
set_active_user(1)
for dpt in get_model("clinic.department").search_browse([["name","=",obj.department]]):
pf_id=None
for pf in get_model("profile").search_read(['code','=',dpt.code]):
pf_id=pf['id']
print('selected profile ', pf['name'])
if pf_id:
user=get_model("base.user").browse(user_id)
user.write({
'profile_id': pf_id,
})
set_active_user(user_id)
res=super().select(ids,context)
return res
2015-02-09 16:47:59 +00:00
SelectCompany.register()