fix
							parent
							
								
									60c55cd6f1
								
							
						
					
					
						commit
						8271ea4740
					
				|  | @ -13,3 +13,6 @@ force to print table for 1 page ->ok | ||||||
| ---- visit --- | ---- visit --- | ||||||
| - check duplicate visit | - check duplicate visit | ||||||
| - run script to take department to patient | - run script to take department to patient | ||||||
|  | 
 | ||||||
|  | --- visit board | ||||||
|  | - hide branch and department according to user profile | ||||||
|  |  | ||||||
|  | @ -77,6 +77,9 @@ | ||||||
|                 <!--<field name="cycle_id"/>--> |                 <!--<field name="cycle_id"/>--> | ||||||
|             </group> |             </group> | ||||||
|         </tab> |         </tab> | ||||||
|  |         <tab string="Location"> | ||||||
|  |             <field name="departments"/> | ||||||
|  |         </tab> | ||||||
|         <tab string="Accounting"> |         <tab string="Accounting"> | ||||||
|             <field name="partner_id" domain='[["is_patient","=","true"]]'/> |             <field name="partner_id" domain='[["is_patient","=","true"]]'/> | ||||||
|         </tab> |         </tab> | ||||||
|  |  | ||||||
|  | @ -4,6 +4,7 @@ class User(Model): | ||||||
|     _inherit="base.user" |     _inherit="base.user" | ||||||
|     _fields={ |     _fields={ | ||||||
|         'department_profile_id': fields.Many2One("clinic.department.profile","Department Profile"), |         'department_profile_id': fields.Many2One("clinic.department.profile","Department Profile"), | ||||||
|  |         'department_id': fields.Many2One("clinic.department","Current Department"), | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| User.register() | User.register() | ||||||
|  |  | ||||||
|  | @ -429,7 +429,7 @@ class HDCase(Model): | ||||||
| 
 | 
 | ||||||
|     def cancelled(self,ids,context={}): |     def cancelled(self,ids,context={}): | ||||||
|         obj=self.browse(ids)[0] |         obj=self.browse(ids)[0] | ||||||
|         obj.write({" state":"cancelled"}) |         obj.write({"state":"cancelled"}) | ||||||
| 
 | 
 | ||||||
|     def make_invoices(self,ids,context={}): |     def make_invoices(self,ids,context={}): | ||||||
|         setting=get_model("settings").browse(1,context) |         setting=get_model("settings").browse(1,context) | ||||||
|  |  | ||||||
|  | @ -68,8 +68,11 @@ class Patient(Model): | ||||||
|         res={} |         res={} | ||||||
|         for obj in self.browse(ids): |         for obj in self.browse(ids): | ||||||
|             dpt_codes=set() |             dpt_codes=set() | ||||||
|             for cline in obj.cycles: |             for dpt in obj.departments: | ||||||
|                 dpt_codes.update({cline.department_id.code}) |                 dpt_codes.update({dpt.code}) | ||||||
|  |             if not dpt_codes: | ||||||
|  |                 for cline in obj.cycles: | ||||||
|  |                     dpt_codes.update({cline.department_id.code}) | ||||||
|             if not dpt_codes: |             if not dpt_codes: | ||||||
|                 dpt_codes=[obj.department_id.code] |                 dpt_codes=[obj.department_id.code] | ||||||
|             res[obj.id]=','.join([code for code in dpt_codes if code]) |             res[obj.id]=','.join([code for code in dpt_codes if code]) | ||||||
|  | @ -184,6 +187,9 @@ class Patient(Model): | ||||||
|         if b_ids: |         if b_ids: | ||||||
|             return b_ids[0] |             return b_ids[0] | ||||||
| 
 | 
 | ||||||
|  |     def _get_dpts(self,context={}): | ||||||
|  |         return get_model("clinic.department").search([]) | ||||||
|  | 
 | ||||||
|     _defaults={ |     _defaults={ | ||||||
|         #"number": _get_number, |         #"number": _get_number, | ||||||
|         "number": "", |         "number": "", | ||||||
|  | @ -195,6 +201,7 @@ class Patient(Model): | ||||||
|         "active" : True, |         "active" : True, | ||||||
|         'state': 'admit', |         'state': 'admit', | ||||||
|         'walkin': 'no', |         'walkin': 'no', | ||||||
|  |         'departments': _get_dpts, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     _sql_constraints=("clinic_patient_key_uniq","unique(name_check,branch_id)","name should be unique"), |     _sql_constraints=("clinic_patient_key_uniq","unique(name_check,branch_id)","name should be unique"), | ||||||
|  |  | ||||||
|  | @ -20,52 +20,6 @@ class SelectCompany(Model): | ||||||
|         'department': _get_department, |         'department': _get_department, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     def _get_departments(self,context={}): |  | ||||||
|         user_id=get_active_user() |  | ||||||
|         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"]) |  | ||||||
|         set_active_user(user_id) |  | ||||||
|         return [(r["name"],r["name"]) for r in res] |  | ||||||
| 
 |  | ||||||
|     def _select(self,ids,context={}): |  | ||||||
|         obj=self.browse(ids)[0] |  | ||||||
|         if obj.department: |  | ||||||
|             user_id=get_active_user() |  | ||||||
|             user=get_model('base.user').browse(user_id) |  | ||||||
|             set_active_user(1) |  | ||||||
|             staff=None |  | ||||||
|             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, |  | ||||||
|                     }) |  | ||||||
|                 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, |  | ||||||
|                     }) |  | ||||||
|             set_active_user(user_id) |  | ||||||
|         res=super().select(ids,context) |  | ||||||
|         return res |  | ||||||
| 
 |  | ||||||
|     def get_departments(self,context={}): |     def get_departments(self,context={}): | ||||||
|         user_id=get_active_user() |         user_id=get_active_user() | ||||||
|         set_active_user(1) |         set_active_user(1) | ||||||
|  | @ -94,6 +48,9 @@ class SelectCompany(Model): | ||||||
|             user=get_model('base.user').browse(user_id) |             user=get_model('base.user').browse(user_id) | ||||||
|             set_active_user(1) |             set_active_user(1) | ||||||
|             for dpt in get_model("clinic.department").search_browse([["name","=",obj.department]]): |             for dpt in get_model("clinic.department").search_browse([["name","=",obj.department]]): | ||||||
|  |                 user.write({ | ||||||
|  |                     'department_id': dpt.id, #current department | ||||||
|  |                 }) | ||||||
|                 pf_id=None |                 pf_id=None | ||||||
|                 for pf in get_model("profile").search_read(['code','=',dpt.code]): |                 for pf in get_model("profile").search_read(['code','=',dpt.code]): | ||||||
|                     pf_id=pf['id'] |                     pf_id=pf['id'] | ||||||
|  | @ -112,15 +69,10 @@ class SelectCompany(Model): | ||||||
|         db=get_connection() |         db=get_connection() | ||||||
|         department_id=None |         department_id=None | ||||||
|         branch_id=None |         branch_id=None | ||||||
|         count=0 |         user=get_model("base.user").browse(user_id) | ||||||
|         for r in db.query("select department from select_company where write_uid=%s order by id desc",user_id): |         dpt=user.department_id | ||||||
|             for dpt in get_model("clinic.department").search_browse([['name','=',r['department']]]): |         department_id=dpt.id | ||||||
|                 department_id=dpt.id |         res={} | ||||||
|                 branch_id=dpt.branch_id.id |  | ||||||
|             count+=1 |  | ||||||
|             break |  | ||||||
|         if count<1: |  | ||||||
|             return {} |  | ||||||
|         return { |         return { | ||||||
|             'department_id': department_id, |             'department_id': department_id, | ||||||
|             'branch_id': branch_id, |             'branch_id': branch_id, | ||||||
|  |  | ||||||
|  | @ -145,6 +145,74 @@ class ClinicSetting(Model): | ||||||
|                     }) |                     }) | ||||||
| 
 | 
 | ||||||
|     def run_script(self,ids,context={}): |     def run_script(self,ids,context={}): | ||||||
|  |         user_id=get_active_user() | ||||||
|  |         if user_id !=1: | ||||||
|  |             print("Only admin!!") | ||||||
|  |             return | ||||||
|  |         # update  | ||||||
|  |         for pt in get_model("clinic.patient").search_browse([]): | ||||||
|  |             dpt=pt.department_id | ||||||
|  |             dpt_ids=set() | ||||||
|  |             for cc in pt.cycles: | ||||||
|  |                 dp=cc.department_id | ||||||
|  |                 vals={} | ||||||
|  |                 if not dp: | ||||||
|  |                     vals.update({ | ||||||
|  |                         'department_id': dpt.id, | ||||||
|  |                     }) | ||||||
|  |                 if (dp.day or "").isdigit(): | ||||||
|  |                     day=DAYS[int(dp.day)] | ||||||
|  |                     vals.update({ | ||||||
|  |                         'day': day, | ||||||
|  |                     }) | ||||||
|  |                 cc.write(vals) | ||||||
|  |                 dp=dp or dpt | ||||||
|  |                 dpt_ids.update({dp.id}) | ||||||
|  |             dpt_ids=list(dpt_ids) | ||||||
|  |             pt.write({ | ||||||
|  |                 'departments': [('set',dpt_ids)], | ||||||
|  |             }) | ||||||
|  |         return | ||||||
|  |         ### remove douplicate visit | ||||||
|  |         visits={} | ||||||
|  |         for visit in get_model("clinic.visit").search_browse([]): | ||||||
|  |             key='%s-%s'%(visit.visit_date, visit.patient_id.id) | ||||||
|  |             if not key in visits.keys(): | ||||||
|  |                 visits[key]=[] | ||||||
|  |             hd_ids=[] | ||||||
|  |             for hdcase in visit.hd_cases: | ||||||
|  |                 hd_ids.append(hdcase.id) | ||||||
|  |             visits[key].append({ | ||||||
|  |                 'id': visit.id, | ||||||
|  |                 'date': visit.visit_date, | ||||||
|  |                 'patient_id': visit.patient_id.id, | ||||||
|  |                 'state': visit.state, | ||||||
|  |                 'hd_ids': hd_ids, | ||||||
|  |             }) | ||||||
|  |         for k, vs in visits.items(): | ||||||
|  |             if len(vs) > 1: | ||||||
|  |                 vids=[] | ||||||
|  |                 for v in vs: | ||||||
|  |                     if v['state']=='pending': | ||||||
|  |                         visit=get_model("clinic.visit").browse(v['id']) | ||||||
|  |                         for hdcase in visit.hd_cases: | ||||||
|  |                             hdcase.delete() | ||||||
|  |                         visit.delete() | ||||||
|  |                         print('deleted id ', v['id'], v['patient_id'], v['date']) | ||||||
|  |                     elif len(v['hd_ids']) < 1: | ||||||
|  |                         visit=get_model("clinic.visit").browse(v['id']) | ||||||
|  |                         if visit: | ||||||
|  |                             for hdcase in visit.hd_cases: | ||||||
|  |                                 hdcase.delete() | ||||||
|  |                             visit.to_draft() | ||||||
|  |                             visit.delete() | ||||||
|  |                             print('deleted id ', v['id'], v['patient_id'], v['date']) | ||||||
|  |                     elif v['state'] in ('confirmed', 'cancelled'): | ||||||
|  |                         vids.append(v['id']) | ||||||
|  |                 print('need to delete id ', vids, vids[0]) | ||||||
|  |         print("Done!") | ||||||
|  | 
 | ||||||
|  |     def multi_department(self,ids,context={}): | ||||||
|         user_id=get_active_user() |         user_id=get_active_user() | ||||||
|         if user_id !=1: |         if user_id !=1: | ||||||
|             print("Only admin!!") |             print("Only admin!!") | ||||||
|  | @ -242,49 +310,6 @@ class ClinicSetting(Model): | ||||||
|         print('Done!') |         print('Done!') | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|         ### remove douplicate visit |  | ||||||
|         visits={} |  | ||||||
|         for visit in get_model("clinic.visit").search_browse([]): |  | ||||||
|             key='%s-%s'%(visit.visit_date, visit.patient_id.id) |  | ||||||
|             if not key in visits.keys(): |  | ||||||
|                 visits[key]=[] |  | ||||||
|             hd_ids=[] |  | ||||||
|             for hdcase in visit.hd_cases: |  | ||||||
|                 hd_ids.append(hdcase.id) |  | ||||||
|             visits[key].append({ |  | ||||||
|                 'id': visit.id, |  | ||||||
|                 'date': visit.visit_date, |  | ||||||
|                 'patient_id': visit.patient_id.id, |  | ||||||
|                 'state': visit.state, |  | ||||||
|                 'hd_ids': hd_ids, |  | ||||||
|             }) |  | ||||||
|         for k, vs in visits.items(): |  | ||||||
|             if len(vs) > 1: |  | ||||||
|                 vids=[] |  | ||||||
|                 for v in vs: |  | ||||||
|                     if v['state']=='pending': |  | ||||||
|                         visit=get_model("clinic.visit").browse(v['id']) |  | ||||||
|                         for hdcase in visit.hd_cases: |  | ||||||
|                             hdcase.delete() |  | ||||||
|                         visit.delete() |  | ||||||
|                         print('deleted id ', v['id'], v['patient_id'], v['date']) |  | ||||||
|                     elif len(v['hd_ids']) < 1: |  | ||||||
|                         visit=get_model("clinic.visit").browse(v['id']) |  | ||||||
|                         if visit: |  | ||||||
|                             for hdcase in visit.hd_cases: |  | ||||||
|                                 hdcase.delete() |  | ||||||
|                             visit.to_draft() |  | ||||||
|                             visit.delete() |  | ||||||
|                             print('deleted id ', v['id'], v['patient_id'], v['date']) |  | ||||||
|                     elif v['state'] in ('confirmed', 'cancelled'): |  | ||||||
|                         vids.append(v['id']) |  | ||||||
|                 print('need to delete id ', vids, vids[0]) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|         #files=['SS3-1.csv','SS4-1.csv','SS4.csv'] |  | ||||||
|         #self.update_patient_file(files) |  | ||||||
|         print("Done!") |  | ||||||
| 
 |  | ||||||
|     def update_patient_file(self,files=[]): |     def update_patient_file(self,files=[]): | ||||||
|         import csv |         import csv | ||||||
|         for _file in files: |         for _file in files: | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue