Explorar el Código

Merge branch 'master' of http://git.shengws.com/csx/gdyb

csx hace 3 años
padre
commit
2ce06d4946

+ 9 - 0
controllers/sg/his_api_controller.go Ver fichero

@@ -1645,6 +1645,15 @@ func (c *HisApiController) GetRegisterInfo() {
1645 1645
 	config, _ := service.GetMedicalInsuranceConfig(adminInfo.CurrentOrgId)
1646 1646
 	roles, _ := service.GetAdminUserInfoByID(adminInfo.CurrentOrgId, admin_user_id)
1647 1647
 
1648
+	his, _ := service.GetHisPatientInfoTwo(adminInfo.CurrentOrgId, patient.ID, recordDateTime)
1649
+	if len(his) >= 1 {
1650
+		order, _ := service.GetNewHisOrderTwo(adminInfo.CurrentOrgId, his[len(his)-1].Number, his[len(his)-1].PatientId, recordDateTime)
1651
+		if len(his) >= 1 && order.ID == 0 {
1652
+			c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeHisPatientParamWrong)
1653
+			return
1654
+		}
1655
+	}
1656
+
1648 1657
 	if config.IsOpen == 1 {
1649 1658
 		api := "http://127.0.0.1:9532/" + "gdyb/one?cert_no=" + patient.IdCardNo + "&org_name=" + miConfig.OrgName + "&doctor=" + patientPrescription.Doctor + "&fixmedins_code=" + miConfig.Code + "&insuplc_admdvs=" + miConfig.InsuplcAdmdvs + "&mdtrtarea_admvs=" + miConfig.MdtrtareaAdmvs + "&secret_key=" + miConfig.SecretKey + "&certificates=" + strconv.FormatInt(certificates, 10)
1650 1659
 		resp, requestErr := http.Get(api)

+ 330 - 323
controllers/sz/sz_his_api_controller.go Ver fichero

@@ -862,7 +862,17 @@ func (c *SZHisApiController) GetRegisterInfo() {
862 862
 	//doctorInfo, _ := service.GetAdminUserInfoByID(adminInfo.CurrentOrgId, doctor)
863 863
 	doctorDepartment, _ := service.GetDepartMentDetail(department)
864 864
 	adminRole, _ := service.GetAdminUserInfoByID(adminInfo.CurrentOrgId, admin_user_id)
865
-	his, _ := service.GetHisPatientInfo(adminInfo.CurrentOrgId, patient_id, theTime.Unix())
865
+	//his, _ := service.GetHisPatientInfo(adminInfo.CurrentOrgId, patient_id, theTime.Unix())
866
+
867
+	his, _ := service.GetHisPatientInfoTwo(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
868
+	if len(his) >= 1 {
869
+		order, _ := service.GetNewHisOrderTwo(adminInfo.CurrentOrgId, his[len(his)-1].Number, his[len(his)-1].PatientId, theTime.Unix())
870
+		if len(his) >= 1 && order.ID == 0 {
871
+			c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeHisPatientParamWrong)
872
+			return
873
+		}
874
+	}
875
+
866 876
 	var custom_code string
867 877
 	var custom_project_name string
868 878
 	var allPrice float64
@@ -897,351 +907,347 @@ func (c *SZHisApiController) GetRegisterInfo() {
897 907
 
898 908
 		break
899 909
 	}
900
-	if his.ID == 0 {
901
-		var opera_name string
902
-		var opera_code string
903
-		if adminRole.ID == 0 {
904
-			opera_name = "管理员"
905
-			opera_code = "01"
906
-		} else {
907
-			opera_name = adminRole.UserName
908
-			opera_code = strconv.FormatInt(admin_user_id, 10)
909
-		}
910
-		month := time.Unix(1557042972, 0).Format("1")
911
-		year := time.Now().Format("2006")
912
-		month = time.Now().Format("01")
913
-		day := time.Now().Format("02")
914
-		//流水号
915
-		number := miConfig.Code + year + month + day +
916
-			fmt.Sprintf("%07v", rand.New(rand.NewSource(time.Now().UnixNano())).Int31n(10000000)) // 定点协议机构编码(5位)+日期(8位)+流水号(7位)
917
-		mz_number := miConfig.Code + year + month + day +
910
+	var opera_name string
911
+	var opera_code string
912
+	if adminRole.ID == 0 {
913
+		opera_name = "管理员"
914
+		opera_code = "01"
915
+	} else {
916
+		opera_name = adminRole.UserName
917
+		opera_code = strconv.FormatInt(admin_user_id, 10)
918
+	}
919
+	month := time.Unix(1557042972, 0).Format("1")
920
+	year := time.Now().Format("2006")
921
+	month = time.Now().Format("01")
922
+	day := time.Now().Format("02")
923
+	//流水号
924
+	number := miConfig.Code + year + month + day +
925
+		fmt.Sprintf("%07v", rand.New(rand.NewSource(time.Now().UnixNano())).Int31n(10000000)) // 定点协议机构编码(5位)+日期(8位)+流水号(7位)
926
+	mz_number := miConfig.Code + year + month + day +
927
+		fmt.Sprintf("%07v", rand.New(rand.NewSource(time.Now().UnixNano())).Int31n(10000000))
928
+
929
+	//1.判断读卡类型
930
+	//2.读卡 获取交易验证码,医疗证号,发卡地区行政区划代码
931
+	yiliao_number, id_card_number, verifyCode, version_code, health_card_no, _, ret4 := ReadBasCardGetNumber("MZ002" + "|" + number + "|" + miConfig.Code + "|")
932
+	fmt.Println(yiliao_number)
933
+	fmt.Println(id_card_number)
934
+	fmt.Println(verifyCode)
935
+	fmt.Println(version_code)
936
+	fmt.Println(ret4)
937
+
938
+	dept_code := doctorDepartment.Number
939
+
940
+	is_yidi = 1
941
+	tempPatient, _ := service.GetPatientByNumber(id_card_number, adminInfo.CurrentOrgId)
942
+	//根据业务的人员信息跟设备读社保卡获取的信息进行匹配,判断是否为同一个人,相同则进行挂号操作,不同则报错
943
+	fmt.Println(tempPatient.ID)
944
+	fmt.Println(patient_id)
945
+
946
+	if tempPatient.ID == patient_id {
947
+		temp_mz_number := miConfig.Code + year + month + day +
918 948
 			fmt.Sprintf("%07v", rand.New(rand.NewSource(time.Now().UnixNano())).Int31n(10000000))
919
-
920
-		//1.判断读卡类型
921
-		//2.读卡 获取交易验证码,医疗证号,发卡地区行政区划代码
922
-		yiliao_number, id_card_number, verifyCode, version_code, health_card_no, _, ret4 := ReadBasCardGetNumber("MZ002" + "|" + number + "|" + miConfig.Code + "|")
923
-		fmt.Println(yiliao_number)
924
-		fmt.Println(id_card_number)
925
-		fmt.Println(verifyCode)
926
-		fmt.Println(version_code)
927
-		fmt.Println(ret4)
928
-
929
-		dept_code := doctorDepartment.Number
930
-
931
-		is_yidi = 1
932
-		tempPatient, _ := service.GetPatientByNumber(id_card_number, adminInfo.CurrentOrgId)
933
-		//根据业务的人员信息跟设备读社保卡获取的信息进行匹配,判断是否为同一个人,相同则进行挂号操作,不同则报错
934
-		fmt.Println(tempPatient.ID)
935
-		fmt.Println(patient_id)
936
-
937
-		if tempPatient.ID == patient_id {
938
-			temp_mz_number := miConfig.Code + year + month + day +
939
-				fmt.Sprintf("%07v", rand.New(rand.NewSource(time.Now().UnixNano())).Int31n(10000000))
940
-			tempVerifyCode, tempVersionCode := ReadCardGetCode("XX001" + "|" + temp_mz_number + "|" + miConfig.Code)
941
-
942
-			yiliao_number = "%GALMAFXJGKUKZNKWAIUH?;07857319025346309758?"
943
-
944
-			result001 := service.SzybXX001(opera_name, opera_code, miConfig.Code, yiliao_number, tempVerifyCode, temp_mz_number, tempVersionCode)
945
-
946
-			if ret4 == 0 { //本地卡流程
947
-				if is_yidi == 1 {
948
-
949
-					//var dat2 map[string]interface{}
950
-					//if err := json.Unmarshal([]byte(result001), &dat2); err == nil {
951
-					//	fmt.Println(dat2)
952
-					//} else {
953
-					//	fmt.Println(err)
954
-					//}
955
-					//userJSONBytes2, _ := json.Marshal(dat2)
956
-					//var res2 ResultMZ001
957
-					//if err := json.Unmarshal(userJSONBytes2, &res2); err != nil {
958
-					//	utils.ErrorLog("解析失败:%v", err)
959
-					//}
960
-
961
-					//本地就医流程
962
-					//挂号
963
-					resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, dept_code, yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
964
-					var dat map[string]interface{}
965
-					if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
966
-						fmt.Println(dat)
967
-					} else {
968
-						fmt.Println(err)
969
-					}
970
-					userJSONBytes, _ := json.Marshal(dat)
971
-					var res ResultOne
972
-					if err := json.Unmarshal(userJSONBytes, &res); err != nil {
973
-						utils.ErrorLog("解析失败:%v", err)
974
-						c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
975
-						return
949
+		tempVerifyCode, tempVersionCode := ReadCardGetCode("XX001" + "|" + temp_mz_number + "|" + miConfig.Code)
950
+
951
+		yiliao_number = "%GALMAFXJGKUKZNKWAIUH?;07857319025346309758?"
952
+
953
+		result001 := service.SzybXX001(opera_name, opera_code, miConfig.Code, yiliao_number, tempVerifyCode, temp_mz_number, tempVersionCode)
954
+
955
+		if ret4 == 0 { //本地卡流程
956
+			if is_yidi == 1 {
957
+
958
+				//var dat2 map[string]interface{}
959
+				//if err := json.Unmarshal([]byte(result001), &dat2); err == nil {
960
+				//	fmt.Println(dat2)
961
+				//} else {
962
+				//	fmt.Println(err)
963
+				//}
964
+				//userJSONBytes2, _ := json.Marshal(dat2)
965
+				//var res2 ResultMZ001
966
+				//if err := json.Unmarshal(userJSONBytes2, &res2); err != nil {
967
+				//	utils.ErrorLog("解析失败:%v", err)
968
+				//}
969
+
970
+				//本地就医流程
971
+				//挂号
972
+				resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, dept_code, yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
973
+				var dat map[string]interface{}
974
+				if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
975
+					fmt.Println(dat)
976
+				} else {
977
+					fmt.Println(err)
978
+				}
979
+				userJSONBytes, _ := json.Marshal(dat)
980
+				var res ResultOne
981
+				if err := json.Unmarshal(userJSONBytes, &res); err != nil {
982
+					utils.ErrorLog("解析失败:%v", err)
983
+					c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
984
+					return
985
+				}
986
+				if res.Transreturncode == "00000000" {
987
+					his := models.VMHisPatient{
988
+						Name:                   name,
989
+						Gender:                 gender,
990
+						Birthday:               birthUnix,
991
+						MedicalTreatmentType:   medical_care,
992
+						IdType:                 certificates,
993
+						IdCardNo:               id_card,
994
+						BalanceAccountsType:    settlementValue,
995
+						SocialType:             social_type,
996
+						MedicalInsuranceNumber: medical_insurance_card,
997
+						RegisterType:           register_type,
998
+						RegisterCost:           registration_fee,
999
+						TreatmentCost:          medical_expenses,
1000
+						Status:                 1,
1001
+						Ctime:                  time.Now().Unix(),
1002
+						Mtime:                  time.Now().Unix(),
1003
+						Iinfo:                  resp_result,
1004
+						PatientId:              patient.ID,
1005
+						RecordDate:             theTime.Unix(),
1006
+						UserOrgId:              adminInfo.CurrentOrgId,
1007
+						AdminUserId:            admin_user_id,
1008
+						IsReturn:               1,
1009
+						IdCardType:             id_card_type,
1010
+						Doctor:                 doctor,
1011
+						Departments:            department,
1012
+						YiliaoNumber:           yiliao_number,
1013
+						MzNumber:               number,
1014
+						Number:                 mz_number,
1015
+						PsnNo:                  health_card_no,
1016
+						PatientInfo:            result001,
976 1017
 					}
977
-					if res.Transreturncode == "00000000" {
978
-						his := models.VMHisPatient{
979
-							Name:                   name,
980
-							Gender:                 gender,
981
-							Birthday:               birthUnix,
982
-							MedicalTreatmentType:   medical_care,
983
-							IdType:                 certificates,
984
-							IdCardNo:               id_card,
985
-							BalanceAccountsType:    settlementValue,
986
-							SocialType:             social_type,
987
-							MedicalInsuranceNumber: medical_insurance_card,
988
-							RegisterType:           register_type,
989
-							RegisterCost:           registration_fee,
990
-							TreatmentCost:          medical_expenses,
991
-							Status:                 1,
992
-							Ctime:                  time.Now().Unix(),
993
-							Mtime:                  time.Now().Unix(),
994
-							Iinfo:                  resp_result,
995
-							PatientId:              patient.ID,
996
-							RecordDate:             theTime.Unix(),
997
-							UserOrgId:              adminInfo.CurrentOrgId,
998
-							AdminUserId:            admin_user_id,
999
-							IsReturn:               1,
1000
-							IdCardType:             id_card_type,
1001
-							Doctor:                 doctor,
1002
-							Departments:            department,
1003
-							YiliaoNumber:           yiliao_number,
1004
-							MzNumber:               number,
1005
-							Number:                 mz_number,
1006
-							PsnNo:                  health_card_no,
1007
-							PatientInfo:            result001,
1008
-						}
1009
-						service.CreateHisPatientTwo(&his)
1010
-						lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1011
-						if len(lists) == 1 {
1012
-							service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1013
-						}
1014
-						c.ServeSuccessJSON(map[string]interface{}{
1015
-							"msg": "挂号成功",
1016
-						})
1017
-					} else {
1018
-						c.ServeSuccessJSON(map[string]interface{}{
1019
-							"failed_code": -10,
1020
-							"msg":         res.Transreturnmessage,
1021
-						})
1022
-						return
1018
+					service.CreateHisPatientTwo(&his)
1019
+					lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1020
+					if len(lists) == 1 {
1021
+						service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1023 1022
 					}
1023
+					c.ServeSuccessJSON(map[string]interface{}{
1024
+						"msg": "挂号成功",
1025
+					})
1026
+				} else {
1027
+					c.ServeSuccessJSON(map[string]interface{}{
1028
+						"failed_code": -10,
1029
+						"msg":         res.Transreturnmessage,
1030
+					})
1031
+					return
1032
+				}
1024 1033
 
1034
+			} else {
1035
+				//异地就医流程
1036
+				//异地走鉴权流程
1037
+				//authResult := CardAuth(number)
1038
+				//fmt.Println(authResult)
1039
+
1040
+				//tempPatient, _ := service.GetPatientByNumber(id_card_number, adminInfo.CurrentOrgId)
1041
+				//if tempPatient.ID == patient_id {
1042
+				resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, "0305", yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
1043
+				var dat map[string]interface{}
1044
+				if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
1045
+					fmt.Println(dat)
1025 1046
 				} else {
1026
-					//异地就医流程
1027
-					//异地走鉴权流程
1028
-					//authResult := CardAuth(number)
1029
-					//fmt.Println(authResult)
1030
-
1031
-					//tempPatient, _ := service.GetPatientByNumber(id_card_number, adminInfo.CurrentOrgId)
1032
-					//if tempPatient.ID == patient_id {
1033
-					resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, "0305", yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
1034
-					var dat map[string]interface{}
1035
-					if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
1036
-						fmt.Println(dat)
1037
-					} else {
1038
-						fmt.Println(err)
1039
-					}
1047
+					fmt.Println(err)
1048
+				}
1040 1049
 
1041
-					userJSONBytes, _ := json.Marshal(dat)
1050
+				userJSONBytes, _ := json.Marshal(dat)
1042 1051
 
1043
-					var res ResultOne
1044
-					if err := json.Unmarshal(userJSONBytes, &res); err != nil {
1045
-						utils.ErrorLog("解析失败:%v", err)
1046
-						c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
1047
-						return
1052
+				var res ResultOne
1053
+				if err := json.Unmarshal(userJSONBytes, &res); err != nil {
1054
+					utils.ErrorLog("解析失败:%v", err)
1055
+					c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
1056
+					return
1057
+				}
1058
+				if res.Transreturncode == "00000000" {
1059
+					his := models.VMHisPatient{
1060
+						Name:                   name,
1061
+						Gender:                 gender,
1062
+						Birthday:               birthUnix,
1063
+						MedicalTreatmentType:   medical_care,
1064
+						IdType:                 certificates,
1065
+						IdCardNo:               id_card,
1066
+						BalanceAccountsType:    settlementValue,
1067
+						SocialType:             social_type,
1068
+						MedicalInsuranceNumber: medical_insurance_card,
1069
+						RegisterType:           register_type,
1070
+						RegisterCost:           registration_fee,
1071
+						TreatmentCost:          medical_expenses,
1072
+						Status:                 1,
1073
+						Ctime:                  time.Now().Unix(),
1074
+						Mtime:                  time.Now().Unix(),
1075
+						Iinfo:                  resp_result,
1076
+						PatientId:              patient.ID,
1077
+						RecordDate:             theTime.Unix(),
1078
+						UserOrgId:              adminInfo.CurrentOrgId,
1079
+						AdminUserId:            admin_user_id,
1080
+						IsReturn:               1,
1081
+						IdCardType:             id_card_type,
1082
+						Doctor:                 doctor,
1083
+						Departments:            department,
1084
+						YiliaoNumber:           yiliao_number,
1085
+						MzNumber:               number,
1086
+						Number:                 mz_number,
1087
+						PsnNo:                  health_card_no,
1088
+						PatientInfo:            result001,
1048 1089
 					}
1049
-					if res.Transreturncode == "00000000" {
1050
-						his := models.VMHisPatient{
1051
-							Name:                   name,
1052
-							Gender:                 gender,
1053
-							Birthday:               birthUnix,
1054
-							MedicalTreatmentType:   medical_care,
1055
-							IdType:                 certificates,
1056
-							IdCardNo:               id_card,
1057
-							BalanceAccountsType:    settlementValue,
1058
-							SocialType:             social_type,
1059
-							MedicalInsuranceNumber: medical_insurance_card,
1060
-							RegisterType:           register_type,
1061
-							RegisterCost:           registration_fee,
1062
-							TreatmentCost:          medical_expenses,
1063
-							Status:                 1,
1064
-							Ctime:                  time.Now().Unix(),
1065
-							Mtime:                  time.Now().Unix(),
1066
-							Iinfo:                  resp_result,
1067
-							PatientId:              patient.ID,
1068
-							RecordDate:             theTime.Unix(),
1069
-							UserOrgId:              adminInfo.CurrentOrgId,
1070
-							AdminUserId:            admin_user_id,
1071
-							IsReturn:               1,
1072
-							IdCardType:             id_card_type,
1073
-							Doctor:                 doctor,
1074
-							Departments:            department,
1075
-							YiliaoNumber:           yiliao_number,
1076
-							MzNumber:               number,
1077
-							Number:                 mz_number,
1078
-							PsnNo:                  health_card_no,
1079
-							PatientInfo:            result001,
1080
-						}
1081
-						service.CreateHisPatientTwo(&his)
1082
-						lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1083
-						if len(lists) == 1 {
1084
-							service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1085
-						}
1086
-						c.ServeSuccessJSON(map[string]interface{}{
1087
-							"msg": "挂号成功",
1088
-						})
1089
-					} else {
1090
-						c.ServeSuccessJSON(map[string]interface{}{
1091
-							"failed_code": -10,
1092
-							"msg":         res.Transreturnmessage,
1093
-						})
1094
-						return
1090
+					service.CreateHisPatientTwo(&his)
1091
+					lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1092
+					if len(lists) == 1 {
1093
+						service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1095 1094
 					}
1096
-
1095
+					c.ServeSuccessJSON(map[string]interface{}{
1096
+						"msg": "挂号成功",
1097
+					})
1098
+				} else {
1099
+					c.ServeSuccessJSON(map[string]interface{}{
1100
+						"failed_code": -10,
1101
+						"msg":         res.Transreturnmessage,
1102
+					})
1103
+					return
1097 1104
 				}
1098 1105
 
1099
-			} else { //异地卡流程
1100
-				//readCardBasResult := ReadCardBasHSM(number)
1101
-				//fmt.Println(readCardBasResult)
1102
-				//是否异地就医,是的话走鉴权流程,不是的话走门诊挂号
1103
-				if is_yidi == 1 { //1本地就医
1104
-					resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, "0305", yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
1105
-					var dat map[string]interface{}
1106
-					if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
1107
-						fmt.Println(dat)
1108
-					} else {
1109
-						fmt.Println(err)
1110
-					}
1106
+			}
1111 1107
 
1112
-					userJSONBytes, _ := json.Marshal(dat)
1108
+		} else { //异地卡流程
1109
+			//readCardBasResult := ReadCardBasHSM(number)
1110
+			//fmt.Println(readCardBasResult)
1111
+			//是否异地就医,是的话走鉴权流程,不是的话走门诊挂号
1112
+			if is_yidi == 1 { //1本地就医
1113
+				resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, "0305", yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
1114
+				var dat map[string]interface{}
1115
+				if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
1116
+					fmt.Println(dat)
1117
+				} else {
1118
+					fmt.Println(err)
1119
+				}
1113 1120
 
1114
-					var res ResultOne
1115
-					if err := json.Unmarshal(userJSONBytes, &res); err != nil {
1116
-						utils.ErrorLog("解析失败:%v", err)
1117
-						c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
1118
-						return
1121
+				userJSONBytes, _ := json.Marshal(dat)
1122
+
1123
+				var res ResultOne
1124
+				if err := json.Unmarshal(userJSONBytes, &res); err != nil {
1125
+					utils.ErrorLog("解析失败:%v", err)
1126
+					c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
1127
+					return
1128
+				}
1129
+				if res.Transreturncode == "00000000" {
1130
+					his := models.VMHisPatient{
1131
+						Name:                   name,
1132
+						Gender:                 gender,
1133
+						Birthday:               birthUnix,
1134
+						MedicalTreatmentType:   medical_care,
1135
+						IdType:                 certificates,
1136
+						IdCardNo:               id_card,
1137
+						BalanceAccountsType:    settlementValue,
1138
+						SocialType:             social_type,
1139
+						MedicalInsuranceNumber: medical_insurance_card,
1140
+						RegisterType:           register_type,
1141
+						RegisterCost:           registration_fee,
1142
+						TreatmentCost:          medical_expenses,
1143
+						Status:                 1,
1144
+						Ctime:                  time.Now().Unix(),
1145
+						Mtime:                  time.Now().Unix(),
1146
+						Iinfo:                  resp_result,
1147
+						PatientId:              patient.ID,
1148
+						RecordDate:             theTime.Unix(),
1149
+						UserOrgId:              adminInfo.CurrentOrgId,
1150
+						AdminUserId:            admin_user_id,
1151
+						IsReturn:               1,
1152
+						IdCardType:             id_card_type,
1153
+						Doctor:                 doctor,
1154
+						Departments:            department,
1155
+						YiliaoNumber:           yiliao_number,
1156
+						MzNumber:               number,
1157
+						Number:                 mz_number,
1158
+						PsnNo:                  health_card_no,
1159
+						PatientInfo:            result001,
1119 1160
 					}
1120
-					if res.Transreturncode == "00000000" {
1121
-						his := models.VMHisPatient{
1122
-							Name:                   name,
1123
-							Gender:                 gender,
1124
-							Birthday:               birthUnix,
1125
-							MedicalTreatmentType:   medical_care,
1126
-							IdType:                 certificates,
1127
-							IdCardNo:               id_card,
1128
-							BalanceAccountsType:    settlementValue,
1129
-							SocialType:             social_type,
1130
-							MedicalInsuranceNumber: medical_insurance_card,
1131
-							RegisterType:           register_type,
1132
-							RegisterCost:           registration_fee,
1133
-							TreatmentCost:          medical_expenses,
1134
-							Status:                 1,
1135
-							Ctime:                  time.Now().Unix(),
1136
-							Mtime:                  time.Now().Unix(),
1137
-							Iinfo:                  resp_result,
1138
-							PatientId:              patient.ID,
1139
-							RecordDate:             theTime.Unix(),
1140
-							UserOrgId:              adminInfo.CurrentOrgId,
1141
-							AdminUserId:            admin_user_id,
1142
-							IsReturn:               1,
1143
-							IdCardType:             id_card_type,
1144
-							Doctor:                 doctor,
1145
-							Departments:            department,
1146
-							YiliaoNumber:           yiliao_number,
1147
-							MzNumber:               number,
1148
-							Number:                 mz_number,
1149
-							PsnNo:                  health_card_no,
1150
-							PatientInfo:            result001,
1151
-						}
1152
-						service.CreateHisPatientTwo(&his)
1153
-						lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1154
-						if len(lists) == 1 {
1155
-							service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1156
-						}
1157
-						c.ServeSuccessJSON(map[string]interface{}{
1158
-							"msg": "挂号成功",
1159
-						})
1160
-					} else {
1161
-						c.ServeSuccessJSON(map[string]interface{}{
1162
-							"failed_code": -10,
1163
-							"msg":         res.Transreturnmessage,
1164
-						})
1165
-						return
1161
+					service.CreateHisPatientTwo(&his)
1162
+					lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1163
+					if len(lists) == 1 {
1164
+						service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1166 1165
 					}
1166
+					c.ServeSuccessJSON(map[string]interface{}{
1167
+						"msg": "挂号成功",
1168
+					})
1169
+				} else {
1170
+					c.ServeSuccessJSON(map[string]interface{}{
1171
+						"failed_code": -10,
1172
+						"msg":         res.Transreturnmessage,
1173
+					})
1174
+					return
1175
+				}
1167 1176
 
1168
-				} else { //异地就医需要走鉴权流程
1169
-					//authResult := CardAuth(number)
1170
-					//fmt.Println(authResult)
1171
-					resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, "0305", yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
1172
-					var dat map[string]interface{}
1173
-					if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
1174
-						fmt.Println(dat)
1175
-					} else {
1176
-						fmt.Println(err)
1177
-					}
1177
+			} else { //异地就医需要走鉴权流程
1178
+				//authResult := CardAuth(number)
1179
+				//fmt.Println(authResult)
1180
+				resp_result := service.SzybMZ002(opera_name, opera_code, miConfig.Code, "0305", yiliao_number, verifyCode, number, mz_number, version_code, custom_code, custom_project_name, allPrice, medical_care)
1181
+				var dat map[string]interface{}
1182
+				if err := json.Unmarshal([]byte(resp_result), &dat); err == nil {
1183
+					fmt.Println(dat)
1184
+				} else {
1185
+					fmt.Println(err)
1186
+				}
1178 1187
 
1179
-					userJSONBytes, _ := json.Marshal(dat)
1188
+				userJSONBytes, _ := json.Marshal(dat)
1180 1189
 
1181
-					var res ResultOne
1182
-					if err := json.Unmarshal(userJSONBytes, &res); err != nil {
1183
-						utils.ErrorLog("解析失败:%v", err)
1184
-						c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
1185
-						return
1190
+				var res ResultOne
1191
+				if err := json.Unmarshal(userJSONBytes, &res); err != nil {
1192
+					utils.ErrorLog("解析失败:%v", err)
1193
+					c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
1194
+					return
1195
+				}
1196
+				if res.Transreturncode == "00000000" {
1197
+					his := models.VMHisPatient{
1198
+						Name:                   name,
1199
+						Gender:                 gender,
1200
+						Birthday:               birthUnix,
1201
+						MedicalTreatmentType:   medical_care,
1202
+						IdType:                 certificates,
1203
+						IdCardNo:               id_card,
1204
+						BalanceAccountsType:    settlementValue,
1205
+						SocialType:             social_type,
1206
+						MedicalInsuranceNumber: medical_insurance_card,
1207
+						RegisterType:           register_type,
1208
+						RegisterCost:           registration_fee,
1209
+						TreatmentCost:          medical_expenses,
1210
+						Status:                 1,
1211
+						Ctime:                  time.Now().Unix(),
1212
+						Mtime:                  time.Now().Unix(),
1213
+						Iinfo:                  resp_result,
1214
+						PatientId:              patient.ID,
1215
+						RecordDate:             theTime.Unix(),
1216
+						UserOrgId:              adminInfo.CurrentOrgId,
1217
+						AdminUserId:            admin_user_id,
1218
+						IsReturn:               1,
1219
+						IdCardType:             id_card_type,
1220
+						Doctor:                 doctor,
1221
+						Departments:            department,
1222
+						YiliaoNumber:           yiliao_number,
1223
+						MzNumber:               number,
1224
+						Number:                 mz_number,
1225
+						PsnNo:                  health_card_no,
1226
+						PatientInfo:            result001,
1186 1227
 					}
1187
-					if res.Transreturncode == "00000000" {
1188
-						his := models.VMHisPatient{
1189
-							Name:                   name,
1190
-							Gender:                 gender,
1191
-							Birthday:               birthUnix,
1192
-							MedicalTreatmentType:   medical_care,
1193
-							IdType:                 certificates,
1194
-							IdCardNo:               id_card,
1195
-							BalanceAccountsType:    settlementValue,
1196
-							SocialType:             social_type,
1197
-							MedicalInsuranceNumber: medical_insurance_card,
1198
-							RegisterType:           register_type,
1199
-							RegisterCost:           registration_fee,
1200
-							TreatmentCost:          medical_expenses,
1201
-							Status:                 1,
1202
-							Ctime:                  time.Now().Unix(),
1203
-							Mtime:                  time.Now().Unix(),
1204
-							Iinfo:                  resp_result,
1205
-							PatientId:              patient.ID,
1206
-							RecordDate:             theTime.Unix(),
1207
-							UserOrgId:              adminInfo.CurrentOrgId,
1208
-							AdminUserId:            admin_user_id,
1209
-							IsReturn:               1,
1210
-							IdCardType:             id_card_type,
1211
-							Doctor:                 doctor,
1212
-							Departments:            department,
1213
-							YiliaoNumber:           yiliao_number,
1214
-							MzNumber:               number,
1215
-							Number:                 mz_number,
1216
-							PsnNo:                  health_card_no,
1217
-							PatientInfo:            result001,
1218
-						}
1219
-						service.CreateHisPatientTwo(&his)
1220
-						lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1221
-						if len(lists) == 1 {
1222
-							service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1223
-						}
1224
-						c.ServeSuccessJSON(map[string]interface{}{
1225
-							"msg": "挂号成功",
1226
-						})
1227
-					} else {
1228
-						c.ServeSuccessJSON(map[string]interface{}{
1229
-							"failed_code": -10,
1230
-							"msg":         res.Transreturnmessage,
1231
-						})
1232
-						return
1228
+					service.CreateHisPatientTwo(&his)
1229
+					lists, _ := service.GetHisPatientInfoList(adminInfo.CurrentOrgId, patient.ID, theTime.Unix())
1230
+					if len(lists) == 1 {
1231
+						service.UpdateHisPrescriptionHisID(his.ID, patient.ID, theTime.Unix(), adminInfo.CurrentOrgId)
1233 1232
 					}
1234
-
1233
+					c.ServeSuccessJSON(map[string]interface{}{
1234
+						"msg": "挂号成功",
1235
+					})
1236
+				} else {
1237
+					c.ServeSuccessJSON(map[string]interface{}{
1238
+						"failed_code": -10,
1239
+						"msg":         res.Transreturnmessage,
1240
+					})
1241
+					return
1235 1242
 				}
1243
+
1236 1244
 			}
1237
-		} else {
1238
-			c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeNoPateintException)
1239
-			return
1240 1245
 		}
1241 1246
 	} else {
1242
-		c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeRegisterRepeatException)
1247
+		c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeNoPateintException)
1243 1248
 		return
1244 1249
 	}
1250
+
1245 1251
 }
1246 1252
 
1247 1253
 //func (c *SZHisApiController) GetInfo() {
@@ -2172,7 +2178,7 @@ func (c *SZHisApiController) GetSettleInfo() {
2172 2178
 	var end_time int64
2173 2179
 
2174 2180
 	if settle_accounts_type == 1 { //日结
2175
-		prescriptions, _ = service.GetHisPrescription(adminUser.CurrentOrgId, patient_id, recordDateTime)
2181
+		prescriptions, _ = service.GetNewHisPrescription(adminUser.CurrentOrgId, his_patient_id, recordDateTime)
2176 2182
 
2177 2183
 	} else { //月结
2178 2184
 		start_time_str := c.GetString("start_time")
@@ -2215,7 +2221,7 @@ func (c *SZHisApiController) GetSettleInfo() {
2215 2221
 	adminRole_two, _ := service.GetAdminUserInfoByID(adminUser.CurrentOrgId, patientPrescription.DoctorId)
2216 2222
 
2217 2223
 	adminRole, _ := service.GetAdminUserInfoByID(adminUser.CurrentOrgId, admin_user_id)
2218
-	his, err := service.GetNewHisPatientInfo(adminUser.CurrentOrgId, his_patient_id, recordDateTime)
2224
+	his, err := service.GetHisPatientInfo(adminUser.CurrentOrgId, his_patient_id, recordDateTime)
2219 2225
 	mz_number := his.Number
2220 2226
 	number := miConfig.Code + year + month + day +
2221 2227
 		fmt.Sprintf("%07v", rand.New(rand.NewSource(time.Now().UnixNano())).Int31n(10000000)) // 定点协议机构编码(5位)+日期(8位)+流水号(7位)
@@ -2395,7 +2401,7 @@ func (c *SZHisApiController) GetSettleInfo() {
2395 2401
 			SettleAccountsDate:  recordDateTime,
2396 2402
 			Ctime:               time.Now().Unix(),
2397 2403
 			Mtime:               time.Now().Unix(),
2398
-			Status:              1,
2404
+			Status:              0,
2399 2405
 			Number:              chrg_bchno,
2400 2406
 			Infcode:             0,
2401 2407
 			WarnMsg:             "",
@@ -2512,6 +2518,7 @@ func (c *SZHisApiController) GetSettleInfo() {
2512 2518
 
2513 2519
 				if res.Transreturncode == "00000000" {
2514 2520
 					order.OrderStatus = 2
2521
+					order.Status = 1
2515 2522
 					order.PayWay = pay_way
2516 2523
 					order.PayPrice = pay_price
2517 2524
 					order.PayCardNo = pay_card_no

+ 3 - 0
enums/error_code.go Ver fichero

@@ -255,6 +255,8 @@ const ( // ErrorCode
255 255
 	ErrorCodeHospitalNoExistDataException = 30009
256 256
 
257 257
 	ErrorCodeHospitalExistDataException = 300010
258
+
259
+	ErrorCodeHisPatientParamWrong = 300004
258 260
 )
259 261
 
260 262
 var ErrCodeMsgs = map[int]string{
@@ -492,6 +494,7 @@ var ErrCodeMsgs = map[int]string{
492 494
 	ErrorCodeHospitalNoExistDataException: "请先办理出院才能进行结算",
493 495
 
494 496
 	ErrorCodeHospitalExistDataException: "该患者已经入院,请选办理出院结算后再进行办理入院操作",
497
+	ErrorCodeHisPatientParamWrong:       "订单正在结算、请先结算完成",
495 498
 }
496 499
 
497 500
 type SGJError struct {

+ 3 - 6
routers/router.go Ver fichero

@@ -3,10 +3,7 @@ package routers
3 3
 import (
4 4
 	//"gdyb/controllers/sz"
5 5
 
6
-	"gdyb/controllers/sg"
7 6
 	"gdyb/controllers/sz"
8
-	"gdyb/controllers/zh"
9
-
10 7
 	//"gdyb/controllers/sz"
11 8
 	//"gdyb/controllers/sz"
12 9
 	//admin_api "XT_New/controllers/admin_api_controllers"
@@ -25,9 +22,9 @@ func init() {
25 22
 		AllowCredentials: true,
26 23
 	}))
27 24
 
28
-	sg.HisManagerApiRegistRouters()
29
-	sg.GdybRegistRouters()
25
+	//sg.HisManagerApiRegistRouters()
26
+	//sg.GdybRegistRouters()
30 27
 	sz.SZHisManagerApiRegistRouters()
31
-	zh.ZHHisManagerApiRegistRouters()
28
+	//zh.ZHHisManagerApiRegistRouters()
32 29
 
33 30
 }

+ 42 - 34
service/gdyb_service.go Ver fichero

@@ -376,8 +376,8 @@ func Gdyb2203(psnNo string, mdtrtId string, doctor string, department string, di
376 376
 	nonce := GetRandomString(32)
377 377
 	timestamp := time.Now().Unix()
378 378
 	signature := setSignature(timestamp, nonce, secret_key)
379
-	tempTime := time.Unix(timestamp, 0)
380
-	timeFormatOne := tempTime.Format("2006-01-02 15:04:05")
379
+	//tempTime := time.Unix(timestamp, 0)
380
+	//timeFormatOne := tempTime.Format("2006-01-02 15:04:05")
381 381
 
382 382
 	// 生成输入报文
383 383
 	inputMessage := SetInputMessage(nonce, timestamp, org_name, doctor, fixmedins_code, insuplc_admdvs, mdtrtarea_admvs)
@@ -385,27 +385,29 @@ func Gdyb2203(psnNo string, mdtrtId string, doctor string, department string, di
385 385
 	inputData := make(map[string]interface{})
386 386
 	diseinfo := make([]map[string]interface{}, 0)
387 387
 
388
-	inputMessage["infno"] = "2203"        // 交易编码
389
-	inputData["mdtrt_id"] = mdtrtId       // 就诊 ID(来自2201接口返回)
390
-	inputData["psn_no"] = psnNo           // 人员编号 (来自1101接口返回)
391
-	inputData["med_type"] = med_type      // 医疗类别 16门诊特殊病
392
-	inputData["begntime"] = timeFormatOne // 开始时间
393
-	inputData["main_cond_dscr"] = ""      // 主要病情描述
394
-	inputData["dise_codg"] = sick_code    // 病种编码
395
-	inputData["dise_name"] = sick_name    // 病种名称
396
-	inputData["birctrl_type"] = ""        // 计划生育手术类别
397
-	inputData["birctrl_matn_date"] = ""   // 计划生育手术或生育日期
388
+	inputMessage["infno"] = "2203"   // 交易编码
389
+	inputData["mdtrt_id"] = mdtrtId  // 就诊 ID(来自2201接口返回)
390
+	inputData["psn_no"] = psnNo      // 人员编号 (来自1101接口返回)
391
+	inputData["med_type"] = med_type // 医疗类别 16门诊特殊病
392
+	//inputData["begntime"] = timeFormatOne // 开始时间
393
+	inputData["begntime"] = "2021-04-10 12:20:30" // 开始时间
394
+	inputData["main_cond_dscr"] = ""              // 主要病情描述
395
+	inputData["dise_codg"] = sick_code            // 病种编码
396
+	inputData["dise_name"] = sick_name            // 病种名称
397
+	inputData["birctrl_type"] = ""                // 计划生育手术类别
398
+	inputData["birctrl_matn_date"] = ""           // 计划生育手术或生育日期
398 399
 
399 400
 	diseinfo_sun := make(map[string]interface{})
400
-	diseinfo_sun["diag_type"] = "1"           // 诊断类别
401
-	diseinfo_sun["diag_srt_no"] = "1"         // 诊断排序号
402
-	diseinfo_sun["diag_code"] = diag_code     // 诊断代码
403
-	diseinfo_sun["diag_name"] = diag          // 诊断名称
404
-	diseinfo_sun["diag_dept"] = department    // 诊断科室
405
-	diseinfo_sun["dise_dor_no"] = doctor_id   // 诊断医生编码
406
-	diseinfo_sun["dise_dor_name"] = doctor    // 诊断医生姓名
407
-	diseinfo_sun["diag_time"] = timeFormatOne // 诊断时间
408
-	diseinfo_sun["vali_flag"] = "1"           // 有效标志
401
+	diseinfo_sun["diag_type"] = "1"         // 诊断类别
402
+	diseinfo_sun["diag_srt_no"] = "1"       // 诊断排序号
403
+	diseinfo_sun["diag_code"] = diag_code   // 诊断代码
404
+	diseinfo_sun["diag_name"] = diag        // 诊断名称
405
+	diseinfo_sun["diag_dept"] = department  // 诊断科室
406
+	diseinfo_sun["dise_dor_no"] = doctor_id // 诊断医生编码
407
+	diseinfo_sun["dise_dor_name"] = doctor  // 诊断医生姓名
408
+	//diseinfo_sun["diag_time"] = timeFormatOne // 诊断时间
409
+	diseinfo_sun["diag_time"] = "2021-04-10 12:20:30"
410
+	diseinfo_sun["vali_flag"] = "1" // 有效标志
409 411
 
410 412
 	diseinfo = append(diseinfo, diseinfo_sun)
411 413
 	input["diseinfo"] = diseinfo
@@ -476,11 +478,13 @@ func Gdyb2203A(psnNo string, mdtrtId string, doctor string, department string, d
476 478
 	inputData["psn_no"] = psnNo           // 人员编号 (来自1101接口返回)
477 479
 	inputData["med_type"] = med_type      // 医疗类别 16门诊特殊病
478 480
 	inputData["begntime"] = timeFormatOne // 开始时间
479
-	inputData["main_cond_dscr"] = ""      // 主要病情描述
480
-	inputData["dise_codg"] = sick_code    // 病种编码
481
-	inputData["dise_name"] = sick_name    // 病种名称
482
-	inputData["birctrl_type"] = ""        // 计划生育手术类别
483
-	inputData["birctrl_matn_date"] = ""   // 计划生育手术或生育日期
481
+	inputData["begntime"] = "2021-04-10 12:20:30"
482
+
483
+	inputData["main_cond_dscr"] = ""    // 主要病情描述
484
+	inputData["dise_codg"] = sick_code  // 病种编码
485
+	inputData["dise_name"] = sick_name  // 病种名称
486
+	inputData["birctrl_type"] = ""      // 计划生育手术类别
487
+	inputData["birctrl_matn_date"] = "" // 计划生育手术或生育日期
484 488
 
485 489
 	inputData["matn_type"] = "" // 生育类别
486 490
 	inputData["geso_val"] = ""  // 孕周数
@@ -494,7 +498,9 @@ func Gdyb2203A(psnNo string, mdtrtId string, doctor string, department string, d
494 498
 	diseinfo_sun["dise_dor_no"] = doctor_id   // 诊断医生编码
495 499
 	diseinfo_sun["dise_dor_name"] = doctor    // 诊断医生姓名
496 500
 	diseinfo_sun["diag_time"] = timeFormatOne // 诊断时间
497
-	diseinfo_sun["vali_flag"] = "1"           // 有效标志
501
+	diseinfo_sun["diag_time"] = "2021-04-10 12:20:30"
502
+
503
+	diseinfo_sun["vali_flag"] = "1" // 有效标志
498 504
 
499 505
 	diseinfo = append(diseinfo, diseinfo_sun)
500 506
 	input["diseinfo"] = diseinfo
@@ -678,13 +684,15 @@ func Gdyb2204(psnNo string, mdtrtId string, hisPrescription []*models.HisPrescri
678 684
 	for _, item := range customs {
679 685
 		feedetailInfo := make(map[string]interface{})
680 686
 		feedetailInfo["feedetl_sn"] = item.FeedetlSn
681
-		feedetailInfo["mdtrt_id"] = mdtrtId                          // 就诊 ID(来自2201接口返回)
682
-		feedetailInfo["psn_no"] = psnNo                              // 人员编号 (来自1101接口返回)
683
-		feedetailInfo["chrg_bchno"] = chrg_bchno                     // 收费批次号
684
-		feedetailInfo["dise_codg"] = ""                              // 病种编码
685
-		feedetailInfo["rxno"] = ""                                   // 处方号
686
-		feedetailInfo["rx_circ_flag"] = "0"                          // 外购处方标志
687
-		feedetailInfo["fee_ocur_time"] = timeFormatOne               // 费用发生时间
687
+		feedetailInfo["mdtrt_id"] = mdtrtId            // 就诊 ID(来自2201接口返回)
688
+		feedetailInfo["psn_no"] = psnNo                // 人员编号 (来自1101接口返回)
689
+		feedetailInfo["chrg_bchno"] = chrg_bchno       // 收费批次号
690
+		feedetailInfo["dise_codg"] = ""                // 病种编码
691
+		feedetailInfo["rxno"] = ""                     // 处方号
692
+		feedetailInfo["rx_circ_flag"] = "0"            // 外购处方标志
693
+		feedetailInfo["fee_ocur_time"] = timeFormatOne // 费用发生时间
694
+		feedetailInfo["fee_ocur_time"] = "2021-04-10 12:20:30"
695
+
688 696
 		feedetailInfo["med_list_codg"] = item.MedListCodg            // 医疗目录编码
689 697
 		feedetailInfo["medins_list_codg"] = fixmedins_code           // 医药机构目录编码
690 698
 		feedetailInfo["det_item_fee_sumamt"] = item.DetItemFeeSumamt // 明细项目费用总额

+ 29 - 0
service/his_service.go Ver fichero

@@ -296,6 +296,22 @@ func GetHisPrescription(org_id int64, patient_id int64, record_date int64) (pres
296 296
 	return
297 297
 }
298 298
 
299
+func GetNewHisPrescription(org_id int64, his_patient_id int64, record_date int64) (prescription []*models.HisPrescription, err error) {
300
+	err = readDb.Model(&models.HisPrescription{}).
301
+		Preload("HisAdditionalCharge", func(db *gorm.DB) *gorm.DB {
302
+			return db.Where("status = 1 AND user_org_id = ?", org_id).Preload("XtHisAddtionConfig", "status=1")
303
+		}).
304
+		Preload("HisDoctorAdviceInfo", func(db *gorm.DB) *gorm.DB {
305
+			return db.Where("status = 1 AND user_org_id = ?", org_id).Preload("BaseDrugLib", "status=1")
306
+		}).
307
+		Preload("HisPrescriptionProject", func(db *gorm.DB) *gorm.DB {
308
+			return db.Where("status = 1 AND user_org_id = ?", org_id).Preload("HisProject", "status=1")
309
+		}).
310
+		Where("user_org_id = ? AND status = 1 AND record_date = ? AND his_patient_id = ? AND order_status <> 2 AND p_type <> 1", org_id, record_date, his_patient_id).
311
+		Find(&prescription).Error
312
+	return
313
+}
314
+
299 315
 type OtherDrugWarehouseInfo struct {
300 316
 	ID               int64 `gorm:"column:id" json:"id" form:"id"`
301 317
 	DrugId           int64 `gorm:"column:drug_id" json:"drug_id" form:"drug_id"`
@@ -1167,6 +1183,7 @@ func GetAllPatient(org_id int64) (patients []*models.Patients, err error) {
1167 1183
 
1168 1184
 func UpdateHisPrescriptionHisID(his_patient_id int64, patient_id int64, record_time int64, org_id int64) {
1169 1185
 	XTWriteDB().Model(&models.HisPrescription{}).Where("record_date = ? AND user_org_id = ? AND patient_id = ?", record_time, org_id, patient_id).Updates(map[string]interface{}{"his_patient_id": his_patient_id})
1186
+	XTWriteDB().Model(&models.HisPrescriptionInfo{}).Where("record_date = ? AND user_org_id = ? AND patient_id = ?", record_time, org_id, patient_id).Updates(map[string]interface{}{"his_patient_id": his_patient_id})
1170 1187
 	return
1171 1188
 }
1172 1189
 
@@ -1198,3 +1215,15 @@ func GetLastHisOrder(org_id int64) (his models.HisOrder, err error) {
1198 1215
 	err = readDb.Model(&models.HisOrder{}).Where("user_org_id = ? AND status = 1 AND order_status = 2", org_id).Last(&his).Error
1199 1216
 	return
1200 1217
 }
1218
+
1219
+func GetHisPatientInfoTwo(org_id int64, patient_id int64, record_date int64) (info []*models.HisPatient, err error) {
1220
+	err = readDb.Model(&models.HisPatient{}).Where("user_org_id = ? AND status = 1 AND record_date = ? AND patient_id = ?", org_id, record_date, patient_id).Find(&info).Error
1221
+	return
1222
+}
1223
+
1224
+func GetNewHisOrderTwo(user_org_id int64, mdtrt_id string, patient_id int64, record_time int64) (order HisOrder, err error) {
1225
+	err = readDb.Model(&HisOrder{}).Where("status = 1 AND user_org_id = ? AND patient_id = ? AND mdtrt_id=? AND settle_accounts_date = ? ", user_org_id, patient_id, mdtrt_id, record_time).
1226
+		Order("ctime desc").
1227
+		Find(&order).Error
1228
+	return
1229
+}