123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292 |
- package services
- import (
- "errors"
- "hongze/hongze_cygx/models"
- "hongze/hongze_cygx/utils"
- "strconv"
- "strings"
- "time"
- )
- func GetActivitySignUpUserMap(activityIds []int, user *models.WxUserItem) (mapUserId map[int]int, err error) {
- userId := user.UserId
- var condition string
- var pars []interface{}
- activityIdsLen := len(activityIds)
- if activityIdsLen > 0 {
- condition += ` AND activity_id IN (` + utils.GetOrmInReplace(activityIdsLen) + `)`
- pars = append(pars, activityIds)
- }
- condition += ` AND user_id = ? AND do_fail_type = 0 `
- pars = append(pars, userId)
- list, e := models.GetActivitySignuListByUser(condition, pars)
- if e != nil {
- err = errors.New("GetCygxActivitySpecialTripList, Err: " + e.Error())
- return
- }
- mapUid := make(map[int]int)
- for _, v := range list {
- mapUid[v.ActivityId] = v.UserId
- }
- mapUserId = mapUid
- return
- }
- func GetActivityReminderUserMasp(activityIds []int, user *models.WxUserItem) (mapUserId map[int]int, err error) {
- userId := user.UserId
- var condition string
- var pars []interface{}
- activityIdsLen := len(activityIds)
- if activityIdsLen > 0 {
- condition += ` AND activity_id IN (` + utils.GetOrmInReplace(activityIdsLen) + `)`
- pars = append(pars, activityIds)
- }
- condition += ` AND user_id = ? `
- pars = append(pars, userId)
- list, e := models.GetCygxReminderListByUser(condition, pars)
- if e != nil {
- err = errors.New("GetCygxReminderListByUser, Err: " + e.Error())
- return
- }
- mapUid := make(map[int]int)
- for _, v := range list {
- mapUid[v.ActivityId] = v.UserId
- }
- mapUserId = mapUid
- return
- }
- func GetActivityAppointmentUserMap(activityIds []int, user *models.WxUserItem) (mapUserId map[int]int, err error) {
- userId := user.UserId
- var condition string
- var pars []interface{}
- activityIdsLen := len(activityIds)
- if activityIdsLen > 0 {
- condition += ` AND activity_id IN (` + utils.GetOrmInReplace(activityIdsLen) + `)`
- pars = append(pars, activityIds)
- }
- condition += ` AND user_id = ? `
- pars = append(pars, userId)
- list, e := models.GetCygxAppointmentListByUser(condition, pars)
- if e != nil {
- err = errors.New("GetCygxActivitySpecialTripList, Err: " + e.Error())
- return
- }
- mapUid := make(map[int]int)
- for _, v := range list {
- mapUid[v.ActivityId] = v.UserId
- }
- mapUserId = mapUid
- return
- }
- func HandleActivityListButton(list []*models.ActivityDetail, user *models.WxUserItem) (items []*models.ActivityDetail, err error) {
- var activityIds []int
- var activitySpecilalIds []int
- for k, v := range list {
- if v.SourceType == 2 {
- activitySpecilalIds = append(activitySpecilalIds, v.ActivityId)
-
- if v.ActivityType == 2 {
- list[k].ActivityType = 0
- }
- list[k].IsShowSignup = true
- } else {
- activityIds = append(activityIds, v.ActivityId)
- }
- }
-
- if len(activityIds) > 0 {
-
- mapSignUp, e := GetActivitySignUpUserMap(activityIds, user)
- if e != nil {
- err = errors.New("GetActivitySignUpUserMap, Err: " + e.Error())
- return
- }
- for k, v := range list {
- if v.SourceType != 2 {
- if _, ok := mapSignUp[v.ActivityId]; ok {
- list[k].IsSignup = 1
- }
- }
- }
-
- mapAppointment, e := GetActivityAppointmentUserMap(activityIds, user)
- if e != nil {
- err = errors.New("GetActivityAppointmentUserMap, Err: " + e.Error())
- return
- }
- for k, v := range list {
- if v.SourceType != 2 {
- if _, ok := mapAppointment[v.ActivityId]; ok {
- list[k].IsAppointment = 1
- }
- }
- }
-
- mapReminder, e := GetActivityReminderUserMasp(activityIds, user)
- if e != nil {
- err = errors.New("GetActivityReminderUserMasp, Err: " + e.Error())
- return
- }
- for k, v := range list {
- if v.SourceType != 2 {
- if _, ok := mapReminder[v.ActivityId]; ok {
- list[k].IsCancelMeetingReminder = 1
- }
- }
- }
- }
-
- if len(activitySpecilalIds) > 0 {
-
- UserMap, e := GetSpecialTripUserMap(activitySpecilalIds, user.UserId)
- if e != nil {
- err = errors.New("GetSpecialTripUserMap, Err: " + e.Error())
- return
- }
- for k, v := range list {
- if v.SourceType == 2 {
- if _, ok := UserMap[v.ActivityId]; ok {
- list[k].IsSignup = 1
- }
- }
- }
- for k, v := range list {
- if v.SourceType == 2 {
- resultTimeStart := utils.StrTimeToTime(v.ActivityTime)
- resultTimeEnd := utils.StrTimeToTime(v.ActivityTimeEnd)
- if resultTimeStart.After(time.Now()) {
- list[k].ActiveState = strconv.Itoa(1)
- } else if time.Now().After(resultTimeEnd) {
- list[k].ActiveState = strconv.Itoa(3)
- } else {
- list[k].ActiveState = strconv.Itoa(2)
- }
- }
- }
- }
-
- isShow, e := GetShowSustainableNew()
- if e != nil {
- err = errors.New("GetShowSustainableNew, Err: " + e.Error())
- return
- }
- detail, e := models.GetConfigByCode("city_img_url")
- if e != nil {
- err = errors.New("GetConfigByCode, Err: " + e.Error())
- return
- }
- detailChart, e := models.GetConfigByCode("chart_img_url")
- if e != nil {
- err = errors.New("GetConfigByCode, Err: " + e.Error())
- return
- }
- addressList := strings.Split(detail.ConfigValue, "{|}")
- mapAddress := make(map[string]string)
- chartList := strings.Split(detailChart.ConfigValue, "{|}")
- mapChart := make(map[string]string)
- var cityName string
- var chartName string
- var imgUrl string
- var imgUrlChart string
- var mapActivityId []int
- for _, v := range addressList {
- vslice := strings.Split(v, "_")
- cityName = vslice[0]
- imgUrl = vslice[len(vslice)-1]
- mapAddress[cityName] = imgUrl
- }
- for _, v := range chartList {
- vslice := strings.Split(v, "_")
- chartName = vslice[0]
- imgUrlChart = vslice[len(vslice)-1]
- mapChart[chartName] = imgUrlChart
- }
- for k, v := range list {
- if strings.Contains(v.ActivityName, "【") {
- list[k].IsBrackets = 1
- }
- if v.SignupNum > v.LimitPeopleNum {
- list[k].SignupNum = v.LimitPeopleNum
- }
- if isShow && strings.Contains(v.ChartPermissionName, "研选") {
- list[k].IsShowSustainable = true
- }
- if strings.Contains(v.ChartPermissionName, "研选") && v.ActivityTypeId == 1 {
- list[k].ActivityTypeName = "买方研选电话会"
- list[k].ImgUrlText = utils.YAN_XUAN_IMG
- }
- if v.SourceType == 1 {
- if v.ActivityType == 0 {
- if mapAddress[v.City] != "" {
- list[k].ImgUrl = mapAddress[v.City]
- } else {
- list[k].ImgUrl = mapAddress["其它"]
- }
- } else {
- if mapChart[v.ChartPermissionName] != "" {
- list[k].ImgUrl = mapChart[v.ChartPermissionName]
- }
- }
- } else {
- if mapChart[v.ChartPermissionName] != "" {
- list[k].ImgUrl = mapChart[v.ChartPermissionName]
- }
- }
- expertTxt, _ := GetReportContentTextSub(v.Expert)
- list[k].Expert = expertTxt
- if v.IsHideAppointment == 0 {
- list[k].IsShowAppointment = IsShowAppointment(v.ActivityTypeId, v.ChartPermissionName)
- }
- if v.ActivityTypeId == utils.C_CLASS_ACTIVITY_TYPE_ID {
- list[k].IsCClassMeeting = true
- }
- mapActivityId = append(mapActivityId, v.ActivityId)
- }
-
- mapActivityVoice, e := GetActivityVoiceResp(mapActivityId)
- if e != nil {
- err = errors.New("GetActivityVoiceResp, Err: " + e.Error())
- return
- }
-
- mapActivityVideo, e := GetActivityVideoResp(mapActivityId)
- if e != nil {
- err = errors.New("GetActivityVoiceResp, Err: " + e.Error())
- return
- }
-
- mapActivitySignup, e := GetActivitySignupResp(mapActivityId, user)
- if e != nil {
- e = errors.New("mapActivitySignup, Err: " + e.Error())
- return
- }
- for k, v := range list {
- if mapActivityVoice[v.ActivityId] != nil {
- list[k].FileType = 1
- list[k].AudioLink = true
- list[k].VoiceList = mapActivityVoice[v.ActivityId]
- }
- if mapActivityVideo[v.ActivityId] != nil {
- list[k].FileType = 2
- list[k].AudioLink = true
- list[k].VideoDetail = mapActivityVideo[v.ActivityId]
- }
- v.SignupType = mapActivitySignup[v.ActivityId]
- items = append(items, ActivityButtonShow(v))
- }
- return
- }
|