132 lines
4.2 KiB
Python
132 lines
4.2 KiB
Python
|
import time
|
||
|
|
||
|
from netforce.model import Model, fields, get_model
|
||
|
|
||
|
class HDReportDialy(Model):
|
||
|
_name="clinic.hd.report.dialy"
|
||
|
_string="HD Report Dialy"
|
||
|
_transient=True
|
||
|
|
||
|
_fields={
|
||
|
"date": fields.Date("Start-Date"),
|
||
|
"patient_id" : fields.Many2One("clinic.patient","Patient"),
|
||
|
"doctor_id" : fields.Many2One("clinic.doctor","Doctor"),
|
||
|
"nurse_id" : fields.Many2One("clinic.nurse","Nurse"),
|
||
|
#"time_start": fields.DateTime("Time start",required=False,search=True),
|
||
|
#"time_stop": fields.DateTime("Time stop",required=False,search=True),
|
||
|
"cycle_id": fields.Many2One("clinic.cycle","Cycle"),
|
||
|
}
|
||
|
|
||
|
_defaults={
|
||
|
'date': lambda *a: time.strftime("%Y-%m-%d"),
|
||
|
#'time_start': lambda *a: time.strftime("%Y-%m-%d"),
|
||
|
#'time_stop': lambda *a: time.strftime("%Y-%m-%d"),
|
||
|
}
|
||
|
|
||
|
_order="cycle_id desc"
|
||
|
|
||
|
|
||
|
def get_report_data(self,ids,context={}):
|
||
|
PATIENT_TYPE={
|
||
|
"mg":"Medical Government",
|
||
|
"sc":"Social Security",
|
||
|
"nhso":"NHSO (30฿)",
|
||
|
"personal": "Personal",
|
||
|
"others": "Others",
|
||
|
}
|
||
|
#time_start=time.strftime("%Y-%m-%d")
|
||
|
#time_stop=time.strftime("%Y-%m-%d")
|
||
|
date=time.strftime("%Y-%m-%d")
|
||
|
dom=[]
|
||
|
dom.append(['state','=','completed'])
|
||
|
if ids:
|
||
|
obj=self.browse(ids)[0]
|
||
|
if obj.date:
|
||
|
date=obj.date
|
||
|
if obj.cycle_id:
|
||
|
dom.append([
|
||
|
'cycle_id','=',obj.cycle_id.id,
|
||
|
])
|
||
|
if obj.patient_id:
|
||
|
dom.append([
|
||
|
'patient_id','=',obj.patient_id.id,
|
||
|
])
|
||
|
if obj.doctor_id:
|
||
|
dom.append([
|
||
|
'doctor_id','=',obj.doctor_id.id,
|
||
|
])
|
||
|
dom.append(['time_start', ">=", date+" 00:00:00"])
|
||
|
dom.append(['time_stop',"<=", date+" 23:59:59"])
|
||
|
|
||
|
lines=[]
|
||
|
cycles=[]
|
||
|
index=0
|
||
|
no_patient=0
|
||
|
for hd_case in get_model("clinic.hd.case").search_browse(dom,order="cycle_id.sequence"):
|
||
|
patient_type=hd_case.patient_id.type
|
||
|
patient_type=PATIENT_TYPE.get(patient_type)
|
||
|
#dialyzer_name=hd_case.dialyzers.id
|
||
|
#dialyzer_name=DIALYZER_NAME.get(dialyzer_name)
|
||
|
cycle_name=hd_case.cycle_id.name or ""
|
||
|
show_cycle=False
|
||
|
if not cycle_name in cycles:
|
||
|
cycles.append(cycle_name)
|
||
|
show_cycle=True
|
||
|
print("OK")
|
||
|
vals={
|
||
|
'color': 'success',
|
||
|
'show_cycle': False,
|
||
|
'cycle' : "",
|
||
|
'patient': "",
|
||
|
'no_patient': no_patient,
|
||
|
'patient_type' : "",
|
||
|
'doctor' : "",
|
||
|
'total' : "",
|
||
|
'rc_no' : "",
|
||
|
'dialyzer_name' : "",
|
||
|
'nurse' : "",
|
||
|
}
|
||
|
lines.append(vals)
|
||
|
no_patient=1
|
||
|
else:
|
||
|
no_patient+=1
|
||
|
index+=1
|
||
|
vals={
|
||
|
'show_cycle': show_cycle,
|
||
|
'cycle' : cycle_name,
|
||
|
'patient': hd_case.patient_id.name,
|
||
|
'patient_type' : patient_type,
|
||
|
'no_patient': 0,
|
||
|
'doctor' : hd_case.doctor_id.name,
|
||
|
'total' : hd_case.fee,
|
||
|
'rc_no' : hd_case.number,
|
||
|
'dialyzer_name' : 'DZ-xxx',
|
||
|
'nurse' : hd_case.nurse_id.name,
|
||
|
}
|
||
|
lines.append(vals)
|
||
|
|
||
|
# XXX
|
||
|
if lines:
|
||
|
vals={
|
||
|
'color': 'success',
|
||
|
'show_cycle': False,
|
||
|
'cycle' : "",
|
||
|
'patient': "",
|
||
|
'no_patient': no_patient,
|
||
|
'patient_type' : "",
|
||
|
'doctor' : "",
|
||
|
'total' : "",
|
||
|
'rc_no' : "",
|
||
|
'dialyzer_name' : "",
|
||
|
'nurse' : "",
|
||
|
}
|
||
|
lines.append(vals)
|
||
|
#XXX
|
||
|
del lines[0]
|
||
|
data={
|
||
|
'lines': lines,
|
||
|
}
|
||
|
return data
|
||
|
|
||
|
HDReportDialy.register()
|