123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493 |
- package yb
- import (
- "encoding/json"
- "fmt"
- "github.com/rdlucklib/rdluck_tools/paging"
- "github.com/tealeg/xlsx"
- "hongze/hz_crm_api/models"
- "hongze/hz_crm_api/models/yb"
- "hongze/hz_crm_api/models/yb/request"
- ybResp "hongze/hz_crm_api/models/yb/response"
- ybService "hongze/hz_crm_api/services/yb"
- "hongze/hz_crm_api/utils"
- "os"
- "path/filepath"
- "time"
- )
- // CreateQs
- // @Title 创建全时会议
- // @Description 创建全时会议接口
- // @Param request body request.CreateQsReq true "type json string"
- // @router /activity/create_qs [post]
- func (this *ActivityController) CreateQs() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- var req request.CreateQsReq
- err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if req.ActivityId <= 0 {
- br.Msg = "请选择活动!"
- br.ErrMsg = "活动ID有误!"
- return
- }
- if req.Time <= 0 {
- br.Msg = "请输入大于0的会议时长!"
- br.ErrMsg = "请输入大于0的会议时长!"
- return
- }
- err, errMsg := ybService.CreateQsEvent(req)
- if err != nil {
- br.Msg = "创建全时会议失败!" + errMsg
- br.ErrMsg = "创建全时会议失败,Err:" + err.Error()
- return
- }
- msg := "创建成功"
- br.Ret = 200
- br.Success = true
- br.Msg = msg
- }
- // CancelQs
- // @Title 取消全时会议
- // @Description 取消全时会议解耦
- // @Param request body request.CancelQsReq true "type json string"
- // @Success 200 {object} 取消发布成功
- // @router /activity/cancel_qs [post]
- func (this *ActivityController) CancelQs() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- var req request.CancelQsReq
- err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if req.ActivityId <= 0 {
- br.Msg = "活动ID异常!"
- br.ErrMsg = "活动ID异常"
- return
- }
- err, errMsg := ybService.CancelQsEvent(req.ActivityId)
- if err != nil {
- br.Msg = "创建全时会议失败!" + errMsg
- br.ErrMsg = "创建全时会议失败,Err:" + err.Error()
- return
- }
- msg := "取消会议成功"
- br.Ret = 200
- br.Success = true
- br.Msg = msg
- }
- // QsList
- // @Title 获取到会列表
- // @Description 获取到会列表
- // @Param Keyword query string false "搜索关键字"
- // @Param ActivityTypeIds query string false "活动类别ids,多个用英文逗号分割"
- // @Param ActiveStatus query int8 false "活动进行状态,枚举值:1:未开始;2:进行中;3:已结束"
- // @Param StartDate query string false "活动开始日期,格式:2021-11-09"
- // @Param EndDate query string false "活动结束日期,格式:2021-11-10"
- // @Success 200 {object} []yb.QsListResp
- // @router /activity/quanshi/list [get]
- func (this *ActivityController) QsList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- keyword := this.GetString("Keyword")
- activityTypeIds := this.GetString("ActivityTypeIds", "")
- activeStatus, _ := this.GetInt("ActiveStatus", 0)
- //publishStatus, _ := this.GetInt("PublishStatus", 0)
- startDate := this.GetString("StartDate")
- endDate := this.GetString("EndDate")
- pageSize, _ := this.GetInt("PageSize")
- currentIndex, _ := this.GetInt("CurrentIndex")
- var startSize int
- if pageSize <= 0 {
- pageSize = utils.PageSize20
- }
- if currentIndex <= 0 {
- currentIndex = 1
- }
- startSize = paging.StartIndex(currentIndex, pageSize)
- condition := ""
- pars := make([]interface{}, 0)
- //关键字
- if keyword != "" {
- condition += ` AND a.activity_name LIKE '%` + keyword + `%' `
- }
- //活动类别ids
- if activityTypeIds != "" {
- condition += ` AND a.activity_type_id IN (` + activityTypeIds + `)`
- }
- //活动开始与否状态
- order := ""
- if activeStatus > 0 {
- nowTime := time.Now().Format(utils.FormatDateTime)
- //1:未开始;2:进行中;3:已结束"
- switch activeStatus {
- case 1:
- condition += ` AND a.start_time > ? `
- pars = append(pars, nowTime)
- case 2:
- condition += ` AND a.start_time <= ? and end_time >= ? `
- pars = append(pars, nowTime, nowTime)
- order = " a.start_time DESC"
- case 3:
- condition += ` AND a.end_time < ? `
- pars = append(pars, nowTime)
- order = " a.start_time DESC"
- }
- }
- //活动是否发布
- //if publishStatus >= 0 {
- // condition += ` AND a.publish_status = ? `
- // pars = append(pars, publishStatus)
- //}
- //活动时间
- if startDate != "" && endDate != "" {
- condition += ` AND a.start_time >= ? and a.end_time <= ?`
- pars = append(pars, startDate+" 00:00:00", endDate+" 23:59:59")
- }
- // 获取所有的分类
- total, list, err := yb.GetQsList(condition, order, pars, startSize, pageSize)
- if err != nil {
- br.Msg = "获取活动列表失败!"
- br.ErrMsg = "获取活动列表失败,Err:" + err.Error()
- return
- }
- //if len(list) > 0 {
- // for _, activityQs := range list {
- // if activityQs.QsStatus == 2 {
- // activityQs.RealTime = activityQs.EventEndTime.Unix() - activityQs.EventStartTime.Unix()
- // }
- // }
- //}
- page := paging.GetPaging(currentIndex, pageSize, total)
- resp := ybResp.QsListResp{
- List: list,
- Paging: page,
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // QsUserList
- // @Title 获取到会用户列表
- // @Description 获取到会用户列表
- // @Param QsId query int false "全时会议与活动的关联id"
- // @Param DataType query int8 false "活动进行状态,枚举值:1:已知联系人;2:未知联系人"
- // @Success 200 {object} []yb.QsUserListResp
- // @router /activity/quanshi/user_list [get]
- func (this *ActivityController) QsUserList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- dataType, _ := this.GetInt("DataType", 0)
- qsId, _ := this.GetInt("QsId", 0)
- if qsId <= 0 {
- br.Msg = "请选择活动"
- br.ErrMsg = "请选择活动"
- return
- }
- if dataType <= 0 {
- br.Msg = "请选择类型"
- br.ErrMsg = "请选择类型"
- return
- }
- pageSize, _ := this.GetInt("PageSize")
- currentIndex, _ := this.GetInt("CurrentIndex")
- var startSize int
- if pageSize <= 0 {
- pageSize = utils.PageSize20
- }
- if currentIndex <= 0 {
- currentIndex = 1
- }
- startSize = paging.StartIndex(currentIndex, pageSize)
- condition := ""
- pars := make([]interface{}, 0)
- condition += ` AND a.qs_id = ? `
- pars = append(pars, qsId)
- switch dataType {
- case 1:
- condition += ` AND a.product_id = ? `
- pars = append(pars, 1)
- case 2:
- condition += ` AND a.product_id = ? `
- pars = append(pars, 2)
- case 3:
- condition += ` AND a.product_id = ? `
- pars = append(pars, 0)
- }
- // 获取所有的用户
- total, list, err := yb.GetQsUserList(condition, pars, startSize, pageSize)
- if err != nil {
- br.Msg = "获取活动列表失败!"
- br.ErrMsg = "获取活动列表失败,Err:" + err.Error()
- return
- }
- page := paging.GetPaging(currentIndex, pageSize, total)
- resp := ybResp.QsUserListResp{
- List: list,
- Paging: page,
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
- // ExportQsUserList
- // @Title 导出全时用户列表
- // @Description 导出全时用户列表
- // @Param QsId query int false "全时会议与活动的关联id"
- // @Success 200 导出成功
- // @router /activity/quanshi/user_list/export [get]
- func (this *ActivityController) ExportQsUserList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- qsId, _ := this.GetInt("QsId", 0)
- if qsId <= 0 {
- br.Msg = "请选择活动"
- br.ErrMsg = "请选择活动"
- return
- }
- dir, _ := os.Executable()
- exPath := filepath.Dir(dir)
- downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
- xlsxFile := xlsx.NewFile()
- for i := 1; i <= 3; i++ {
- var sheetName string
- switch i {
- case 1:
- sheetName = "ficc联系人"
- case 2:
- sheetName = "权益联系人"
- case 3:
- sheetName = "未知联系人"
- }
- sheet, err := xlsxFile.AddSheet(sheetName)
- if err != nil {
- fmt.Println("新增Sheet失败", err.Error())
- br.Msg = "新增Sheet失败"
- br.ErrMsg = "新增Sheet失败," + err.Error()
- br.Ret = 408
- return
- }
- row := sheet.AddRow()
- row.AddCell().SetValue("手机号")
- row.AddCell().SetValue("姓名")
- row.AddCell().SetValue("注册时间")
- row.AddCell().SetValue("累计阅读")
- row.AddCell().SetValue("最近阅读")
- row.AddCell().SetValue("客户名称")
- row.AddCell().SetValue("类型")
- row.AddCell().SetValue("状态")
- row.AddCell().SetValue("销售")
- row.AddCell().SetValue("阅读")
- row.AddCell().SetValue("路演")
- // 获取所有的用户
- condition := ""
- pars := make([]interface{}, 0)
- condition += ` AND a.qs_id = ? `
- pars = append(pars, qsId)
- switch i {
- case 1:
- condition += ` AND a.product_id = ? `
- pars = append(pars, 1)
- case 2:
- condition += ` AND a.product_id = ? `
- pars = append(pars, 2)
- case 3:
- condition += ` AND a.product_id = ? `
- pars = append(pars, 0)
- }
- total, list, err := yb.GetQsUserListForExport(condition, pars)
- if err != nil {
- br.Msg = "获取活动列表失败!"
- br.ErrMsg = "获取活动列表失败,Err:" + err.Error()
- return
- }
- if len(list) <= 0 {
- for n := 0; n < total; n++ {
- rowIndex := n + 1
- row := sheet.Row(rowIndex)
- row.AddCell()
- row.AddCell()
- row.AddCell()
- }
- } else {
- for j, item := range list {
- row := sheet.Row(j + 1)
- row.AddCell().SetValue(item.Mobile)
- row.AddCell().SetValue(item.Name)
- row.AddCell().SetValue(item.RegisterTime)
- row.AddCell().SetValue(item.ViewTotal)
- row.AddCell().SetValue(item.LastViewTime)
- row.AddCell().SetValue(item.CompanyName)
- productName := ""
- switch item.ProductId {
- case 1:
- productName = "FICC"
- case 2:
- productName = "权益"
- }
- row.AddCell().SetValue(productName)
- row.AddCell().SetValue(item.Status)
- row.AddCell().SetValue(item.SellerName)
- row.AddCell().SetValue(item.CompanyViewTotal)
- row.AddCell().SetValue(item.CompanyRoadTotal)
- }
- }
- }
- err := xlsxFile.Save(downLoadnFilePath)
- if err != nil {
- br.Msg = "保存文件失败"
- br.ErrMsg = "保存文件失败"
- return
- }
- fileName := `全时到会详情`
- fileName += time.Now().Format("06.01.02") + `.xlsx` //文件名称
- this.Ctx.Output.Download(downLoadnFilePath, fileName)
- defer func() {
- os.Remove(downLoadnFilePath)
- }()
- br.Ret = 200
- br.Success = true
- br.Msg = "success"
- }
- // QsShare2Seller
- // @Title 全时会议-分享给销售
- // @Description 全时会议-分享给销售
- // @Param request body request.QsShare2SellerReq true "type json string"
- // @router /activity/qs_share2seller [post]
- func (this *ActivityController) QsShare2Seller() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- var req request.QsShare2SellerReq
- err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if req.QsId <= 0 {
- br.Msg = "参数异常!"
- return
- }
- if req.SellerId <= 0 {
- br.Msg = "请选择销售"
- return
- }
- item, e := yb.GetQsEventByQsId(req.QsId)
- if e != nil {
- br.Msg = "操作失败"
- br.ErrMsg = "获取全时会议信息失败, Err: " + e.Error()
- return
- }
- item.ShareSellerId = req.SellerId
- item.ModifyTime = time.Now().Local()
- if e = item.Update([]string{"ShareSellerId", "ModifyTime"}); e != nil {
- br.Msg = "操作失败"
- br.ErrMsg = "更新全时会议销售失败, Err: " + e.Error()
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "操作成功"
- }
|