clinic/netforce_clinic/models/staff.py

231 lines
8.8 KiB
Python
Raw Normal View History

2014-10-29 09:10:19 +00:00
import time
from netforce.model import Model, fields, get_model
from netforce.access import get_active_company, get_active_user, set_active_user
class Staff(Model):
_name="clinic.staff"
_string="Staff"
2014-10-29 09:10:19 +00:00
_audit_log=True
_multi_company=True
2015-01-14 17:49:17 +00:00
_key=["name","branch_id"]
2014-10-29 09:10:19 +00:00
2014-11-05 05:06:43 +00:00
def _get_age(self,ids,context={}):
2014-10-29 09:10:19 +00:00
res={}
year_now=int(time.strftime("%Y"))
for obj in self.browse(ids):
age=0
if obj.birthday:
year_bd=int(obj.birthday[0:4])
age=year_now-year_bd
res[obj.id]=age
return res
2014-11-05 05:06:43 +00:00
def _get_level(self,ids,context={}):
res={}
for obj in self.browse(ids):
level_id=None
2014-11-25 16:31:29 +00:00
for rotate in obj.rotations:
level_id=rotate.level_id.id
2014-11-05 05:06:43 +00:00
res[obj.id]=level_id
return res
2014-10-29 09:10:19 +00:00
2014-11-14 01:58:12 +00:00
def _get_cycle(self,ids,context={}):
res={}
for obj in self.browse(ids):
cycle_id=None
for line in obj.cycles:
cycle=line.cycle_id
cycle_id=cycle.id
res[obj.id]=cycle_id
return res
2014-11-21 16:11:57 +00:00
def _get_base(self,ids,context={}):
res={}
for obj in self.browse(ids):
2014-11-25 16:31:29 +00:00
wage=0
2014-11-23 13:44:25 +00:00
max_cycle=0
2014-11-25 16:31:29 +00:00
for rotate in obj.rotations:
wage=rotate.wage
max_cycle=rotate.max_cycle
2014-11-23 13:44:25 +00:00
res[obj.id]={
2014-11-25 16:31:29 +00:00
'wage': wage,
2014-11-23 13:44:25 +00:00
'max_cycle': max_cycle,
}
2014-11-21 16:11:57 +00:00
return res
2014-12-04 02:52:49 +00:00
2015-01-14 04:31:24 +00:00
def _get_hdcase(self,ids,context={}):
2015-01-14 04:53:51 +00:00
# problem slow to load
2015-01-14 04:31:24 +00:00
res={}
for obj in self.browse(ids):
2015-01-14 04:53:51 +00:00
hids=[]
if obj.type=='doctor':
hids=get_model("clinic.hd.case.staff").search([['staff_id','=',obj.id]])
elif obj.type=='nurse':
item_ids=[item['cycle_item_id'][0] for item in get_model("clinic.cycle.item.line").search_read([['nurse_id','=',obj.id]],['cycle_item_id'])]
2015-01-14 04:53:51 +00:00
for item in get_model("clinic.cycle.item").browse(item_ids):
for hdcase in item.hd_cases:
hids.append(hdcase.id)
res[obj.id]=hids
2015-01-14 04:31:24 +00:00
return res
2014-11-14 01:58:12 +00:00
2014-10-29 09:10:19 +00:00
_fields={
'employee_id': fields.Many2One("hr.employee","Employee"),
2014-11-27 06:04:20 +00:00
"number": fields.Char("Number",required=True,search=True),
2014-10-29 09:10:19 +00:00
"name": fields.Char("Name",required=True,search=True),
2014-11-05 05:06:43 +00:00
"name_eng": fields.Char("Eng Name",search=True),
"nick_name": fields.Char("Nick Name",search=True),
"identification" : fields.Char("Identification Card"),
"expiry_card" : fields.Date("Expired Card"),
2014-10-29 09:10:19 +00:00
"birthday": fields.Date("Birthday",search=True),
"age": fields.Integer("Age", function="_get_age"),
2015-01-21 10:57:11 +00:00
"state": fields.Selection([["part_time","Part Time"],["full_time","Full Time"]],"Working Status",search=True),
"type": fields.Selection([['staff','Staff'],["doctor","Doctor"],["nurse","Nurse"]],"Type"),
2014-11-05 05:06:43 +00:00
"gender": fields.Selection([["male","Male"],["female","Female"]],"Gender"),
"nation_id": fields.Many2One("clinic.nation","Nationality"),
2014-10-29 09:10:19 +00:00
"mobile": fields.Char("Mobile",required=False,search=True),
"phone": fields.Char("Phone",search=True),
'email': fields.Char("Email"),
2014-11-05 05:06:43 +00:00
"prof_license" : fields.Char("License No."),
2014-10-29 09:10:19 +00:00
"prof_license_date" : fields.Date("License Date"),
2014-11-05 05:06:43 +00:00
"prof_license_expiry" : fields.Date("Expired License"),
2014-10-29 09:10:19 +00:00
"birthday": fields.Date("BirthDay",search=True),
"department_id": fields.Many2One("clinic.department", "Department",search=True),
2014-11-02 03:38:17 +00:00
"patients": fields.One2Many("clinic.patient","doctor_id","Patients"),
"addresses": fields.One2Many("address","staff_id","Addresses"),
2014-10-29 09:10:19 +00:00
"comments": fields.One2Many("message","related_id","Comments"),
2014-11-02 03:38:17 +00:00
"nurse_visits": fields.One2Many("clinic.visit","nurse_id","Visits"),
"doctor_visits": fields.One2Many("clinic.visit","doctor_id","Visits"),
2015-01-14 08:06:19 +00:00
"company_id": fields.Many2One("company","Company",search=True),
2015-01-18 10:31:54 +00:00
"user_id": fields.Many2One("base.user","User",search=True),
2015-01-09 05:19:52 +00:00
'image': fields.File("Image"),
2014-10-29 09:10:19 +00:00
'note': fields.Text("Note"),
2015-02-08 08:48:08 +00:00
'categ_id': fields.Many2One("clinic.staff.categ", "Category",search=True),
2014-11-25 16:31:29 +00:00
'level_id': fields.Many2One("clinic.staff.level", "Level", function="_get_level"),
2014-10-29 09:10:19 +00:00
'active': fields.Boolean("Active"),
'date': fields.Date("Register Date"),
2014-11-25 16:31:29 +00:00
'wage': fields.Float("Wage", function="_get_base",function_multi=True),
2014-11-23 13:44:25 +00:00
'max_cycle': fields.Integer("Max Cycle", function="_get_base",function_multi=True),
2014-11-27 15:14:31 +00:00
'check_max_cycle': fields.Boolean("Check Max Cycle"),
2014-11-05 05:06:43 +00:00
'hire_date': fields.Date("Hire Date"),
'resign_date': fields.Date("Resign Date"),
"documents": fields.One2Many("document","related_id","Documents"),
2014-11-25 16:31:29 +00:00
"rotations": fields.One2Many("clinic.staff.rotation","staff_id","Staff Rotation"),
"cycles": fields.One2Many("clinic.staff.cycle","staff_id","Cycles"),
'cycle_id': fields.Many2One('clinic.cycle','Last Cycle',function="_get_cycle"),
2014-12-04 02:52:49 +00:00
"hd_case_staffs": fields.One2Many("clinic.hd.case.staff","staff_id","HD Cases"),
2015-01-14 05:30:22 +00:00
"hd_cases": fields.Many2Many("clinic.hd.case","HD Cases",function="_get_hdcase"), # not need to use (it's slow to load)
"cycle_item_nurses": fields.One2Many("clinic.cycle.item.line","nurse_id","Cycle Items"),
2015-01-14 13:36:23 +00:00
'branch_id': fields.Many2One("clinic.branch","Branch", search=True),
2014-10-29 09:10:19 +00:00
}
def _get_number(self,context={}):
while 1:
seq_id=get_model("sequence").find_sequence(name="Clinic Staff")
2014-10-29 09:10:19 +00:00
if not seq_id:
return "/"
num=get_model("sequence").get_next_number(seq_id,context=context)
if not num:
return None
user_id=get_active_user()
set_active_user(1)
res=self.search([["number","=",num]])
set_active_user(user_id)
if not res:
return num
get_model("sequence").increment_number(seq_id,context=context)
2015-01-14 17:49:17 +00:00
def _get_branch(self,context={}):
b_ids=get_model('clinic.branch').search([])
if b_ids:
return b_ids[0]
2014-10-29 09:10:19 +00:00
_defaults={
'active': True,
2015-01-21 09:53:56 +00:00
"state": "part_time",
2014-11-29 00:48:00 +00:00
"type": lambda self,ctx: ctx.get("type") or "staff",
2014-10-29 09:10:19 +00:00
"date": lambda *a: time.strftime("%Y-%m-%d"),
"number": _get_number,
"company_id": lambda *a: get_active_company(),
2015-01-14 17:49:17 +00:00
'branch_id': _get_branch,
2014-10-29 09:10:19 +00:00
}
_order="date desc,number desc"
2014-11-25 16:31:29 +00:00
2014-11-26 01:39:49 +00:00
def check_emp(self,name="", employee_id=None):
names=name.split(" ")
first_name=names[0]
last_name=names[-1]
if first_name==last_name:
first_name=""
vals={
'first_name': first_name,
'last_name': last_name,
}
2014-11-25 16:31:29 +00:00
emp_obj=get_model("hr.employee")
emp_ids=emp_obj.search([['last_name','=',last_name]])
2014-11-26 01:39:49 +00:00
emp_id=None
if not emp_ids and not employee_id:
emp_id=emp_obj.create(vals)
elif employee_id:
emp_obj.browse(employee_id).write(vals)
emp_id=employee_id
else:
emp_id=emp_ids[0]
return emp_id
def create(self,vals,**kw):
name=vals['name']
employee_id=vals.get('employee_id')
emp_id=self.check_emp(name,employee_id)
if emp_id:
vals['employee_id']=emp_id
2014-11-25 16:31:29 +00:00
new_id=super().create(vals,**kw)
return new_id
2014-10-29 09:10:19 +00:00
2014-11-26 01:39:49 +00:00
def write(self,ids,vals,**kw):
obj=self.browse(ids)[0]
name=vals.get("name","")
if not name:
name=obj.name
emp_id=self.check_emp(name,obj.employee_id.id)
if emp_id:
vals['employee_id']=emp_id
super().write(ids,vals,**kw)
2014-12-08 14:54:25 +00:00
def name_get(self,ids,context={}):
vals=[]
for obj in self.browse(ids):
level=obj.level_id
2015-01-14 17:49:17 +00:00
name=obj.name or ""
2015-02-09 12:49:26 +00:00
nickname=obj.nick_name or ""
2014-12-09 01:12:46 +00:00
if level:
2015-02-09 12:49:26 +00:00
if nickname:
name+=" (%s)"%(nickname)
name+=" - %s"%(level.name or "")
2014-12-08 14:54:25 +00:00
vals.append((obj.id,name))
return vals
def name_search(self,name,domain=None,context={},**kw):
dom=[["name","ilike","%"+name+"%"]]
if domain:
dom=[dom,domain]
ids1=self.search(dom)
2014-12-09 01:12:46 +00:00
dom=[["name","ilike","%"+name+"%"]]
level_ids=get_model('clinic.staff.level').search(dom)
2015-01-14 17:49:17 +00:00
ids2=[]
for x in self.search_read([domain],['level_id']):
if x['level_id']:
level_id=x['level_id'][0]
if level_id in level_ids:
ids2.append(x['id'])
2015-02-09 12:49:26 +00:00
dom=[["nick_name","ilike","%"+name+"%"]]
if domain:
dom=[dom,domain]
ids3=self.search(dom)
2014-12-09 01:12:46 +00:00
2015-02-09 12:49:26 +00:00
ids=list(set(ids1+ids2+ids3))
2014-12-08 14:54:25 +00:00
return self.name_get(ids,context=context)
Staff.register()