conv_bal
watcha.h 2014-11-22 12:44:41 +07:00
parent 14164962ce
commit d229e2eba2
9 changed files with 99 additions and 43 deletions

View File

@ -3,6 +3,7 @@
<field name="state"/> <field name="state"/>
<button string="Options" dropdown="1"> <button string="Options" dropdown="1">
<item string="Compute Labor Cost" method="compute"/> <item string="Compute Labor Cost" method="compute"/>
<item string="View Schedule" method="view_schedule"/>
</button> </button>
</head> </head>
@ -43,12 +44,12 @@
<field name="total" span="6" offset="6"/> <field name="total" span="6" offset="6"/>
</group> </group>
</tab> </tab>
<tab string="Other Info">
<field name="cycle_dialy_id" domain="[['date','=',date]]"/>
</tab>
<tab string="Validation"> <tab string="Validation">
<field name="user_id"/> <field name="user_id"/>
</tab> </tab>
<tab string="Other Info">
<field name="cycle_dialy_id" domain="[['date','=',date]]"/>
</tab>
</tabs> </tabs>
<foot> <foot>
<button string="Validate" type="success" method="validate" icon="ok" states="draft" /> <button string="Validate" type="success" method="validate" icon="ok" states="draft" />

View File

@ -2,5 +2,6 @@
<!--<field name="name"/>--> <!--<field name="name"/>-->
<field name="cycle_id"/> <field name="cycle_id"/>
<field name="date"/> <field name="date"/>
<!--<field name="sequence"/>-->
<field name="state"/> <field name="state"/>
</list> </list>

View File

@ -3,10 +3,10 @@
<field name="state"/> <field name="state"/>
<button string="Options" dropdown="1"> <button string="Options" dropdown="1">
<item string="Copy" method="copy"/> <item string="Copy" method="copy"/>
<item string="Copy From" action="clinic_schedule_copy"/> <item string="Copy By Duration" action="clinic_schedule_copy"/>
<item string="Copy Nurses To Schedule" action="clinic_load_nurses"/> <item string="Load Nurse To Schedule" action="clinic_load_nurses"/>
<item string="Copy Nurses To Cycle Item" method="copy2cycle_item"/> <item string="Load Nurses To Cycle Item" method="copy2cycle_item"/>
<item string="Clear List" method="clear" states="draft"/> <item string="Clear Nurses" method="clear" states="draft"/>
</button> </button>
</head> </head>
<tabs> <tabs>
@ -16,8 +16,9 @@
<field name="lines" nolabel="1"> <field name="lines" nolabel="1">
<list> <list>
<field name="cycle_id"/> <field name="cycle_id"/>
<field name="nurse_id"/> <field name="nurse_id" onchange="onchange_nurse"/>
<field name="level_id"/> <field name="level_id"/>
<field name="cycle_item_id" readonly="1"/>
</list> </list>
</field> </field>
</group> </group>

View File

@ -74,7 +74,7 @@ class CycleItem(Model):
'var_k': _get_vark, 'var_k': _get_vark,
} }
_order="sequence" _order="date desc"
_sql_constraints=[ _sql_constraints=[
("cycle_item_uniq","unique (cycle_id,date,company_id)","Cycle item should be unique"), ("cycle_item_uniq","unique (cycle_id,date,company_id)","Cycle item should be unique"),
] ]
@ -336,5 +336,20 @@ class CycleItem(Model):
nurse=get_model('clinic.personal').browse(nurse_id) nurse=get_model('clinic.personal').browse(nurse_id)
line['level_id']=nurse.level_id.id line['level_id']=nurse.level_id.id
return data return data
def view_schedule(self,ids,context={}):
obj=self.browse(ids)[0]
date=obj.date
schd_ids=get_model('clinic.schedule').search([['date','=',date]])
schedule_id=None
if schd_ids:
schedule_id=schd_ids[0]
return {
'next': {
'name': 'clinic_schedule',
'mode': 'form',
'active_id': schedule_id,
}
}
CycleItem.register() CycleItem.register()

View File

@ -37,7 +37,6 @@ class HDCaseDialy(Model):
dom.append(['time_start','>=','%s 00:00:00'%date]) dom.append(['time_start','>=','%s 00:00:00'%date])
dom.append(['time_stop','<=','%s 23:59:59'%date]) dom.append(['time_stop','<=','%s 23:59:59'%date])
lines=[] lines=[]
no=1
for obj in get_model("clinic.hd.case").search_browse(dom): for obj in get_model("clinic.hd.case").search_browse(dom):
patient_type=utils.PATIENT_TYPE[obj.patient_id.type] patient_type=utils.PATIENT_TYPE[obj.patient_id.type]
dlz_number="" dlz_number=""
@ -48,7 +47,7 @@ class HDCaseDialy(Model):
dlz_number=dlz.number dlz_number=dlz.number
line={ line={
'cycle_name': obj.cycle_id.name, 'cycle_name': obj.cycle_id.name,
'no': no, 'cycle_sequence': obj.cycle_id.sequence,
'hd_case_number': obj.number, 'hd_case_number': obj.number,
'patient_name': obj.patient_id.name, 'patient_name': obj.patient_id.name,
'patient_type': patient_type, 'patient_type': patient_type,
@ -62,12 +61,19 @@ class HDCaseDialy(Model):
'note': obj.note or "", 'note': obj.note or "",
} }
lines.append(line) lines.append(line)
no+=1
# XXX # XXX
year=int(year)+543 year=int(year)+543
date_str='%s %s %s'%(day,month_str,year) date_str='%s %s %s'%(day,month_str,year)
slines=[]
no=1
for line in sorted(lines,key=lambda x: (x['cycle_sequence'],x['hd_case_number'])):
line['no']=no
slines.append(line)
no+=1
data={ data={
'lines': lines, 'lines': slines,
'date': date_str, 'date': date_str,
'company_name': company.name, 'company_name': company.name,
'company_parent_name': company.parent_id.name, 'company_parent_name': company.parent_id.name,

View File

@ -48,18 +48,28 @@ class LoadNurse(Model):
'lines': [], 'lines': [],
} }
cycles=set() cycles=set()
lines=[]
for line in obj.lines: for line in obj.lines:
nurse=line.nurse_id nurse=line.nurse_id
cycle_id=line.cycle_id.id cycle=line.cycle_id
cycles.update({cycle_id}) cycles.update({(cycle.id,nurse.id)})
vals['lines'].append(('create',{ lines.append({
'cycle_id': cycle_id, 'cycle_id': cycle.id,
'nurse_id': nurse.id, 'nurse_id': nurse.id,
})) 'cycle_seq': cycle.sequence,
})
for line in schedule.lines: for line in schedule.lines:
if line.cycle_id.id in list(cycles): for cycle in cycles:
line.delete() cycle_id,nurse_id=cycle
if line.cycle_id.id==cycle_id and line.nurse_id.id==nurse_id:
line.delete()
for line in sorted(lines,key=lambda x: x['cycle_seq']):
vals['lines'].append(('create',{
'cycle_id': line['cycle_id'],
'nurse_id': line['nurse_id'],
}))
schedule.write(vals) schedule.write(vals)
return { return {

View File

@ -2,6 +2,7 @@ from datetime import datetime, timedelta
from netforce.model import Model, fields, get_model from netforce.model import Model, fields, get_model
from netforce.access import get_active_company, get_active_user from netforce.access import get_active_company, get_active_user
from netforce.utils import get_data_path
class Schedule(Model): class Schedule(Model):
_name="clinic.schedule" _name="clinic.schedule"
@ -35,7 +36,6 @@ class Schedule(Model):
_fields={ _fields={
'name': fields.Char("Name", function="_get_name"), 'name': fields.Char("Name", function="_get_name"),
'cycle_item_id': fields.Many2One("clinic.cycle.item","Cycle Item", function="_get_item"),
"time_start": fields.DateTime("Time Start",required=True), "time_start": fields.DateTime("Time Start",required=True),
"time_stop": fields.DateTime("Time Stop",required=True), "time_stop": fields.DateTime("Time Stop",required=True),
'date': fields.Date("Date",required=True,search=True), 'date': fields.Date("Date",required=True,search=True),
@ -101,34 +101,45 @@ class Schedule(Model):
def copy2cycle_item(self,ids,context={}): def copy2cycle_item(self,ids,context={}):
obj=self.browse(ids)[0] obj=self.browse(ids)[0]
nurses=[] date=obj.date
items={}
cycles=set()
for line in obj.lines: for line in obj.lines:
nurse=line.nurse_id nurse=line.nurse_id
nurses.append(('create',{ cycle=line.cycle_id
'nurse_id': nurse.id, item_ids=get_model("clinic.cycle.item").search([['date','=',date],['cycle_id','=',cycle.id],['state','=','draft']])
'level_id': nurse.level_id.id, if item_ids:
})) item_id=item_ids[0]
if not obj.cycle_item_id: if not items.get(item_id):
item_id=get_model("clinic.cycle.item").create({ items[item_id]=[]
'date': obj.date, items[item_id].append(('create',{
'cycle_id': obj.cycle_id.id, 'nurse_id': nurse.id,
}) 'level_id': nurse.level_id.id,
obj.write({ }))
'cycle_item_id': item_id, line.write({
}) 'cycle_item_id': item_id,
for nurse in obj.cycle_item_id.nurses: })
nurse.delete() cycles.update({cycle.name})
obj.cycle_item_id.write({ for item_id, nurses in items.items():
'nurses': nurses, item=get_model("clinic.cycle.item").browse(item_id)
}) for nurse in item.nurses:
nurse.delete()
item.write({
'nurses': nurses,
})
msg='Load nurses to cycle item %s successfully'%(','.join(list(cycles)))
# TODO create cycle item automatically
if not items:
msg='No cycle item to copy'
return { return {
'next': { 'next': {
'name': 'clinic_cycle_item', 'name': 'clinic_schedule',
'mode': 'form', 'mode': 'form',
'active_id': obj.cycle_item_id.id, 'active_id': obj.id,
}, },
'flash': 'Copy nurses to cycle item successfully', 'flash': msg,
} }
def onchange_date(self,context={}): def onchange_date(self,context={}):
@ -166,5 +177,14 @@ class Schedule(Model):
'flash': 'List of nurse has been cleared.', 'flash': 'List of nurse has been cleared.',
} }
def onchange_nurse(self,context={}):
data=context['data']
path=context["path"]
line=get_data_path(data,path,parent=True)
nurse_id=line['nurse_id']
nurse=get_model("clinic.personal").browse(nurse_id)
line['level_id']=nurse.level_id.id
return data
Schedule.register() Schedule.register()

View File

@ -9,9 +9,11 @@ class ScheduleLine(Model):
for obj in self.browse(ids): for obj in self.browse(ids):
res[obj.id]=obj.nurse_id.level_id.id res[obj.id]=obj.nurse_id.level_id.id
return res return res
_fields={ _fields={
'schedule_id': fields.Many2One("clinic.schedule","Schedule"), 'schedule_id': fields.Many2One("clinic.schedule","Schedule"),
'cycle_id': fields.Many2One("clinic.cycle","Cycle"), 'cycle_id': fields.Many2One("clinic.cycle","Cycle"),
'cycle_item_id': fields.Many2One("clinic.cycle.item","Cycle Item"),
"nurse_id": fields.Many2One("clinic.personal","Nurse",domain=[['type','=','nurse']]), "nurse_id": fields.Many2One("clinic.personal","Nurse",domain=[['type','=','nurse']]),
'level_id': fields.Many2One("clinic.personal.level","Level",function="_get_level"), 'level_id': fields.Many2One("clinic.personal.level","Level",function="_get_level"),
} }

View File

@ -30,7 +30,7 @@
<td><a href="/ui#name=clinic_patient&active_id={{patient_id}}&mode=form">{{patient_name}}</a></td> <td><a href="/ui#name=clinic_patient&active_id={{patient_id}}&mode=form">{{patient_name}}</a></td>
<td><a href="/ui#name=clinic_personal&active_id={{doctor_id}}&mode=form">{{doctor_name}}</a></td> <td><a href="/ui#name=clinic_personal&active_id={{doctor_id}}&mode=form">{{doctor_name}}</a></td>
<td>{{patient_type}}</td> <td>{{patient_type}}</td>
<td>{{fee_amount}}</td> <td>{{currency fee_amount}}</td>
<td>-</td> <td>-</td>
<td><a href="/ui#name=clinic_hd_case&active_id={{hd_case_id}}&mode=form">{{hd_case_number}}</a></td> <td><a href="/ui#name=clinic_hd_case&active_id={{hd_case_id}}&mode=form">{{hd_case_number}}</a></td>
<td><a href="/ui#name=clinic_hd_dialyzer&active_id={{dlz_id}}&mode=form">{{dlz_number}}</a></td> <td><a href="/ui#name=clinic_hd_dialyzer&active_id={{dlz_id}}&mode=form">{{dlz_number}}</a></td>