1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261 |
- package roadshow
- import (
- "encoding/json"
- "github.com/rdlucklib/rdluck_tools/paging"
- "hongze/hz_crm_api/models"
- "hongze/hz_crm_api/models/company"
- "hongze/hz_crm_api/models/roadshow"
- "hongze/hz_crm_api/models/system"
- "hongze/hz_crm_api/services"
- roadshowService "hongze/hz_crm_api/services/roadshow"
- "hongze/hz_crm_api/utils"
- "strconv"
- "strings"
- "time"
- )
- // ResearcherReportList
- // @Title 研究员路演统计
- // @Description 研究员路演统计接口
- // @Param DataType query string true "枚举值:week、month、time_interval"
- // @Param StartDate query string true "开始日期,格式:2022-04-06"
- // @Param EndDate query string true "结束日期,格式:2022-04-06"
- // @Success 200 {object} roadshow.RsReportRecordResp
- // @router /report/researcher/list [get]
- func (this *CalendarController) ResearcherReportList() {
- 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.GetString("DataType")
- startDate := this.GetString("StartDate")
- endDate := this.GetString("EndDate")
- var adminDataList []roadshowService.AdminDataMap
- var err error
- //var firstDate time.Time
- //获取列表
- switch dataType {
- case "week":
- adminDataList, _, err = roadshowService.GetWeekData("researcher", "company_status")
- if err != nil {
- br.Msg = "数据异常"
- br.ErrMsg = "数据异常,Err:" + err.Error()
- return
- }
- case "month":
- adminDataList, _, err = roadshowService.GetMonthData("researcher", "company_status")
- if err != nil {
- br.Msg = "数据异常"
- br.ErrMsg = "数据异常,Err:" + err.Error()
- return
- }
- case "time_interval":
- if startDate == `` || endDate == `` {
- br.Msg = "开始日期或结束日期不能为空"
- br.ErrMsg = "开始日期或结束日期不能为空,Err:" + err.Error()
- return
- }
- adminDataList, _, err = roadshowService.GetTimeIntervalData(startDate, endDate, "researcher", "company_status")
- if err != nil {
- br.Msg = "数据异常"
- br.ErrMsg = "数据异常,Err:" + err.Error()
- return
- }
- }
- group, err := roadshow.GetResearcherGroup()
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取分组信息失败!Err:" + err.Error()
- return
- }
- researcherList, err := roadshow.GetResearcherV2()
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取分组信息失败!,GetResearcherV2 Err:" + err.Error()
- return
- }
- groupMap := make(map[int][]*roadshow.Researcher)
- for _, v := range researcherList {
- //if v.RoleTypeCode == "ficc_admin" {
- // findItems := groupMap[1]
- // findItems = append(findItems, v)
- // groupMap[1] = findItems
- //} else {
- if findItems, ok := groupMap[v.GroupId]; ok {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- } else {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- }
- //}
- }
- groupReportRecordList := make([]roadshow.GroupReportRecord, 0)
- rsAllReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- RsReportRecordResp := roadshow.RsReportRecordResp{
- List: groupReportRecordList,
- RsReportRecordNumList: rsAllReportRecordNumList,
- }
- startDateIndexList := make(map[int]string) //开始时间间隔map
- endDateIndexList := make(map[int]string) //结束时间间隔map
- tmpAllTryOutNumMap := make(map[int]int)
- tmpAllFormalNumMap := make(map[int]int)
- tmpAllMeetingNumMap := make(map[int]int)
- for _, v := range group {
- v.ResearcherList = groupMap[v.GroupId]
- tmpGroupAdminReportRecord := make([]roadshow.AdminReportRecord, 0)
- tmpGroupRsReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- tmpGroupTryOutNumMap := make(map[int]int)
- tmpGroupFormalNumMap := make(map[int]int)
- tmpGroupMeetingNumMap := make(map[int]int)
- for _, researcher := range groupMap[v.GroupId] {
- //组内研究员数据
- //每个区间的数据
- tmpAdminRsReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- for index, adminData := range adminDataList {
- startDateIndexList[index] = adminData.StartDate
- endDateIndexList[index] = adminData.EndDate
- var tmpTryOutNum, tmpFormalNum, tmpMeetingNum int
- if num, ok := adminData.TryOutMap[researcher.AdminId]; ok {
- tmpTryOutNum = num
- }
- if num, ok := adminData.FormalMap[researcher.AdminId]; ok {
- tmpFormalNum = num
- }
- if num, ok := adminData.MeetingMap[researcher.AdminId]; ok {
- tmpMeetingNum = num
- }
- tmpAdminRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpTryOutNum,
- FormalNum: tmpFormalNum,
- MeetingNum: tmpMeetingNum,
- StartDate: adminData.StartDate,
- EndDate: adminData.EndDate,
- }
- tmpAdminRsReportRecordNumList = append(tmpAdminRsReportRecordNumList, tmpAdminRsReportRecordNum)
- //组内数据汇总
- if _, ok := tmpGroupTryOutNumMap[index]; !ok {
- tmpGroupTryOutNumMap[index] = 0
- }
- if _, ok := tmpGroupFormalNumMap[index]; !ok {
- tmpGroupFormalNumMap[index] = 0
- }
- if _, ok := tmpGroupMeetingNumMap[index]; !ok {
- tmpGroupMeetingNumMap[index] = 0
- }
- tmpGroupTryOutNumMap[index] += tmpTryOutNum
- tmpGroupFormalNumMap[index] += tmpFormalNum
- tmpGroupMeetingNumMap[index] += tmpMeetingNum
- //总数据汇总
- if _, ok := tmpAllTryOutNumMap[index]; !ok {
- tmpAllTryOutNumMap[index] = 0
- }
- if _, ok := tmpAllFormalNumMap[index]; !ok {
- tmpAllFormalNumMap[index] = 0
- }
- if _, ok := tmpAllMeetingNumMap[index]; !ok {
- tmpAllMeetingNumMap[index] = 0
- }
- tmpAllTryOutNumMap[index] += tmpTryOutNum
- tmpAllFormalNumMap[index] += tmpFormalNum
- tmpAllMeetingNumMap[index] += tmpMeetingNum
- }
- tmpAdminReportRecord := roadshow.AdminReportRecord{
- Name: researcher.RealName,
- AdminId: researcher.AdminId,
- RsReportRecordNumList: tmpAdminRsReportRecordNumList,
- }
- tmpGroupAdminReportRecord = append(tmpGroupAdminReportRecord, tmpAdminReportRecord)
- }
- for i := 0; i < len(tmpGroupMeetingNumMap); i++ {
- tmpGroupRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpGroupTryOutNumMap[i],
- FormalNum: tmpGroupFormalNumMap[i],
- MeetingNum: tmpGroupMeetingNumMap[i],
- StartDate: startDateIndexList[i],
- EndDate: endDateIndexList[i],
- }
- tmpGroupRsReportRecordNumList = append(tmpGroupRsReportRecordNumList, tmpGroupRsReportRecordNum)
- }
- groupReportRecord := roadshow.GroupReportRecord{
- Item: tmpGroupAdminReportRecord,
- Name: v.GroupName,
- RsReportRecordNumList: tmpGroupRsReportRecordNumList,
- }
- RsReportRecordResp.List = append(RsReportRecordResp.List, groupReportRecord)
- }
- //总体汇总数据
- for i := 0; i < len(tmpAllFormalNumMap); i++ {
- tmpGroupRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpAllTryOutNumMap[i],
- FormalNum: tmpAllFormalNumMap[i],
- MeetingNum: tmpAllMeetingNumMap[i],
- StartDate: startDateIndexList[i],
- EndDate: endDateIndexList[i],
- }
- rsAllReportRecordNumList = append(rsAllReportRecordNumList, tmpGroupRsReportRecordNum)
- }
- RsReportRecordResp.RsReportRecordNumList = rsAllReportRecordNumList
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = RsReportRecordResp
- return
- }
- // SellerReportList
- // @Title 销售路演统计
- // @Description 销售路演统计接口
- // @Param DataType query string true "枚举值:week、month、time_interval、online、offline"
- // @Param DimensionType query string true "维度枚举值:company_status、roadshow_type"
- // @Param StartDate query string true "开始日期,格式:2022-04-06"
- // @Param EndDate query string true "结束日期,格式:2022-04-06"
- // @Success 200 {object} roadshow.RsReportRecordResp
- // @router /report/seller/list [get]
- func (this *CalendarController) SellerReportList() {
- 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.GetString("DataType")
- dimensionType := this.GetString("DimensionType")
- startDate := this.GetString("StartDate")
- endDate := this.GetString("EndDate")
- if dimensionType == "" {
- dimensionType = "company_status"
- }
- var adminDataList []roadshowService.AdminDataMap
- var err error
- var firstDate time.Time
- //获取列表
- switch dataType {
- case "week":
- adminDataList, firstDate, err = roadshowService.GetWeekDataV2("seller", dimensionType, 6)
- if err != nil {
- br.Msg = "数据异常"
- br.ErrMsg = "数据异常,Err:" + err.Error()
- return
- }
- case "month":
- adminDataList, firstDate, err = roadshowService.GetMonthDataV2("seller", dimensionType, 6)
- if err != nil {
- br.Msg = "数据异常"
- br.ErrMsg = "数据异常,Err:" + err.Error()
- return
- }
- case "time_interval":
- if startDate == `` || endDate == `` {
- br.Msg = "开始日期或结束日期不能为空"
- br.ErrMsg = "开始日期或结束日期不能为空,Err:" + err.Error()
- return
- }
- adminDataList, firstDate, err = roadshowService.GetTimeIntervalData(startDate, endDate, "seller", dimensionType)
- if err != nil {
- br.Msg = "数据异常"
- br.ErrMsg = "数据异常,Err:" + err.Error()
- return
- }
- }
- group, groupIdRelationMap, err := services.GetFiccSystemGroup()
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取分组信息失败!Err:" + err.Error()
- return
- }
- researcherList, err := services.GetFiccSeller(firstDate, groupIdRelationMap)
- groupMap := make(map[int][]*roadshow.Researcher)
- for _, v := range researcherList {
- if v.RoleTypeCode == "ficc_admin" {
- findItems := groupMap[1]
- findItems = append(findItems, v)
- groupMap[1] = findItems
- } else {
- if findItems, ok := groupMap[v.GroupId]; ok {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- } else {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- }
- }
- }
- groupReportRecordList := make([]roadshow.GroupReportRecord, 0)
- rsAllReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- RsReportRecordResp := roadshow.RsReportRecordResp{
- List: groupReportRecordList,
- RsReportRecordNumList: rsAllReportRecordNumList,
- }
- startDateIndexList := make(map[int]string) //开始时间间隔map
- endDateIndexList := make(map[int]string) //结束时间间隔map
- tmpAllTryOutNumMap := make(map[int]int)
- tmpAllFormalNumMap := make(map[int]int)
- tmpAllMeetingNumMap := make(map[int]int)
- tmpAllOnlineNumMap := make(map[int]int)
- tmpAllOfflineNumMap := make(map[int]int)
- for _, v := range group {
- v.ResearcherList = groupMap[v.GroupId]
- tmpGroupAdminReportRecord := make([]roadshow.AdminReportRecord, 0)
- tmpGroupRsReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- tmpGroupTryOutNumMap := make(map[int]int)
- tmpGroupFormalNumMap := make(map[int]int)
- tmpGroupMeetingNumMap := make(map[int]int)
- tmpGroupOnlineNumMap := make(map[int]int)
- tmpGroupOfflineNumMap := make(map[int]int)
- for _, researcher := range groupMap[v.GroupId] {
- //组内研究员数据
- //每个区间的数据
- tmpAdminRsReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- for index, adminData := range adminDataList {
- startDateIndexList[index] = adminData.StartDate
- endDateIndexList[index] = adminData.EndDate
- var tmpTryOutNum, tmpFormalNum, tmpMeetingNum, tmpOnlineNum, tmpOfflineNum int
- if num, ok := adminData.TryOutMap[researcher.AdminId]; ok {
- tmpTryOutNum = num
- }
- if num, ok := adminData.FormalMap[researcher.AdminId]; ok {
- tmpFormalNum = num
- }
- if num, ok := adminData.MeetingMap[researcher.AdminId]; ok {
- tmpMeetingNum = num
- }
- if num, ok := adminData.OnlineMap[researcher.AdminId]; ok {
- tmpOnlineNum = num
- }
- if num, ok := adminData.OfflineMap[researcher.AdminId]; ok {
- tmpOfflineNum = num
- }
- tmpAdminRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpTryOutNum,
- FormalNum: tmpFormalNum,
- MeetingNum: tmpMeetingNum,
- OnlineNum: tmpOnlineNum,
- OfflineNum: tmpOfflineNum,
- StartDate: adminData.StartDate,
- EndDate: adminData.EndDate,
- }
- tmpAdminRsReportRecordNumList = append(tmpAdminRsReportRecordNumList, tmpAdminRsReportRecordNum)
- //组内数据汇总
- if _, ok := tmpGroupTryOutNumMap[index]; !ok {
- tmpGroupTryOutNumMap[index] = 0
- }
- if _, ok := tmpGroupFormalNumMap[index]; !ok {
- tmpGroupFormalNumMap[index] = 0
- }
- if _, ok := tmpGroupMeetingNumMap[index]; !ok {
- tmpGroupMeetingNumMap[index] = 0
- }
- if _, ok := tmpGroupOnlineNumMap[index]; !ok {
- tmpGroupOnlineNumMap[index] = 0
- }
- if _, ok := tmpGroupOfflineNumMap[index]; !ok {
- tmpGroupOfflineNumMap[index] = 0
- }
- tmpGroupTryOutNumMap[index] += tmpTryOutNum
- tmpGroupFormalNumMap[index] += tmpFormalNum
- tmpGroupMeetingNumMap[index] += tmpMeetingNum
- tmpGroupOnlineNumMap[index] += tmpOnlineNum
- tmpGroupOfflineNumMap[index] += tmpOfflineNum
- //总数据汇总
- if _, ok := tmpAllTryOutNumMap[index]; !ok {
- tmpAllTryOutNumMap[index] = 0
- }
- if _, ok := tmpAllFormalNumMap[index]; !ok {
- tmpAllFormalNumMap[index] = 0
- }
- if _, ok := tmpAllMeetingNumMap[index]; !ok {
- tmpAllMeetingNumMap[index] = 0
- }
- if _, ok := tmpAllOnlineNumMap[index]; !ok {
- tmpAllOnlineNumMap[index] = 0
- }
- if _, ok := tmpAllOfflineNumMap[index]; !ok {
- tmpAllOfflineNumMap[index] = 0
- }
- tmpAllTryOutNumMap[index] += tmpTryOutNum
- tmpAllFormalNumMap[index] += tmpFormalNum
- tmpAllMeetingNumMap[index] += tmpMeetingNum
- tmpAllOnlineNumMap[index] += tmpOnlineNum
- tmpAllOfflineNumMap[index] += tmpOfflineNum
- }
- tmpAdminReportRecord := roadshow.AdminReportRecord{
- Name: researcher.RealName,
- AdminId: researcher.AdminId,
- RsReportRecordNumList: tmpAdminRsReportRecordNumList,
- }
- tmpGroupAdminReportRecord = append(tmpGroupAdminReportRecord, tmpAdminReportRecord)
- }
- for i := 0; i < len(tmpGroupMeetingNumMap); i++ {
- tmpGroupRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpGroupTryOutNumMap[i],
- FormalNum: tmpGroupFormalNumMap[i],
- MeetingNum: tmpGroupMeetingNumMap[i],
- OnlineNum: tmpGroupOnlineNumMap[i],
- OfflineNum: tmpGroupOfflineNumMap[i],
- StartDate: startDateIndexList[i],
- EndDate: endDateIndexList[i],
- }
- tmpGroupRsReportRecordNumList = append(tmpGroupRsReportRecordNumList, tmpGroupRsReportRecordNum)
- }
- groupReportRecord := roadshow.GroupReportRecord{
- Item: tmpGroupAdminReportRecord,
- Name: v.GroupName,
- GruopId: v.GroupId,
- RsReportRecordNumList: tmpGroupRsReportRecordNumList,
- }
- groupReportRecordList = append(groupReportRecordList, groupReportRecord)
- }
- //总体汇总数据
- for i := 0; i < len(tmpAllFormalNumMap); i++ {
- tmpGroupRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpAllTryOutNumMap[i],
- FormalNum: tmpAllFormalNumMap[i],
- MeetingNum: tmpAllMeetingNumMap[i],
- OnlineNum: tmpAllOnlineNumMap[i],
- OfflineNum: tmpAllOfflineNumMap[i],
- StartDate: startDateIndexList[i],
- EndDate: endDateIndexList[i],
- }
- rsAllReportRecordNumList = append(rsAllReportRecordNumList, tmpGroupRsReportRecordNum)
- }
- RsReportRecordResp.RsReportRecordNumList = rsAllReportRecordNumList
- //tmpList := groupReportRecordList
- //因为RoleTypeCode不一样,所以需要重新从数据库取数据
- //adminInfo, _ := system.GetSysAdminById(sysUser.AdminId)
- //adminGroupId := adminInfo.GroupId
- //if tmpGroupId, ok := groupIdRelationMap[adminGroupId]; ok {
- // adminGroupId = tmpGroupId
- //}
- //switch adminInfo.RoleTypeCode {
- //case utils.ROLE_TYPE_CODE_FICC_GROUP, utils.ROLE_TYPE_CODE_FICC_TEAM:
- // for index, v := range tmpList {
- // //如果不是同一个分组,那么就移除该分组下的人员数据
- // if v.GruopId != adminGroupId {
- // tmpList[index].Item = make([]roadshow.AdminReportRecord, 0)
- // }
- // }
- // RsReportRecordResp.List = tmpList
- //case utils.ROLE_TYPE_CODE_FICC_ADMIN, utils.ROLE_TYPE_CODE_ADMIN:
- // //管理员、超管看全部数据
- // RsReportRecordResp.List = groupReportRecordList
- //}
- // 20230529-有权限查看该页面的用户权限同admin
- RsReportRecordResp.List = groupReportRecordList
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = RsReportRecordResp
- return
- }
- // ReportCalendarList
- // @Title 路演详情列表
- // @Description 路演详情列表接口
- // @Param AdminType query string true "枚举值:researcher、seller、 special:专项路演"
- // @Param DataType query string true "枚举值:try_out、formal、meeting、online、offline"
- // @Param AdminId query int true "用户id"
- // @Param StartDate query string true "开始日期,格式:2022-04-06"
- // @Param EndDate query string true "结束日期,格式:2022-04-06"
- // @Success 200 {object} []roadshow.RsReportRecordList
- // @router /report/calendar/list [get]
- func (this *CalendarController) ReportCalendarList() {
- 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
- }
- adminType := this.GetString("AdminType")
- dataType := this.GetString("DataType")
- startDate := this.GetString("StartDate")
- endDate := this.GetString("EndDate")
- adminId, _ := this.GetInt("AdminId")
- if adminId <= 0 {
- br.Msg = "请传入对应的人员"
- return
- }
- //正式客户
- var condition string
- var pars []interface{}
- condition = ` and a.start_date >= ? and a.end_date <= ? `
- pars = append(pars, startDate, endDate)
- //选择的人员类型(发起人还是被发起人)
- if adminType == "seller" {
- condition += ` and a.seller_id = ? `
- } else if adminType == "special" {
- condition += ` and a.seller_id = ? `
- detail, err := company.GetConfigDetailByCode("choice_researcher_adminid")
- if err != nil {
- br.Msg = "获取研究员信息失败!"
- br.ErrMsg = "选择研究员失败,Err:" + err.Error()
- return
- }
- condition += ` and a.researcher_id IN (` + detail.ConfigValue + `) `
- } else {
- condition += ` and a.researcher_id = ? `
- }
- pars = append(pars, adminId)
- //获取列表
- switch dataType {
- case "try_out":
- condition += ` and a.company_status = ? `
- pars = append(pars, "试用")
- case "formal":
- condition += ` and a.company_status = ? `
- pars = append(pars, "正式")
- case "meeting":
- condition += ` and a.activity_type = ? `
- pars = append(pars, "公开会议")
- case "online":
- condition += ` and a.roadshow_type = ? `
- pars = append(pars, "线上")
- case "offline":
- condition += ` and a.roadshow_type = ? `
- pars = append(pars, "线下")
- default:
- br.Msg = "请传入类型"
- br.ErrMsg = "请传入类型DataType"
- return
- }
- list, err := roadshow.GetRsReportRecordList(condition, pars)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取失败,ERR:" + err.Error()
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = list
- return
- }
- // ChoiceResearcher
- // @Title 选择的研究员
- // @Description 选择的研究员接口
- // @Param AdminIds query string true "研究员ID ,多个用 , 隔开"
- // @Success 200 操作成功
- // @router /report/choice/researcher [post]
- func (this *CalendarController) ChoiceResearcher() {
- 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 roadshow.ResearcherIds
- err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数解析异常!"
- br.ErrMsg = "参数解析失败,Err:" + err.Error()
- return
- }
- if req.AdminIds == "" {
- req.AdminIds = "0"
- }
- adminIdArr := strings.Split(req.AdminIds, ",")
- for _, v := range adminIdArr {
- _, err := strconv.Atoi(v)
- if err != nil {
- br.Msg = "选择研究员失败!"
- br.ErrMsg = "选择研究员失败,Err:" + err.Error()
- return
- }
- }
- err = company.CrmConfigUpdate(req.AdminIds, "choice_researcher_adminid")
- if err != nil {
- br.Msg = "操作失败"
- br.ErrMsg = "操作失败,Err:" + err.Error()
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "操作成功"
- return
- }
- // AdminList
- // @Title 选择的研究员列表
- // @Description 获取选择的研究员列表
- // @Success 200 {object} roadshow.Researcher
- // @Success 200 操作成功
- // @router /report/admin/list [get]
- func (this *CalendarController) AdminList() {
- 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
- }
- detail, err := company.GetConfigDetailByCode("choice_researcher_adminid")
- if err != nil {
- br.Msg = "获取研究员信息失败!"
- br.ErrMsg = "选择研究员失败,Err:" + err.Error()
- return
- }
- list, err := roadshow.GetChoiceResearcher(detail.ConfigValue)
- if err != nil {
- br.Msg = "操作失败"
- br.ErrMsg = "操作失败,Err:" + err.Error()
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "操作成功"
- br.Data = list
- return
- }
- // SellerReportList
- // @Title 专项路演统计
- // @Description 专项路演统计接口
- // @Success 200 {object} roadshow.RsReportRecordResp
- // @router /report/special/list [get]
- func (this *CalendarController) SpecialReportList() {
- 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
- }
- dimensionType := this.GetString("DimensionType")
- if dimensionType == "" {
- dimensionType = "seller_special"
- }
- var adminDataList []roadshowService.AdminDataMap
- var err error
- var firstDate time.Time
- //获取列表
- adminDataList, firstDate, err = roadshowService.GetWeekData("seller", dimensionType)
- if err != nil {
- br.Msg = "数据异常"
- br.ErrMsg = "数据异常,Err:" + err.Error()
- return
- }
- var haveData bool
- detail, err := company.GetConfigDetailByCode("choice_researcher_adminid")
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取选择研究员信息失败,Err:" + err.Error()
- return
- }
- adminMap := make(map[int]int)
- adminIdArr := strings.Split(detail.ConfigValue, ",")
- for _, v := range adminIdArr {
- adminId, err := strconv.Atoi(v)
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取选择研究员信息失败,Err:" + err.Error()
- return
- }
- adminMap[adminId] = adminId
- }
- group, groupIdRelationMap, err := services.GetFiccSystemGroup()
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取分组信息失败!Err:" + err.Error()
- return
- }
- researcherList, err := services.GetFiccSeller(firstDate, groupIdRelationMap)
- groupMap := make(map[int][]*roadshow.Researcher)
- for _, v := range researcherList {
- //if v.RoleTypeCode == "ficc_admin" {
- // findItems := groupMap[1]
- // findItems = append(findItems, v)
- // groupMap[1] = findItems
- //} else {
- if findItems, ok := groupMap[v.GroupId]; ok {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- } else {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- }
- //}
- }
- groupReportRecordList := make([]roadshow.GroupReportRecord, 0)
- rsAllReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- RsReportRecordResp := roadshow.RsReportRecordResp{
- List: groupReportRecordList,
- RsReportRecordNumList: rsAllReportRecordNumList,
- }
- startDateIndexList := make(map[int]string) //开始时间间隔map
- endDateIndexList := make(map[int]string) //结束时间间隔map
- tmpAllTryOutNumMap := make(map[int]int)
- tmpAllFormalNumMap := make(map[int]int)
- tmpAllMeetingNumMap := make(map[int]int)
- tmpAllOnlineNumMap := make(map[int]int)
- tmpAllOfflineNumMap := make(map[int]int)
- for _, v := range group {
- v.ResearcherList = groupMap[v.GroupId]
- tmpGroupAdminReportRecord := make([]roadshow.AdminReportRecord, 0)
- tmpGroupRsReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- tmpGroupTryOutNumMap := make(map[int]int)
- tmpGroupFormalNumMap := make(map[int]int)
- tmpGroupMeetingNumMap := make(map[int]int)
- tmpGroupOnlineNumMap := make(map[int]int)
- tmpGroupOfflineNumMap := make(map[int]int)
- for _, researcher := range groupMap[v.GroupId] {
- //组内研究员数据
- var isLook bool
- //如果是管理员或者本组的可以查看详情
- if sysUser.GroupId == v.GroupId || sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_ADMIN {
- isLook = true
- }
- //每个区间的数据
- tmpAdminRsReportRecordNumList := make([]roadshow.RsReportRecordNum, 0)
- var isAppend bool
- for index, adminData := range adminDataList {
- startDateIndexList[index] = adminData.StartDate
- endDateIndexList[index] = adminData.EndDate
- var tmpTryOutNum, tmpFormalNum, tmpMeetingNum, tmpOnlineNum, tmpOfflineNum int
- if num, ok := adminData.TryOutMap[researcher.AdminId]; ok {
- tmpTryOutNum = num
- }
- if num, ok := adminData.FormalMap[researcher.AdminId]; ok {
- tmpFormalNum = num
- }
- if num, ok := adminData.MeetingMap[researcher.AdminId]; ok {
- tmpMeetingNum = num
- }
- if num, ok := adminData.OnlineMap[researcher.AdminId]; ok {
- tmpOnlineNum = num
- }
- if num, ok := adminData.OfflineMap[researcher.AdminId]; ok {
- tmpOfflineNum = num
- }
- tmpAdminRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpTryOutNum,
- FormalNum: tmpFormalNum,
- MeetingNum: tmpMeetingNum,
- OnlineNum: tmpOnlineNum,
- OfflineNum: tmpOfflineNum,
- StartDate: adminData.StartDate,
- EndDate: adminData.EndDate,
- IsLook: isLook,
- }
- if tmpTryOutNum > 0 || tmpFormalNum > 0 || tmpMeetingNum > 0 || tmpOnlineNum > 0 || tmpOfflineNum > 0 {
- isAppend = true
- haveData = true
- }
- tmpAdminRsReportRecordNumList = append(tmpAdminRsReportRecordNumList, tmpAdminRsReportRecordNum)
- //组内数据汇总
- if _, ok := tmpGroupTryOutNumMap[index]; !ok {
- tmpGroupTryOutNumMap[index] = 0
- }
- if _, ok := tmpGroupFormalNumMap[index]; !ok {
- tmpGroupFormalNumMap[index] = 0
- }
- if _, ok := tmpGroupMeetingNumMap[index]; !ok {
- tmpGroupMeetingNumMap[index] = 0
- }
- if _, ok := tmpGroupOnlineNumMap[index]; !ok {
- tmpGroupOnlineNumMap[index] = 0
- }
- if _, ok := tmpGroupOfflineNumMap[index]; !ok {
- tmpGroupOfflineNumMap[index] = 0
- }
- tmpGroupTryOutNumMap[index] += tmpTryOutNum
- tmpGroupFormalNumMap[index] += tmpFormalNum
- tmpGroupMeetingNumMap[index] += tmpMeetingNum
- tmpGroupOnlineNumMap[index] += tmpOnlineNum
- tmpGroupOfflineNumMap[index] += tmpOfflineNum
- //总数据汇总
- if _, ok := tmpAllTryOutNumMap[index]; !ok {
- tmpAllTryOutNumMap[index] = 0
- }
- if _, ok := tmpAllFormalNumMap[index]; !ok {
- tmpAllFormalNumMap[index] = 0
- }
- if _, ok := tmpAllMeetingNumMap[index]; !ok {
- tmpAllMeetingNumMap[index] = 0
- }
- if _, ok := tmpAllOnlineNumMap[index]; !ok {
- tmpAllOnlineNumMap[index] = 0
- }
- if _, ok := tmpAllOfflineNumMap[index]; !ok {
- tmpAllOfflineNumMap[index] = 0
- }
- tmpAllTryOutNumMap[index] += tmpTryOutNum
- tmpAllFormalNumMap[index] += tmpFormalNum
- tmpAllMeetingNumMap[index] += tmpMeetingNum
- tmpAllOnlineNumMap[index] += tmpOnlineNum
- tmpAllOfflineNumMap[index] += tmpOfflineNum
- }
- tmpAdminReportRecord := roadshow.AdminReportRecord{
- Name: researcher.RealName,
- AdminId: researcher.AdminId,
- RsReportRecordNumList: tmpAdminRsReportRecordNumList,
- }
- if isAppend {
- tmpGroupAdminReportRecord = append(tmpGroupAdminReportRecord, tmpAdminReportRecord)
- }
- }
- for i := 0; i < len(tmpGroupMeetingNumMap); i++ {
- tmpGroupRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpGroupTryOutNumMap[i],
- FormalNum: tmpGroupFormalNumMap[i],
- MeetingNum: tmpGroupMeetingNumMap[i],
- OnlineNum: tmpGroupOnlineNumMap[i],
- OfflineNum: tmpGroupOfflineNumMap[i],
- StartDate: startDateIndexList[i],
- EndDate: endDateIndexList[i],
- }
- tmpGroupRsReportRecordNumList = append(tmpGroupRsReportRecordNumList, tmpGroupRsReportRecordNum)
- }
- groupReportRecord := roadshow.GroupReportRecord{
- Item: tmpGroupAdminReportRecord,
- Name: v.GroupName,
- GruopId: v.GroupId,
- RsReportRecordNumList: tmpGroupRsReportRecordNumList,
- }
- if len(tmpGroupAdminReportRecord) > 0 {
- groupReportRecordList = append(groupReportRecordList, groupReportRecord)
- }
- }
- //总体汇总数据
- for i := 0; i < len(tmpAllFormalNumMap); i++ {
- tmpGroupRsReportRecordNum := roadshow.RsReportRecordNum{
- TryOutNum: tmpAllTryOutNumMap[i],
- FormalNum: tmpAllFormalNumMap[i],
- MeetingNum: tmpAllMeetingNumMap[i],
- OnlineNum: tmpAllOnlineNumMap[i],
- OfflineNum: tmpAllOfflineNumMap[i],
- StartDate: startDateIndexList[i],
- EndDate: endDateIndexList[i],
- }
- rsAllReportRecordNumList = append(rsAllReportRecordNumList, tmpGroupRsReportRecordNum)
- }
- RsReportRecordResp.RsReportRecordNumList = rsAllReportRecordNumList
- tmpList := groupReportRecordList
- //因为RoleTypeCode不一样,所以需要重新从数据库取数据
- adminInfo, _ := system.GetSysAdminById(sysUser.AdminId)
- adminGroupId := adminInfo.GroupId
- if tmpGroupId, ok := groupIdRelationMap[adminGroupId]; ok {
- adminGroupId = tmpGroupId
- }
- switch adminInfo.RoleTypeCode {
- case utils.ROLE_TYPE_CODE_FICC_GROUP, utils.ROLE_TYPE_CODE_FICC_TEAM:
- for index, v := range tmpList {
- //如果不是同一个分组,那么就移除该分组下的人员数据
- if v.GruopId != adminGroupId {
- tmpList[index].Item = make([]roadshow.AdminReportRecord, 0)
- }
- }
- RsReportRecordResp.List = tmpList
- case utils.ROLE_TYPE_CODE_FICC_ADMIN, utils.ROLE_TYPE_CODE_ADMIN:
- //管理员、超管看全部数据
- RsReportRecordResp.List = groupReportRecordList
- }
- //判断是否有数据如果没有,处理数据为空
- if !haveData {
- RsReportRecordResp = roadshow.RsReportRecordResp{
- List: make([]roadshow.GroupReportRecord, 0),
- RsReportRecordNumList: make([]roadshow.RsReportRecordNum, 0),
- }
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = RsReportRecordResp
- return
- }
- // ResearcherReportList
- // @Title 研究员出差表
- // @Description 研究员出差表接口
- // @Param AdminId query int true "研究员id"
- // @Param WeekQuery query int false "周查询: 0-本期(本周及下周); 1-前两周; 2-后两周"
- // @Param BaseQueryDate query string false "周查询时的开始日期"
- // @Success 200 {object} roadshow.BusinessTripResp
- // @router /report/researcher/business_trip [get]
- func (this *CalendarController) ResearcherBusinessTrip() {
- 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
- }
- adminId, _ := this.GetInt("AdminId")
- weekQuery, _ := this.GetInt("WeekQuery")
- baseQueryDate := this.GetString("BaseQueryDate")
- //fmt.Println(adminId)
- group, err := roadshow.GetResearcherGroup()
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取分组信息失败!Err:" + err.Error()
- return
- }
- researcherList, err := roadshow.GetBusinessTripResearcher()
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取分组信息失败!,GetBusinessTripResearcher Err:" + err.Error()
- return
- }
- ////获取当天周日期
- //nowWeekStart := utils.GetNowWeekMonday().AddDate(0, 0, -2)
- ////nowWeekEnd := utils.GetNowWeekLastDay()
- ////获取下周日期
- //nextWeekStart := utils.GetNextWeekMonday().AddDate(0, 0, -2)
- //nextWeekEnd := utils.GetNextWeekLastDay().AddDate(0, 0, -2)
- var nowWeekStart time.Time
- if baseQueryDate == "" {
- now := time.Now()
- weekDay := int(now.Weekday())
- if weekDay == 6 {
- nowWeekStart, _ = time.ParseInLocation(utils.FormatDate, now.Format(utils.FormatDate), time.Local)
- } else {
- nowWeekStart, _ = time.ParseInLocation(utils.FormatDate, now.AddDate(0, 0, -(weekDay+1)).Format(utils.FormatDate), time.Local)
- }
- }
- // 查询需求是可以无限往前后两周查询, 以入参为本周开始日期
- if baseQueryDate != "" {
- t, e := time.ParseInLocation(utils.FormatDate, baseQueryDate, time.Local)
- if e != nil {
- br.Msg = "查询开始日期格式有误"
- return
- }
- nowWeekStart = t
- }
- // 前/后两周
- if weekQuery == 1 {
- nowWeekStart = nowWeekStart.AddDate(0, 0, -14)
- }
- if weekQuery == 2 {
- nowWeekStart = nowWeekStart.AddDate(0, 0, +14)
- }
- //nowWeekEnd := utils.GetNowWeekLastDay()
- //获取下周日期
- nextWeekStart := nowWeekStart.AddDate(0, 0, +7)
- nextWeekEnd := nowWeekStart.AddDate(0, 0, +13)
- //获取路演信息
- roadshowList, err := roadshow.GetBusinessTripList(adminId, nowWeekStart.Format(utils.FormatDate), nextWeekEnd.Format(utils.FormatDateTime))
- if err != nil {
- br.Msg = "获取信息失败!"
- br.ErrMsg = "获取路演信息失败!,GetBusinessTripList Err:" + err.Error()
- return
- }
- roadshowMap := make(map[int][]*roadshow.BusinessTripResearcherList)
- for _, v := range roadshowList {
- if findVals, ok := roadshowMap[v.ResearcherId]; ok {
- findVals = append(findVals, v)
- roadshowMap[v.ResearcherId] = findVals
- } else {
- roadsItems := make([]*roadshow.BusinessTripResearcherList, 0)
- roadsItems = append(roadsItems, v)
- roadshowMap[v.ResearcherId] = roadsItems
- }
- }
- //fmt.Println("roadshow json start")
- //jsonBody, err := json.Marshal(roadshowMap)
- //fmt.Println("json body:" + string(jsonBody))
- //fmt.Println("roadshow json end")
- groupMap := make(map[int][]*roadshow.BusinessTripResearcher)
- for _, v := range researcherList {
- if findRoadshowList, ok := roadshowMap[v.AdminId]; ok {
- tripList := make([]*roadshow.BusinessTrip, 0)
- researcherMap := make(map[string]string)
- for i := 0; i < 7; i++ {
- newDay, _ := time.ParseInLocation(utils.FormatDate, nowWeekStart.AddDate(0, 0, i).Format(utils.FormatDate), time.Local)
- weekDate := newDay.Format(utils.FormatDate)
- tripItem := new(roadshow.BusinessTrip)
- for _, r := range findRoadshowList {
- startDateT, _ := time.ParseInLocation(utils.FormatDate, r.StartDate, time.Local)
- endDateT, _ := time.ParseInLocation(utils.FormatDate, r.EndDate, time.Local)
- if int(endDateT.Sub(startDateT)) <= 0 {
- skey := strconv.Itoa(r.ResearcherId) + r.StartDate
- if _, sok := researcherMap[skey]; !sok {
- if r != nil && (newDay.Equal(startDateT) || (newDay.Equal(endDateT)) || (newDay.Before(endDateT) && newDay.After(startDateT))) {
- tripItem.City = r.City
- researcherMap[skey] = skey
- }
- }
- } else {
- if r != nil && (newDay.Equal(startDateT) || (newDay.Equal(endDateT)) || (newDay.Before(endDateT) && newDay.After(startDateT))) {
- tripItem.City = r.City
- //researcherMap[skey] = skey
- }
- }
- }
- tripItem.WeekDate = weekDate
- tripItem.WeekType = "current"
- tripItem.Week = newDay.Weekday().String()
- tripList = append(tripList, tripItem)
- }
- for i := 0; i < 7; i++ {
- newDay := nextWeekStart.AddDate(0, 0, i)
- weekDate := newDay.Format(utils.FormatDate)
- tripItem := new(roadshow.BusinessTrip)
- for _, r := range findRoadshowList {
- startDateT, _ := time.ParseInLocation(utils.FormatDate, r.StartDate, time.Local)
- endDateT, _ := time.ParseInLocation(utils.FormatDate, r.EndDate, time.Local)
- if int(endDateT.Sub(startDateT)) <= 0 {
- skey := strconv.Itoa(r.ResearcherId) + r.StartDate
- if _, sok := researcherMap[skey]; !sok {
- if r != nil && (newDay.Equal(startDateT) || (newDay.Equal(endDateT)) || (newDay.Before(endDateT) && newDay.After(startDateT))) {
- tripItem.City = r.City
- researcherMap[skey] = skey
- }
- }
- } else {
- if r != nil && (newDay.Equal(startDateT) || (newDay.Equal(endDateT)) || (newDay.Before(endDateT) && newDay.After(startDateT))) {
- tripItem.City = r.City
- //researcherMap[skey] = skey
- }
- }
- }
- tripItem.WeekDate = weekDate
- tripItem.WeekType = "next"
- tripItem.Week = newDay.Weekday().String()
- tripList = append(tripList, tripItem)
- }
- v.BusinessTripList = tripList
- //if v.RoleTypeCode == "ficc_admin" {
- // findItems := groupMap[1]
- // findItems = append(findItems, v)
- // groupMap[1] = findItems
- //} else {
- if findItems, ok := groupMap[v.GroupId]; ok {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- } else {
- findItems = append(findItems, v)
- groupMap[v.GroupId] = findItems
- }
- //}
- }
- }
- groupList := make([]*roadshow.BusinessTripGroup, 0)
- for _, v := range group {
- item := new(roadshow.BusinessTripGroup)
- item.GroupName = v.GroupName
- item.GroupId = v.GroupId
- item.ResearcherList = groupMap[v.GroupId]
- groupList = append(groupList, item)
- }
- resp := new(roadshow.BusinessTripResp)
- resp.GroupList = groupList
- resp.BaseDate = nowWeekStart.Format(utils.FormatDate)
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- return
- }
- // OverseasCustomReportCalendarList
- // @Title 路演详情列表
- // @Description 路演详情列表接口
- // @Param CompanyStatus query string true "客户状态,枚举值:正式、试用、关闭"
- // @Param SellerId query int true "销售id列表;多个用英文,分割"
- // @Param ResearcherId query int true "销售id列表;多个用英文,分割"
- // @Param StartDate query string true "开始日期,格式:2022-04-06"
- // @Param EndDate query string true "结束日期,格式:2022-04-06"
- // @Success 200 {object} []roadshow.RsReportRecordList
- // @router /overseas_custom/calendar/list [get]
- func (this *CalendarController) OverseasCustomReportCalendarList() {
- 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
- }
- companyStatus := this.GetString("CompanyStatus")
- startDate := this.GetString("StartDate")
- endDate := this.GetString("EndDate")
- sellerId := this.GetString("SellerId")
- researcherId := this.GetString("ResearcherId")
- 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)
- total, list, err := roadshow.GetOverseaCustomCalendarList(sellerId, researcherId, startDate, endDate, companyStatus, startSize, pageSize)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取失败,ERR:" + err.Error()
- return
- }
- page := paging.GetPaging(currentIndex, pageSize, total)
- resp := new(roadshow.OverseaCustomRecordInfoResp)
- resp.Paging = page
- resp.List = list
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- return
- }
- // OverseasCustomCalendarAdminList
- // @Title 海外客户路演用户列表接口
- // @Description 海外客户路演用户列表接口
- // @Param AdminType query string true "枚举值:researcher、seller"
- // @Success 200 {object} []roadshow.AdminInfo
- // @router /overseas_custom/sys_user/list [get]
- func (this *CalendarController) OverseasCustomCalendarAdminList() {
- 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
- }
- adminType := this.GetString("AdminType")
- var list []*roadshow.AdminInfo
- var err error
- //选择的人员类型(发起人还是被发起人)
- if adminType == "seller" {
- list, err = roadshow.GetOverseaCustomCalendarSellerList()
- } else if adminType == "researcher" {
- list, err = roadshow.GetOverseaCustomCalendarResearcherList()
- } else {
- br.Msg = "错误的类型"
- br.IsSendEmail = false
- }
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取失败,ERR:" + err.Error()
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = list
- return
- }
|