fix
wangpengfei
2023-08-08 d557ed582308257aaefcbcfe2bada1e195d83a91
fix

add multi-criteria query to salesLeads
8个文件已修改
112 ■■■■■ 已修改文件
api/v1/salesLeads.go 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
docs/docs.go 10 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
docs/swagger.json 10 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
docs/swagger.yaml 12 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
model/request/client.go 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
model/request/salesLeads.go 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
model/salesLeads.go 70 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
service/salesLeads.go 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
api/v1/salesLeads.go
@@ -151,7 +151,7 @@
        return
    }
    salesLeadss, total, errCode := salesLeadsService.GetSalesLeadsList(params.Page, params.PageSize, params.Keyword)
    salesLeadss, total, errCode := salesLeadsService.GetSalesLeadsList(params.Page, params.PageSize, params.SearchMap)
    if errCode != ecode.OK {
        ctx.Fail(errCode)
        return
docs/docs.go
@@ -13572,7 +13572,7 @@
                    "type": "integer"
                },
                "search_map": {
                    "description": "搜索条件: map[string]interface{}{\"name\": \"xxx\"}; \"not_contact\": 超过15天未联系; \"public_sea\": 公海客户",
                    "description": "搜索条件: map[string]interface{}{\"name\": \"xxx\"}; \"name\": 客户名称; \"number\": 公海客户",
                    "type": "object",
                    "additionalProperties": true
                }
@@ -13747,9 +13747,6 @@
        "request.GetSalesLeadsList": {
            "type": "object",
            "properties": {
                "keyword": {
                    "type": "string"
                },
                "page": {
                    "description": "页码",
                    "type": "integer"
@@ -13757,6 +13754,11 @@
                "pageSize": {
                    "description": "每页大小",
                    "type": "integer"
                },
                "search_map": {
                    "description": "搜索条件: map[string]interface{}{\"name\": \"xxx\"} {\"client_name\": \"客户名称\", \"number\": \"销售线索编号\", \"contact_name\": \"联系人姓名\", \"phone\": \"手机号码\", \"sales_resources\": \"商机来源\", \"city\": \"城市\", \"province\": \"省份\", \"member_name\": \"负责人\"}",
                    "type": "object",
                    "additionalProperties": true
                }
            }
        },
docs/swagger.json
@@ -13560,7 +13560,7 @@
                    "type": "integer"
                },
                "search_map": {
                    "description": "搜索条件: map[string]interface{}{\"name\": \"xxx\"}; \"not_contact\": 超过15天未联系; \"public_sea\": 公海客户",
                    "description": "搜索条件: map[string]interface{}{\"name\": \"xxx\"}; \"name\": 客户名称; \"number\": 公海客户",
                    "type": "object",
                    "additionalProperties": true
                }
@@ -13735,9 +13735,6 @@
        "request.GetSalesLeadsList": {
            "type": "object",
            "properties": {
                "keyword": {
                    "type": "string"
                },
                "page": {
                    "description": "页码",
                    "type": "integer"
@@ -13745,6 +13742,11 @@
                "pageSize": {
                    "description": "每页大小",
                    "type": "integer"
                },
                "search_map": {
                    "description": "搜索条件: map[string]interface{}{\"name\": \"xxx\"} {\"client_name\": \"客户名称\", \"number\": \"销售线索编号\", \"contact_name\": \"联系人姓名\", \"phone\": \"手机号码\", \"sales_resources\": \"商机来源\", \"city\": \"城市\", \"province\": \"省份\", \"member_name\": \"负责人\"}",
                    "type": "object",
                    "additionalProperties": true
                }
            }
        },
docs/swagger.yaml
@@ -2828,8 +2828,8 @@
        type: integer
      search_map:
        additionalProperties: true
        description: '搜索条件: map[string]interface{}{"name": "xxx"}; "not_contact":
          超过15天未联系; "public_sea": 公海客户'
        description: '搜索条件: map[string]interface{}{"name": "xxx"}; "name": 客户名称; "number":
          公海客户'
        type: object
    type: object
  request.GetContactList:
@@ -2948,14 +2948,18 @@
    type: object
  request.GetSalesLeadsList:
    properties:
      keyword:
        type: string
      page:
        description: 页码
        type: integer
      pageSize:
        description: 每页大小
        type: integer
      search_map:
        additionalProperties: true
        description: '搜索条件: map[string]interface{}{"name": "xxx"} {"client_name":
          "客户名称", "number": "销售线索编号", "contact_name": "联系人姓名", "phone": "手机号码", "sales_resources":
          "商机来源", "city": "城市", "province": "省份", "member_name": "负责人"}'
        type: object
    type: object
  request.GetSalesRefundList:
    properties:
model/request/client.go
@@ -30,7 +30,7 @@
type GetClientList struct {
    PageInfo
    SearchMap map[string]interface{} `json:"search_map"` // 搜索条件: map[string]interface{}{"name": "xxx"}; "not_contact": 超过15天未联系; "public_sea": 公海客户
    SearchMap map[string]interface{} `json:"search_map"` // 搜索条件: map[string]interface{}{"name": "xxx"}; "name": 客户名称; "number": 公海客户
}
type DeleteClient struct {
model/request/salesLeads.go
@@ -25,7 +25,7 @@
type GetSalesLeadsList struct {
    PageInfo
    Keyword string `json:"keyword"`
    SearchMap map[string]interface{} `json:"search_map"` // 搜索条件: map[string]interface{}{"name": "xxx"} {"name": "客户名称", "number": "销售线索编号", "contact_name": "联系人姓名", "phone": "手机号码", "sales_resources": "商机来源", "city": "城市", "province": "省份", "member_name": "负责人"}
}
type DeleteSalesLeads struct {
model/salesLeads.go
@@ -15,7 +15,9 @@
        ContactPhone    string               `json:"contact_phone" gorm:"column:contact_phone;type:varchar(255);comment:联系人电话"`
        ContactPosition string               `json:"contact_position" gorm:"column:contact_position;type:varchar(255);comment:联系人职位"`
        SalesSourcesId  int                  `json:"sales_sources_id" gorm:"column:sales_sources_id;type:int(11);comment:商机来源ID"`
        SalesSources    SalesSources         `json:"-" gorm:"foreignKey:SalesSourcesId"`
        MemberId        int                  `json:"member_id" gorm:"column:member_id;type:int(11);comment:销售负责人ID"`
        Member          User                 `json:"-" gorm:"foreignKey:MemberId"`
        SalesStatus     constvar.SalesStatus `json:"sales_status" gorm:"column:sales_status;type:int(11);comment:销售状态"`
        Desc            string               `json:"desc" gorm:"column:desc;type:varchar(255);comment:备注"`
        Reason          string               `json:"reason" gorm:"column:reason;type:text;comment:失败原因"`
@@ -27,11 +29,11 @@
    SalesLeadsSearch struct {
        SalesLeads
        Orm      *gorm.DB
        Keyword  string
        OrderBy  string
        PageNum  int
        PageSize int
        Orm       *gorm.DB
        SearchMap map[string]interface{}
        OrderBy   string
        PageNum   int
        PageSize  int
    }
)
@@ -51,12 +53,6 @@
func (slf *SalesLeadsSearch) build() *gorm.DB {
    var db = slf.Orm.Model(&SalesLeads{})
    if slf.Keyword != "" {
        db = db.Where("name LIKE ?", "%"+slf.Keyword+"%")
    }
    if slf.Keyword != "" {
        db = db.Where("name LIKE ?", "%"+slf.Keyword+"%")
    }
    if slf.Id != 0 {
        db = db.Where("id = ?", slf.Id)
    }
@@ -64,28 +60,36 @@
        db = db.Where("name = ?", slf.Name)
    }
    if slf.Number != "" {
        db = db.Where("number = ?", slf.Number)
    }
    if len(slf.SearchMap) > 0 {
        for key, value := range slf.SearchMap {
            switch v := value.(type) {
            case string:
                if key == "number" || key == "contact_name" || key == "contact_phone" || key == "name" {
                    db = db.Where(key+" LIKE ?", "%"+v+"%")
                }
    if slf.ContactName != "" {
        db = db.Where("contact_name = ?", slf.ContactName)
    }
                if key == "city" {
                    db = db.Joins("City").Where("City.name LIKE ?", "%"+v+"%")
                }
    if slf.ContactPhone != "" {
        db = db.Where("contact_phone = ?", slf.ContactPhone)
    }
                if key == "province" {
                    db = db.Joins("Province").Where("Province.name LIKE ?", "%"+v+"%")
                }
    if slf.ContactPosition != "" {
        db = db.Where("contact_position = ?", slf.ContactPosition)
    }
                if key == "sales_sources" {
                    db = db.Joins("SalesSources").Where("SalesSources.name LIKE ?", "%"+v+"%")
                }
    if slf.SalesSourcesId != 0 {
        db = db.Where("sales_sources_id = ?", slf.SalesSourcesId)
    }
                if key == "member_name" {
                    db = db.Joins("Member").Where("Member.username LIKE ?", "%"+v+"%")
                }
    if slf.MemberId != 0 {
        db = db.Where("member_id = ?", slf.MemberId)
            case int:
                if key == "member_id" {
                    db = db.Where("member_id = ?", v)
                }
            }
        }
    }
    return db
@@ -149,11 +153,6 @@
    return
}
func (slf *SalesLeadsSearch) SetKeyword(keyword string) *SalesLeadsSearch {
    slf.Keyword = keyword
    return slf
}
func (slf *SalesLeadsSearch) SetPage(page, size int) *SalesLeadsSearch {
    slf.PageNum, slf.PageSize = page, size
    return slf
@@ -172,3 +171,8 @@
    slf.Orm = slf.Orm.Where("id in (?)", ids)
    return slf
}
func (slf *SalesLeadsSearch) SetSearchMap(data map[string]interface{}) *SalesLeadsSearch {
    slf.SearchMap = data
    return slf
}
service/salesLeads.go
@@ -40,9 +40,9 @@
    return ecode.OK
}
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
    }