|
@@ -77,6 +77,8 @@ func main() {
|
77
|
77
|
|
78
|
78
|
//深圳百霖
|
79
|
79
|
//GetblBatchSettleList()
|
|
80
|
+ //GetblpgBatchSettleList()
|
|
81
|
+
|
80
|
82
|
//GetblbrBatchSettleList()
|
81
|
83
|
//深圳百霖贝尔
|
82
|
84
|
//GetblbrBatchSettleList()
|
|
@@ -707,10 +709,231 @@ type ResultSeventeen struct {
|
707
|
709
|
//
|
708
|
710
|
func GetblBatchSettleList() {
|
709
|
711
|
org_id, _ := beego.AppConfig.Int64("org_id")
|
710
|
|
- org_id = 10610
|
|
712
|
+ org_id = 9504
|
711
|
713
|
var orders []*models.HisOrder
|
712
|
714
|
//var orders []*models.HisOrderError
|
713
|
715
|
orders, _ = service.GetAllHisOrder10138()
|
|
716
|
+ for _, item := range orders {
|
|
717
|
+ order_id := item.ID
|
|
718
|
+ order, _ := service.GetHisOrderByIDTwo(order_id)
|
|
719
|
+ if order.MedType == "14" {
|
|
720
|
+ his, _ := service.GetHisPatientByNumber(order.MdtrtId)
|
|
721
|
+ var patientPrescription models.HisPrescriptionInfo
|
|
722
|
+ patientPrescription, _ = service.FindLastPatientPrescriptionInfo(order.UserOrgId, order.PatientId, order.SettleAccountsDate)
|
|
723
|
+ doctor_info, _ := service.GetAdminUserInfoByID(order.UserOrgId, patientPrescription.DoctorId)
|
|
724
|
+ department, _ := service.GetDepartMentDetail(patientPrescription.Departments)
|
|
725
|
+ miConfig, _ := service.FindMedicalInsuranceInfo(order.UserOrgId)
|
|
726
|
+ var configTwo []*models.HisXtDiagnoseConfig
|
|
727
|
+ diagnosis_idstwo := strings.Split(his.Diagnosis, ",")
|
|
728
|
+ curRoles, _ := service.GetAdminUserInfoByID(org_id, 5488)
|
|
729
|
+ for _, item := range diagnosis_idstwo {
|
|
730
|
+ id, _ := strconv.ParseInt(item, 10, 64)
|
|
731
|
+ diagnosisConfig, _ := service.FindDiagnoseById(id)
|
|
732
|
+ configTwo = append(configTwo, &diagnosisConfig)
|
|
733
|
+ }
|
|
734
|
+ patient, _ := service.GetPatientByIDTwo(9504, order.PatientId)
|
|
735
|
+
|
|
736
|
+ sickConfig, _ := service.FindSickById(his.SickType)
|
|
737
|
+ //if order.MedType == "1111" || order.MedType == "1112" {
|
|
738
|
+ // order.MedType = "11"
|
|
739
|
+ //}
|
|
740
|
+ service.Gdyb2203d(his.PsnNo, his.Number, doctor_info.UserName, department.Name, miConfig.OrgName, "14", doctor_info.DoctorNumber, miConfig.Code, his.InsuplcAdmdvs, miConfig.MdtrtareaAdmvs, miConfig.SecretKey, sickConfig.ContentCode, sickConfig.ClassName, curRoles.UserName, configTwo, time.Unix(his.RecordDate, 0).Format("2006-01-02 15:04:05"))
|
|
741
|
+
|
|
742
|
+ depart, _ := service.GetDepartMentDetail(curRoles.DepartmentId)
|
|
743
|
+ pre, _ := service.GetNewHisPrescriptionByNumber(order.Number)
|
|
744
|
+ doctor, _ := service.GetAdminUserInfoByID(org_id, pre.Creator)
|
|
745
|
+ if order.ID == 0 {
|
|
746
|
+ return
|
|
747
|
+ }
|
|
748
|
+ if his.BalanceAccountsType == 2 {
|
|
749
|
+ continue
|
|
750
|
+ }
|
|
751
|
+
|
|
752
|
+ ID := strconv.FormatInt(int64(order.ID), 10)
|
|
753
|
+
|
|
754
|
+ struct4101 := service.Struct4101{
|
|
755
|
+ PsnNo: order.PsnNo,
|
|
756
|
+ MdtrtId: order.MdtrtId,
|
|
757
|
+ SetlId: order.SetlId,
|
|
758
|
+ PsnName: order.PsnName,
|
|
759
|
+ Gend: order.Gend,
|
|
760
|
+ Brdy: his.Brdy,
|
|
761
|
+ Age: his.Age,
|
|
762
|
+ Naty: order.Naty,
|
|
763
|
+ PatnCertType: order.PsnCertType,
|
|
764
|
+ Certno: order.Certno,
|
|
765
|
+ Prfs: "90",
|
|
766
|
+ ConerName: "",
|
|
767
|
+ PatnRlts: "",
|
|
768
|
+ ConerAddr: "",
|
|
769
|
+ ConerTel: "",
|
|
770
|
+ HiType: order.Insutype,
|
|
771
|
+ Insuplc: his.InsuplcAdmdvs,
|
|
772
|
+ MaindiagFlag: "1",
|
|
773
|
+ BillCode: "000"+ID,
|
|
774
|
+ BillNo: "000"+ID,
|
|
775
|
+ BizSn: order.Number,
|
|
776
|
+ PsnSelfPay: order.PsnPartAmt,
|
|
777
|
+ PsnOwnPay: order.PsnPartAmt,
|
|
778
|
+ AcctPay: order.AcctPay,
|
|
779
|
+ PsnCashpay: order.PsnCashPay,
|
|
780
|
+ HiPaymtd: "1",
|
|
781
|
+ Hsorg: his.InsuplcAdmdvs,
|
|
782
|
+ HsorgOpter: his.InsuplcAdmdvs,
|
|
783
|
+ MedinsFillPsn: curRoles.UserName,
|
|
784
|
+ MedinsFillDept: depart.Name,
|
|
785
|
+ IptMedType: "2",
|
|
786
|
+ CurAddr: patient.HomeAddress,
|
|
787
|
+ }
|
|
788
|
+
|
|
789
|
+ struct4101.SetlBegnDate = order.SetlTime
|
|
790
|
+ struct4101.SetlEndDate = order.SetlTime
|
|
791
|
+
|
|
792
|
+ var rf []CustomFundPay
|
|
793
|
+ json.Unmarshal([]byte(order.SetlDetail), &rf)
|
|
794
|
+
|
|
795
|
+ //var tempFunPays []service.CustomStruct
|
|
796
|
+ //var tempFunPay610100 service.CustomStruct
|
|
797
|
+
|
|
798
|
+ //for _, item := range rf {
|
|
799
|
+ // if item.FundPayType == "610100" {
|
|
800
|
+ // tempFunPay610100.FundPayamt, _ = decimal.NewFromFloat(tempFunPay610100.FundPayamt).Add(decimal.NewFromFloat(item.FundPayamt)).Float64()
|
|
801
|
+ // tempFunPay610100.FundPayType = item.FundPayType
|
|
802
|
+ // } else {
|
|
803
|
+ // var tempFunPay service.CustomStruct
|
|
804
|
+ // tempFunPay.FundPayamt = item.FundPayamt
|
|
805
|
+ // tempFunPay.FundPayType = item.FundPayType
|
|
806
|
+ // tempFunPays = append(tempFunPays, tempFunPay)
|
|
807
|
+ // }
|
|
808
|
+ //}
|
|
809
|
+ //tempFunPays = append(tempFunPays, tempFunPay610100)
|
|
810
|
+ //struct4101.CustomStruct = tempFunPays
|
|
811
|
+
|
|
812
|
+ var tempDiaginfos []service.DiaginfoStructTwo
|
|
813
|
+ var tempOpspdiseinfo2 service.OpspdiseinfoStruct
|
|
814
|
+ var tempOpspdiseinfos []service.OpspdiseinfoStruct
|
|
815
|
+
|
|
816
|
+ diagnosis_ids := strings.Split(his.Diagnosis, ",")
|
|
817
|
+ var config []*models.HisXtDiagnoseConfig
|
|
818
|
+ for _, item := range diagnosis_ids {
|
|
819
|
+ id, _ := strconv.ParseInt(item, 10, 64)
|
|
820
|
+ if id == 24 {
|
|
821
|
+
|
|
822
|
+ diagnosisConfig, _ := service.FindDiagnoseById(id)
|
|
823
|
+ config = append(config, &diagnosisConfig)
|
|
824
|
+ }
|
|
825
|
+
|
|
826
|
+ }
|
|
827
|
+
|
|
828
|
+ for _, item := range diagnosis_ids {
|
|
829
|
+
|
|
830
|
+ id, _ := strconv.ParseInt(item, 10, 64)
|
|
831
|
+ if id != 24 {
|
|
832
|
+ diagnosisConfig, _ := service.FindDiagnoseById(id)
|
|
833
|
+ config = append(config, &diagnosisConfig)
|
|
834
|
+ }
|
|
835
|
+
|
|
836
|
+ }
|
|
837
|
+
|
|
838
|
+ for index, item := range config {
|
|
839
|
+ if index == 0 {
|
|
840
|
+ var tempDiaginfo service.DiaginfoStructTwo
|
|
841
|
+ tempDiaginfo.DiagCode = item.CountryCode
|
|
842
|
+ tempDiaginfo.DiagName = item.CountryContentName
|
|
843
|
+ tempDiaginfo.DiagType = "1"
|
|
844
|
+ tempDiaginfo.MaindiagFlag = "1"
|
|
845
|
+ tempDiaginfos = append(tempDiaginfos, tempDiaginfo)
|
|
846
|
+ } else {
|
|
847
|
+
|
|
848
|
+ var tempDiaginfo service.DiaginfoStructTwo
|
|
849
|
+ tempDiaginfo.DiagCode = item.CountryCode
|
|
850
|
+ tempDiaginfo.DiagName = item.CountryContentName
|
|
851
|
+ tempDiaginfo.DiagType = "1"
|
|
852
|
+ tempDiaginfo.MaindiagFlag = "0"
|
|
853
|
+ tempDiaginfos = append(tempDiaginfos, tempDiaginfo)
|
|
854
|
+ }
|
|
855
|
+ }
|
|
856
|
+ struct4101.Diseinfo = tempDiaginfos
|
|
857
|
+ sickConfigTwo, _ := service.FindSickById(his.SickType)
|
|
858
|
+ tempOpspdiseinfo2.DiagCode = sickConfigTwo.ContentCode
|
|
859
|
+ tempOpspdiseinfo2.DiagName = sickConfigTwo.CountryContentName
|
|
860
|
+ tempOpspdiseinfo2.OprnOprtCode = ""
|
|
861
|
+ tempOpspdiseinfo2.OprnOprtName = ""
|
|
862
|
+ tempOpspdiseinfos = append(tempOpspdiseinfos, tempOpspdiseinfo2)
|
|
863
|
+ struct4101.OpspdiseinfoStruct = tempOpspdiseinfos
|
|
864
|
+ time_arr := strings.Split(order.SetlTime, " ")
|
|
865
|
+ struct4101.AdmTime = time_arr[0]
|
|
866
|
+ struct4101.AdmEndTime = time_arr[0]
|
|
867
|
+ struct4101.DoctorName = doctor.UserName
|
|
868
|
+ struct4101.DoctorCode = doctor.DoctorNumber
|
|
869
|
+
|
|
870
|
+ struct4101.Ntly = "CHN"
|
|
871
|
+ struct4101.AdmCaty = "A03.06"
|
|
872
|
+ var res ResultSeventeen
|
|
873
|
+
|
|
874
|
+ result, request := service.Gdyb4101For10138(struct4101, miConfig.SecretKey, miConfig.OrgName, curRoles.UserName, miConfig.Code, his.InsuplcAdmdvs, miConfig.MdtrtareaAdmvs, org_id)
|
|
875
|
+ fmt.Println(result)
|
|
876
|
+ saveLog(result, request, "4101A", "清单上传")
|
|
877
|
+ var dat map[string]interface{}
|
|
878
|
+ if err := json.Unmarshal([]byte(result), &dat); err == nil {
|
|
879
|
+ fmt.Println(dat)
|
|
880
|
+ } else {
|
|
881
|
+ fmt.Println(err)
|
|
882
|
+ }
|
|
883
|
+ userJSONBytes, _ := json.Marshal(dat)
|
|
884
|
+ if err := json.Unmarshal(userJSONBytes, &res); err != nil {
|
|
885
|
+ //utils.ErrorLog("解析失败:%v", err)
|
|
886
|
+ //c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
|
|
887
|
+ //adminUser := c.GetAdminUserInfo()
|
|
888
|
+ errlog := &models.HisOrderError{
|
|
889
|
+ UserOrgId: org_id,
|
|
890
|
+ Ctime: time.Now().Unix(),
|
|
891
|
+ Mtime: time.Now().Unix(),
|
|
892
|
+ ErrMsg: res.ErrMsg + "解析失败",
|
|
893
|
+ Status: 1,
|
|
894
|
+ PatientId: order_id,
|
|
895
|
+ Stage: 10138600,
|
|
896
|
+ }
|
|
897
|
+ service.CreateErrMsgLog(errlog)
|
|
898
|
+ continue
|
|
899
|
+ }
|
|
900
|
+
|
|
901
|
+ if res.Infcode != 0 {
|
|
902
|
+ //adminUser := c.GetAdminUserInfo()
|
|
903
|
+ errlog := &models.HisOrderError{
|
|
904
|
+ UserOrgId: org_id,
|
|
905
|
+ Ctime: time.Now().Unix(),
|
|
906
|
+ Mtime: time.Now().Unix(),
|
|
907
|
+ ErrMsg: res.ErrMsg,
|
|
908
|
+ Status: 1,
|
|
909
|
+ PatientId: order_id,
|
|
910
|
+ Stage: 10138600,
|
|
911
|
+ }
|
|
912
|
+ service.CreateErrMsgLog(errlog)
|
|
913
|
+ continue
|
|
914
|
+ } else {
|
|
915
|
+ hisFundSettleListResult := &models.HisFundSettleListResult{
|
|
916
|
+ Number: res.Output.SetlListId,
|
|
917
|
+ Status: 1,
|
|
918
|
+ Ctime: time.Now().Unix(),
|
|
919
|
+ Mtime: time.Now().Unix(),
|
|
920
|
+ UserOrgId: org_id,
|
|
921
|
+ IsUpload: 1,
|
|
922
|
+ OrderId: order_id,
|
|
923
|
+ }
|
|
924
|
+ service.CreateUploadRecord(hisFundSettleListResult)
|
|
925
|
+ continue
|
|
926
|
+ }
|
|
927
|
+ }
|
|
928
|
+ }
|
|
929
|
+}
|
|
930
|
+
|
|
931
|
+func GetblpgBatchSettleList() {
|
|
932
|
+ org_id, _ := beego.AppConfig.Int64("org_id")
|
|
933
|
+ org_id = 10610
|
|
934
|
+ var orders []*models.HisOrder
|
|
935
|
+ //var orders []*models.HisOrderError
|
|
936
|
+ orders, _ = service.GetAllHisOrder10610()
|
714
|
937
|
for _, item := range orders {
|
715
|
938
|
order_id := item.ID
|
716
|
939
|
order, _ := service.GetHisOrderByIDTwo(order_id)
|
|
@@ -746,6 +969,8 @@ func GetblBatchSettleList() {
|
746
|
969
|
if his.BalanceAccountsType == 2 {
|
747
|
970
|
continue
|
748
|
971
|
}
|
|
972
|
+ ID := strconv.FormatInt(int64(order.ID), 10)
|
|
973
|
+
|
749
|
974
|
struct4101 := service.Struct4101{
|
750
|
975
|
PsnNo: order.PsnNo,
|
751
|
976
|
MdtrtId: order.MdtrtId,
|
|
@@ -765,8 +990,8 @@ func GetblBatchSettleList() {
|
765
|
990
|
HiType: order.Insutype,
|
766
|
991
|
Insuplc: his.InsuplcAdmdvs,
|
767
|
992
|
MaindiagFlag: "1",
|
768
|
|
- BillCode: order.SetlId,
|
769
|
|
- BillNo: order.SetlId,
|
|
993
|
+ BillCode: "000" +ID,
|
|
994
|
+ BillNo: "000" +ID,
|
770
|
995
|
BizSn: order.Number,
|
771
|
996
|
PsnSelfPay: order.PsnPartAmt,
|
772
|
997
|
PsnOwnPay: order.PsnPartAmt,
|
|
@@ -963,7 +1188,10 @@ func GetblbrBatchSettleList() {
|
963
|
1188
|
}
|
964
|
1189
|
if his.BalanceAccountsType == 2 {
|
965
|
1190
|
continue
|
|
1191
|
+
|
966
|
1192
|
}
|
|
1193
|
+ ID := strconv.FormatInt(int64(order.ID), 10)
|
|
1194
|
+
|
967
|
1195
|
struct4101 := service.Struct4101{
|
968
|
1196
|
PsnNo: order.PsnNo,
|
969
|
1197
|
MdtrtId: order.MdtrtId,
|
|
@@ -983,8 +1211,8 @@ func GetblbrBatchSettleList() {
|
983
|
1211
|
HiType: order.Insutype,
|
984
|
1212
|
Insuplc: his.InsuplcAdmdvs,
|
985
|
1213
|
MaindiagFlag: "1",
|
986
|
|
- BillCode: order.SetlId,
|
987
|
|
- BillNo: order.SetlId,
|
|
1214
|
+ BillCode: "000" +ID,
|
|
1215
|
+ BillNo: "000" +ID,
|
988
|
1216
|
BizSn: order.Number,
|
989
|
1217
|
PsnSelfPay: order.PsnPartAmt,
|
990
|
1218
|
PsnOwnPay: order.PsnPartAmt,
|