Browse Source

Merge branch 'pool_639' into pool_677

ziwen 1 year ago
parent
commit
51f1cfb37a
2 changed files with 28 additions and 10 deletions
  1. 20 7
      controller/contract/register.go
  2. 8 3
      models/fms/contract_register.go

+ 20 - 7
controller/contract/register.go

@@ -3843,8 +3843,8 @@ func (rg *RegisterController) CheckContractName(c *gin.Context) {
 }
 
 // CheckContract
-// @Title 货币单位列表
-// @Description 货币单位列表
+// @Title 校验重复合同
+// @Description 校验重复合同
 // @Success 200 {object} fms.CheckContractNameResp
 // @router /contract/register/check_contract_duplicate [post]
 func (rg *RegisterController) CheckContractDuplicate(c *gin.Context) {
@@ -3902,17 +3902,24 @@ func (rg *RegisterController) CheckContractDuplicate(c *gin.Context) {
 		return
 	}
 
+	typeIdMap := make(map[int]int)
 	registerIds := make([]int, 0)
 	for i := range list {
 		registerIds = append(registerIds, list[i].ContractRegisterId)
+		if list[i].ContractCode != "" {
+			typeIdMap[list[i].ContractRegisterId] = 1
+		}
 	}
 
-	idlist, e := fms.CheckContractServiceDuplicate(registerIds)
+	dupList, e := fms.CheckContractServiceDuplicate(registerIds)
 	if e != nil {
 		resp.FailMsg("操作失败", "查询重复合同套餐失败, Err: "+e.Error(), c)
 		return
 	}
-
+	serviceIdMap := make(map[int]string)
+	for _, v := range dupList {
+		serviceIdMap[v.ContractRegisterId] = v.Ids
+	}
 	//校验套餐
 	if len(req.Services) > 0 {
 		serviceAmountMap := make(map[int]float64)
@@ -3932,11 +3939,17 @@ func (rg *RegisterController) CheckContractDuplicate(c *gin.Context) {
 		}
 		templateIdStr := strings.Join(ids, ",")
 
-		for _, s := range idlist {
-			if templateIdStr == *s {
-				data.Exist = 1
+		for _, v := range dupList {
+			if serviceIds, ok := serviceIdMap[v.ContractRegisterId]; ok{
+				if serviceIds == templateIdStr{
+					data.Exist = 1
+					if _, ok2 := typeIdMap[v.ContractRegisterId]; ok2{
+						data.Type = 1
+					}
+				}
 			}
 		}
+
 	}
 
 	resp.OkData("查询成功", data, c)

+ 8 - 3
models/fms/contract_register.go

@@ -928,12 +928,17 @@ func CheckContractDuplicate(condition string, pars []interface{}) (list []*Contr
 
 type CheckContractDuplicateResp struct {
 	Exist int `json:"exist" description:"是否存在重复的合同:0不存在,1存在"`
+	Type  int `json:"type" description:"重复的合同类型:0预登记,1合规登记"`
+}
+type ContractServiceDuplicateItem struct {
+	Ids string
+	ContractRegisterId int
 }
 
-func CheckContractServiceDuplicate(registerIds []int) (ids []*string, err error) {
+func CheckContractServiceDuplicate(registerIds []int) (list []*ContractServiceDuplicateItem, err error) {
 	err = global.DEFAULT_MYSQL.Table("contract_service").
-		Select("GROUP_CONCAT(service_template_id ORDER BY service_template_id)  AS ids ").
+		Select("GROUP_CONCAT(service_template_id ORDER BY service_template_id)  AS ids, contract_register_id ").
 		Where("contract_register_id IN (?)", registerIds).
-		Group("contract_register_id").Scan(&ids).Error
+		Group("contract_register_id").Find(&list).Error
 	return
 }