From 9ec9a4987cb5fe4a3bd39d61029add5c51d3ab92 Mon Sep 17 00:00:00 2001
From: liujiandao <274878379@qq.com>
Date: 星期六, 02 十二月 2023 11:00:26 +0800
Subject: [PATCH] 添加来源

---
 service/salesLeads.go |   53 +++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 45 insertions(+), 8 deletions(-)

diff --git a/service/salesLeads.go b/service/salesLeads.go
index 114c089..b3d3363 100644
--- a/service/salesLeads.go
+++ b/service/salesLeads.go
@@ -1,6 +1,7 @@
 package service
 
 import (
+	"aps_crm/constvar"
 	"aps_crm/model"
 	"aps_crm/pkg/ecode"
 )
@@ -26,22 +27,22 @@
 }
 
 // CheckSalesLeadsExist check salesLeads exist
-func CheckSalesLeadsExist(id int) int {
-	tmp, err := model.NewSalesLeadsSearch(nil).SetId(id).Find()
+func CheckSalesLeadsExist(id int) (int, *model.SalesLeads) {
+	tmp, err := model.NewSalesLeadsSearch(nil).SetId(id).First()
 	if err != nil {
-		return ecode.SalesLeadsNotExist
+		return ecode.SalesLeadsNotExist, nil
 	}
 
-	if len(tmp) == 0 {
-		return ecode.SalesLeadsNotExist
+	if tmp.Id == 0 {
+		return ecode.SalesLeadsNotExist, nil
 	}
 
-	return ecode.OK
+	return ecode.OK, &tmp
 }
 
-func (SalesLeadsService) GetSalesLeadsList(page, pageSize int, keyword string) ([]*model.SalesLeads, int64, int) {
+func (SalesLeadsService) GetSalesLeadsList(page, pageSize int, data map[string]interface{}) ([]*model.SalesLeads, int64, int) {
 	// get contact list
-	contacts, total, err := model.NewSalesLeadsSearch(nil).SetKeyword(keyword).SetPage(page, pageSize).FindAll()
+	contacts, total, err := model.NewSalesLeadsSearch(nil).SetPage(page, pageSize).SetSearchMap(data).FindAll()
 	if err != nil {
 		return nil, 0, ecode.SalesLeadsListErr
 	}
@@ -74,3 +75,39 @@
 	}
 	return ecode.OK
 }
+
+func (SalesLeadsService) PushSalesLeads(id int, step constvar.SalesStatus, txt string) int {
+	// check salesLeads exist
+	errCode, tmp := CheckSalesLeadsExist(id)
+	if errCode != ecode.OK {
+		return errCode
+	}
+
+	// check step
+	if tmp.SalesStatus > step && step != constvar.SalesStatusFail {
+		return ecode.SalesLeadsStatusErr
+	}
+
+	switch step {
+	case constvar.SalesStatusFail:
+		err := model.NewSalesLeadsSearch(nil).SetId(id).UpdateMap(map[string]interface{}{
+			"sales_status": constvar.SalesStatusFail,
+			"reason":       txt,
+		})
+		if err != nil {
+			return ecode.SalesLeadsUpdateErr
+		}
+	case constvar.SalesStatusIng:
+		err := model.NewSalesLeadsSearch(nil).SetId(id).UpdateMap(map[string]interface{}{
+			"sales_status": constvar.SalesStatusIng,
+		})
+		if err != nil {
+			return ecode.SalesLeadsUpdateErr
+		}
+		return ecode.OK
+	default:
+		return ecode.SalesLeadsStatusErr
+	}
+
+	return ecode.OK
+}

--
Gitblit v1.8.0