123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862 |
- package services
- import (
- "errors"
- "fmt"
- "hongze/hongze_clpt/models"
- "hongze/hongze_clpt/utils"
- "strconv"
- "strings"
- "time"
- )
- func GetActivityonditionList(user *models.WxUserItem, activityTypeId, chartPermissionIds, whichDay, activeState, label string, isPower, source int, keyWord string, playBack int) (conditionActivity string, err error) {
- adminIds, err := models.GetSelleridWhichGroup(user.CompanyId, 2)
- if err != nil {
- return
- }
- userType, permissionStr, err := GetUserType(user.CompanyId)
- if err != nil {
- return
- }
-
- companyProduct, err := models.GetCompanyProductDetail(user.CompanyId, 2)
- if err != nil && err.Error() != utils.ErrNoRow() {
- return
- }
- isMaker := user.IsMaker
- slicePer := strings.Split(permissionStr, ",")
- var permissionSqlStr string
- var permissionNameStr string
- for _, v := range slicePer {
- if userType == 1 {
-
- if !strings.Contains(v, utils.CHART_PERMISSION_NAME_YANXUAN) {
- permissionNameStr += "'" + v + "',"
- }
- } else {
- permissionNameStr += "'" + v + "',"
- }
- }
- permissionNameStr = strings.Replace(permissionNameStr, "(主观)", "", -1)
- permissionNameStr = strings.Replace(permissionNameStr, "(客观)", "", -1)
- permissionNameStr = strings.TrimRight(permissionNameStr, ",")
-
- if permissionNameStr == `` {
- permissionNameStr = `'宏观'`
- } else {
- permissionNameStr += `, '宏观'`
- }
- var condition string
- var conditionAdmin string
- var conditionHz string
- var sqlExport string
-
- sqlExport = ` AND (art.customer_type_ids LIKE '%` + strconv.Itoa(userType) + `%' `
- if userType == 2 {
- sqlExport += ` OR art.customer_type_ids LIKE '%3%' `
- }
- if (userType == 2 || userType == 3) && strings.Contains(permissionStr, "专家") {
- sqlExport += ` OR art.customer_type_ids LIKE '%4%' `
- }
- sqlExport += `) `
-
- if activityTypeId != "" {
- if activityTypeId == strconv.Itoa(utils.ANALYST_TELL_ACTIVITY_TYPE_ID) {
- condition = ` AND art.publish_status = 1 AND art.label != '' AND art.activity_type_id IN (` + activityTypeId + "," + strconv.Itoa(utils.C_CLASS_ACTIVITY_TYPE_ID) + `)`
- } else {
- condition = ` AND art.publish_status = 1 AND art.label != '' AND art.activity_type_id = ` + activityTypeId
- }
- }
-
- if label != "" {
- condition = ` AND art.label LIKE '%` + label + `%' `
- }
- if isPower == 1 {
- condition += permissionSqlStr
- }
-
- if len(chartPermissionIds) > 0 {
- condition += ` AND art.chart_permission_id IN (` + chartPermissionIds + `)`
- }
-
- if source == 1 {
- condition += ` AND art.yidong_activity_id = '' `
- }
- var conditionOr string
- if whichDay != "" {
- var startDate string
- var endDate string
- if whichDay == "1" {
- startDate = time.Now().Format(utils.FormatDate)
- endDate = startDate
- } else if whichDay == "2" {
- startDate = time.Now().AddDate(0, 0, +1).Format(utils.FormatDate)
- endDate = startDate
- } else if whichDay == "1,2" || whichDay == "2,1" {
- startDate = time.Now().Format(utils.FormatDate)
- endDate = time.Now().AddDate(0, 0, +1).Format(utils.FormatDate)
- } else if whichDay == "3" {
- startDate = utils.GetNowWeekMonday().Format(utils.FormatDate)
- endDate = utils.GetNowWeekSunday().Format(utils.FormatDate)
- } else if whichDay == "4" {
- startDate = utils.GetLastWeekMonday().Format(utils.FormatDate)
- endDate = utils.GetLastWeekSunday().Format(utils.FormatDate)
- } else if whichDay == "5" {
- startDate = utils.GetNowMonthFirstDay().Format(utils.FormatDate)
- endDate = utils.GetNowMonthLastDay().Format(utils.FormatDate)
- } else if whichDay == "6" {
- startDate = utils.GetLastMonthFirstDay().Format(utils.FormatDate)
- endDate = utils.GetLastMonthLastDay().Format(utils.FormatDate)
- } else if whichDay == "3,4" || whichDay == "4,3" {
- startDate = utils.GetLastWeekMonday().Format(utils.FormatDate)
- endDate = utils.GetNowWeekSunday().Format(utils.FormatDate)
- } else if whichDay == "5,6" || whichDay == "6,5" {
- startDate = utils.GetLastMonthFirstDay().Format(utils.FormatDate)
- endDate = utils.GetNowMonthLastDay().Format(utils.FormatDate)
- } else {
- startDate = utils.GetNowWeekMonday().Format(utils.FormatDate)
- endDate = utils.GetNowWeekSunday().Format(utils.FormatDate)
- }
- condition += ` AND art.activity_time >= ` + "'" + startDate + " 00:00:00'"
- condition += ` AND art.activity_time <= ` + "'" + endDate + " 23:59:59'"
- }
-
- if keyWord != "" {
- condition += ` AND (art.label LIKE '%` + keyWord + `%' OR art.activity_name LIKE '%` + keyWord + `%' ) `
- } else {
- if activeState != "" {
-
- if activeState == "1" {
- condition += ` AND art.active_state IN (1,2)`
- } else {
- condition += ` AND art.active_state IN (` + activeState + `)`
- }
- } else {
- condition += ` AND art.active_state IN (1,2)`
- }
- }
- if playBack == 1 {
- var pars []interface{}
- ativityVIdArry := make([]string, 0)
- voiceList, e := models.GetActivityVoiceListAll("", pars, 0, 1000)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = e
- return
- }
- for _, v := range voiceList {
- ativityVIdArry = append(ativityVIdArry, strconv.Itoa(v.ActivityId))
- }
- videoList, e := models.GetActivityVideoListAll("", pars, 0, 1000)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = e
- return
- }
- for _, v := range videoList {
- ativityVIdArry = append(ativityVIdArry, strconv.Itoa(v.ActivityId))
- }
-
-
-
- if len(ativityVIdArry) > 0 {
- ativityVIdstr := strings.Join(ativityVIdArry, ",")
- condition += ` AND art.activity_id IN (` + ativityVIdstr + `) `
- }
- }
-
- condition += ` AND art.publish_status = 1 `
- conditionHz = condition
-
- if isMaker == 0 {
- condition += ` AND art.is_maker_show = 0 `
- }
- conditionAdmin = condition + ` AND art.visible_range = 1 `
- condition += ` AND art.visible_range != 1 `
- if (userType == 2 || userType == 3 || userType == 4) && strings.Contains(permissionStr, "专家") {
- conditionOr += ` OR ( art.is_limit_people = 1 AND art.customer_type_ids LIKE '%4%' ` + condition + `) `
- }
- if (userType == 5) && strings.Contains(permissionStr, "专家") {
- conditionOr += ` OR ( art.is_limit_people = 1 AND art.customer_type_ids LIKE '%5%' ` + condition + `) `
- }
- if userType == 1 {
- conditionOr += ` OR ( art.is_limit_people = 0 ` + condition + permissionSqlStr + `) `
- } else {
- conditionOr += ` OR ( art.is_limit_people = 0 ` + condition + `) `
- }
- if userType == 6 || userType == 7 {
- conditionOr += ` OR ( art.customer_type_ids LIKE '%` + strconv.Itoa(userType) + `%' ` + condition + `) `
- }
- if companyProduct != nil {
- if companyProduct.Scale != "" {
- conditionOr += ` OR ( art.scale LIKE '%` + companyProduct.Scale + `%' ` + condition + `) `
- }
- }
- if adminIds != "" {
- conditionOr += ` OR ( art.customer_type_ids LIKE '%` + strconv.Itoa(userType) + `%' ` + ` AND art.admin_id IN (` + adminIds + `) ` + conditionAdmin + `) `
- if companyProduct != nil {
- if companyProduct.Scale != "" {
- conditionOr += ` OR ( art.scale LIKE '%` + companyProduct.Scale + `%'` + ` AND art.admin_id IN (` + adminIds + `) ` + conditionAdmin + `) `
- }
- }
- }
-
- if user.CompanyId == 16 {
- mapMobile, e := GetAdminMobileMap()
- if e != nil {
- err = e
- return
- }
- if _, ok := mapMobile[user.Mobile]; ok {
- conditionOr += ` OR ( art.publish_status = 1 ` + conditionHz + `) `
- }
- }
- conditionActivity = condition + permissionSqlStr + sqlExport + conditionOr
- return
- }
- func HandleActivityPowerList(listActivity []*models.CygxActivity, user *models.WxUserItem) (items []*models.CygxActivity, err error) {
- return
- }
- func LabelStr(label string, isShowSubjectName int, temporaryLabel string) (labelNew string) {
- slicebr := strings.Split(label, "-")
- if len(slicebr) > 1 {
- if isShowSubjectName == 1 {
- labelNew = slicebr[1]
- } else {
- labelNew = slicebr[0]
- }
- } else {
- labelNew = label
- }
- if temporaryLabel != "" {
- labelNew = temporaryLabel
- }
- return labelNew
- }
- func HandleActivityTypeHomeList(listType []*models.ActivityTypeHome, listActivity []*models.CygxActivity, user *models.WxUserItem) (items []*models.ActivityTypeHome, err error) {
- mapActivity := make(map[int][]*models.CygxActivityLabelList)
- activityIds := make([]int, 0)
- for _, v := range listActivity {
-
- if v.ActivityTypeId == 7 {
- v.ActivityTypeId = 2
- }
- if v.ActivityTypeId == 1 {
- activityIds = append(activityIds, v.ActivityId)
- }
- }
-
- newLabelMap, _, e := GetActivityNewLabelMap(activityIds)
- if e != nil {
- err = errors.New("获取产业新标签Map失败,GetActivityNewLabelMap Err: " + e.Error())
- return
- }
- mapkeyWord := make(map[string]string)
- for _, v := range listActivity {
- if v.Label == "" {
- continue
- }
-
- if v.ActivityTypeId == 7 {
- v.ActivityTypeId = 2
- }
- item := new(models.CygxActivityLabelList)
- item.KeyWord = LabelStr(v.Label, v.IsShowSubjectName, v.TemporaryLabel)
- if _, ok := mapkeyWord[fmt.Sprint(v.ActivityTypeId, "-", item.KeyWord)]; ok {
- continue
- }
- item.Resource = 1
- item.ActivityId = v.ActivityId
- if v.YidongActivityId != "" {
- item.IsExternalLabel = true
- }
- item.IsNew = newLabelMap[v.ActivityId]
- mapActivity[v.ActivityTypeId] = append(mapActivity[v.ActivityTypeId], item)
- mapkeyWord[fmt.Sprint(v.ActivityTypeId, "-", item.KeyWord)] = item.KeyWord
- }
- for _, v := range listType {
- v.Resource = 1
- if len(mapActivity[v.ActivityTypeId]) > 0 {
- v.List = mapActivity[v.ActivityTypeId]
- } else {
- v.List = make([]*models.CygxActivityLabelList, 0)
- }
- }
- items = listType
- fmt.Println(len(mapActivity))
- return
- }
- func GetActivityVoiceResp(mapActivityId []int) (mapItem map[int]*models.CygxActivityVoiceReq, err error) {
- activityVoiceList, err := models.GetCygxActivityVoiceReqList(mapActivityId)
- if err != nil && err.Error() != utils.ErrNoRow() {
- return
- }
- mapActivityVoice := make(map[int]*models.CygxActivityVoiceReq)
- if len(activityVoiceList) > 0 {
- for _, v := range activityVoiceList {
- mapActivityVoice[v.ActivityId] = v
- }
- }
- mapItem = mapActivityVoice
- return
- }
- func GetActivityVideoResp(mapActivityId []int) (mapItem map[int]*models.CygxActivityVideoListResp, err error) {
- var condition string
- var ativityVIdstr string
- for _, v := range mapActivityId {
- ativityVIdstr += strconv.Itoa(v) + ","
- }
- if ativityVIdstr == "" {
- return
- }
- ativityVIdstr = strings.TrimRight(ativityVIdstr, ",")
- condition += ` AND art.activity_id IN (` + ativityVIdstr + `) `
- var pars []interface{}
-
-
-
- videoList, e := models.GetActivityVideoListAll(condition, pars, 0, 1000)
- if e != nil && e.Error() != utils.ErrNoRow() {
- err = e
- return
- }
- mapActivityVideo := make(map[int]*models.CygxActivityVideoListResp)
- if len(videoList) > 0 {
- for _, v := range videoList {
- mapActivityVideo[v.ActivityId] = v
- }
- }
- mapItem = mapActivityVideo
- return
- }
- func ActivityButtonShow(item *models.ActivityDetail, user *models.WxUserItem) (itemActivity *models.ActivityListResp) {
- articleDetail := item
-
-
-
-
-
- activityTimeText := articleDetail.ActivityTimeText
- activityTimeText = strings.Replace(activityTimeText, "(", "(", -1)
- activityTimeText = strings.Replace(activityTimeText, ")", ")", -1)
- articleDetail.ActivityTimeText = activityTimeText
- var yidongActivityUrl string
- articleDetail.IsShowAppointment = false
-
- if articleDetail.YidongActivityId != "" {
- articleDetail.IsShowSignup = false
- articleDetail.IsShowDetails = true
- if articleDetail.YidongActivityId != "" {
- ydTgc, _ := GetYiDongCreateUserInfo(user)
- yidongLongLink, _ := GetYiDongOriginalLink(articleDetail)
- if yidongLongLink != "" {
- yidongActivityUrl = yidongLongLink + "%26source=11%26fromHz=true%26tgc=" + ydTgc
- }
- }
- } else {
-
- if articleDetail.ActivityTypeId == 1 && articleDetail.IsLimitPeople == 0 && (articleDetail.ActiveState == "1" || articleDetail.ActiveState == "2") {
- articleDetail.IsShowHelpSsk = true
- }
- if articleDetail.ActiveState == "1" {
-
- if articleDetail.IsCanAppointmentMinutes == 1 {
- articleDetail.IsShowAppointment = true
- }
-
- if articleDetail.ActivityTypeId == 1 {
- articleDetail.IsShowOutboundCall = true
- if articleDetail.IsLimitPeople == 0 {
- articleDetail.IsShowMeetingReminder = true
- articleDetail.IsShowHelpSsk = true
- }
- }
-
- if articleDetail.ActivityTypeId == 2 {
- articleDetail.IsShowOutboundCall = true
- if articleDetail.LimitPeopleNum == 0 {
- articleDetail.IsShowMeetingReminder = true
- }
- }
-
- if articleDetail.ActivityTypeId == 3 {
- if articleDetail.LimitPeopleNum == 0 {
- articleDetail.IsShowMeetingReminder = true
- articleDetail.IsShowOutboundCall = true
- } else {
- articleDetail.IsShowSignup = true
- }
- }
-
- if articleDetail.ActivityTypeId == 4 {
- articleDetail.IsShowSignup = true
- }
-
- if articleDetail.ActivityTypeId == 5 {
- articleDetail.IsShowSignup = true
- }
-
- if articleDetail.ActivityTypeId == 6 {
- articleDetail.IsShowSignup = true
- }
-
- if articleDetail.ActivityTypeId == 7 {
- articleDetail.IsShowSignup = true
- }
- }
- }
- v := articleDetail
- itemActivity = &models.ActivityListResp{
- ActivityId: v.ActivityId,
- ActivityTypeId: v.ActivityTypeId,
- ActivityTypeName: v.ActivityTypeName,
- ChartPermissionId: v.ChartPermissionId,
- ChartPermissionName: v.ChartPermissionName,
- IsLimitPeople: v.IsLimitPeople,
- LimitPeopleNum: v.LimitPeopleNum,
- LastUpdatedTime: v.LastUpdatedTime,
- ActivityTime: v.ActivityTime,
- ActivityTimeText: v.ActivityTimeText,
- DistinguishedGuest: v.DistinguishedGuest,
- Host: v.Host,
- Speaker: v.Speaker,
- MainlandTell: v.MainlandTell,
- HongKongTell: v.HongKongTell,
- TaiwanTell: v.TaiwanTell,
- AmericaTell: v.AmericaTell,
- ParticipationCode: v.ParticipationCode,
- Theme: v.Theme,
- Expert: v.Expert,
- ActivityName: v.ActivityName,
- OnlineParticipation: v.OnlineParticipation,
- ReportLink: v.ReportLink,
- City: v.City,
- Address: v.Address,
- Highlights: v.Highlights,
- Remarks: v.Remarks,
- IsSignup: v.IsSignup,
- IsCancelMeetingReminder: v.IsCancelMeetingReminder,
- IsAppointment: v.IsAppointment,
- ActiveState: v.ActiveState,
- IsShowSustainable: v.IsShowSustainable,
- Description: v.Description,
- IsResearch: v.IsResearch,
- IsHideAppointment: v.IsHideAppointment,
- IsCClassMeeting: v.IsCClassMeeting,
- Label: v.Label,
- ImgUrl: v.ImgUrl,
- ImgUrlText: v.ImgUrlText,
- ActivityType: v.ActivityType,
- IsShowOutboundCall: v.IsShowOutboundCall,
- IsShowMeetingReminder: v.IsShowMeetingReminder,
- IsShowHelpSsk: v.IsShowHelpSsk,
- IsShowSignup: v.IsShowSignup,
- IsShowAppointment: v.IsShowAppointment,
- IsShowDetails: v.IsShowDetails,
- AudioLink: v.AudioLink,
- VoiceDetail: v.VoiceList,
- VideoDetail: v.VideoDetail,
- FileType: v.FileType,
- SourceType: v.SourceType,
- SignupNum: v.SignupNum,
- YidongActivityUrl: yidongActivityUrl,
- AuthInfo: v.AuthInfo,
- }
- return
- }
- func ActivityDetaailShow(activityInfo *models.ActivityListResp) (itemActivity *models.ActivityListResp, err error) {
- itemActivity = activityInfo
- if GetShowSustainable() && strings.Contains(itemActivity.ChartPermissionName, "研选") {
- itemActivity.IsShowSustainable = true
- }
- if activityInfo.SignupNum > activityInfo.LimitPeopleNum {
- activityInfo.SignupNum = activityInfo.LimitPeopleNum
- }
- if activityInfo.ReportLink != "" {
- artList := strings.Split(activityInfo.ReportLink, "{|}")
- if len(artList) > 0 {
- for _, v := range artList {
- artitem := new(models.ActivityArticleResp)
- artitem.ReportLink = v
- artIdSlice := strings.Split(v, "/")
- if len(artIdSlice) > 0 {
- articleId, _ := strconv.Atoi(artIdSlice[len(artIdSlice)-1])
- artitem.ArticleId = articleId
- }
- activityInfo.ArticleList = append(activityInfo.ArticleList, artitem)
- }
- }
- } else {
- activityInfo.ArticleList = make([]*models.ActivityArticleResp, 0)
- }
- activityInfo.ActivityTypeName = strings.Replace(activityInfo.ActivityTypeName, "(C类)", "", -1)
- return
- }
- func GetActivityNewLabelMap(activityIds []int) (labelMap map[int]bool, industryNewMap map[int]bool, err error) {
- labelMap = make(map[int]bool, 0)
- industryNewMap = make(map[int]bool, 0)
- if len(activityIds) == 0 {
- return
- }
-
- var groupCond string
- var groupPars []interface{}
- groupCond += ` AND a.activity_id IN (` + utils.GetOrmInReplace(len(activityIds)) + `) AND b.source = 1 AND a.active_state != 3 `
- groupPars = append(groupPars, activityIds)
- groups, e := models.GetActivityIndustryRelationList(groupCond, groupPars)
- if e != nil {
- err = errors.New("获取活动产业关联列表失败, Err: " + e.Error())
- return
- }
- activityIndustryMap := make(map[int][]int, 0)
- industryIds := make([]int, 0)
- for i := range groups {
- industryIds = append(industryIds, groups[i].IndustrialManagementId)
- activityIndustryMap[groups[i].ActivityId] = append(activityIndustryMap[groups[i].ActivityId], groups[i].IndustrialManagementId)
- }
-
- industryLabelMap, e := GetIndustryNewLabelMap(industryIds)
- if e != nil {
- err = errors.New("获取产业新标签Map失败, Err: " + e.Error())
- return
- }
-
- for k := range industryLabelMap {
- for k2, v2 := range activityIndustryMap {
- if labelMap[k2] {
- continue
- }
-
- if utils.InArrayByInt(v2, k) {
- labelMap[k2] = true
- }
- }
- }
-
-
-
-
-
- articNewLabel, e := GetArticNewLabelWhithActivity3Month()
- if e != nil {
- err = errors.New("获取产业新标签Map失败, Err: " + e.Error())
- return
- }
- for k := range articNewLabel {
- labelMap[k] = false
- }
- return
- }
- func GetIndustryNewLabelMap(industryIds []int) (labelMap map[int]bool, err error) {
- labelMap = make(map[int]bool, 0)
- industryIdLen := len(industryIds)
- if industryIdLen == 0 {
- return
- }
-
- var timeCond string
- var timePars []interface{}
- timeCond += ` AND b.publish_status = 1`
- if industryIdLen > 0 {
- timeCond += ` AND a.industrial_management_id IN (` + utils.GetOrmInReplace(industryIdLen) + `)`
- timePars = append(timePars, industryIds)
- }
- industryTimeList, e := models.GetIndustryArticleMinMaxPublishTime(timeCond, timePars)
- if e != nil {
- err = errors.New("获取产业文章最大最小发布时间失败, Err: " + e.Error())
- return
- }
-
- nowTime := time.Now().Local()
- threeMonthBefore := nowTime.AddDate(0, -3, 0)
- nullTime, _ := time.ParseInLocation(utils.FormatDateTime, "0001-01-01 00:00:00", time.Local)
- industryMap := make(map[int]*models.IndustryArticleMinMaxPublishTime, 0)
- for i := range industryTimeList {
- industryMap[industryTimeList[i].IndustrialManagementId] = industryTimeList[i]
- }
- for i := range industryIds {
- iid := industryIds[i]
- item := industryMap[iid]
- if item != nil {
-
- if item.MinPublishTime.Equal(nullTime) || (item.MinPublishTime.After(threeMonthBefore)) {
- labelMap[iid] = true
- }
- } else {
-
- labelMap[iid] = true
- }
- }
- return
- }
- func GetActivityDetailUserPower(user *models.WxUserItem, activityInfo *models.ActivityDetail) (havePower bool, err error) {
- var companyDetailStatus string
- userType, permissionStr, e := GetUserType(user.CompanyId)
- if e != nil {
- err = errors.New("GetCompanyPermissionUpgrade, Err: " + e.Error())
- return
- }
- if user.CompanyId <= 1 {
- return
- } else {
- if permissionStr == "" {
- return
- } else {
- companyDetail, e := models.GetCompanyDetailById(user.CompanyId)
- if e != nil {
- err = errors.New("GetCompanyPermissionUpgrade, Err: " + e.Error())
- return
- }
- if companyDetail == nil {
- err = errors.New("客户不存在,uid:" + strconv.Itoa(user.UserId) + "CompanyId:" + strconv.Itoa(user.CompanyId))
- return
- }
- companyDetailStatus = companyDetail.Status
- }
- }
- if activityInfo.ChartPermissionId == 1 {
- havePower = true
- return
- }
- if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3) && strings.Contains(permissionStr, "专家") && activityInfo.LimitPeopleNum == 0 {
- havePower = true
- } else if activityInfo.ActivityTypeId == 3 && strings.Contains(permissionStr, "专家") && companyDetailStatus == "正式" && strings.Contains(activityInfo.CustomerTypeIds, "4") {
- havePower = true
- } else if activityInfo.ActivityTypeId == 3 && strings.Contains(permissionStr, "专家") && companyDetailStatus == "试用" && strings.Contains(activityInfo.CustomerTypeIds, "5") {
- havePower = true
- } else if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3 || activityInfo.ActivityTypeId == 4 || activityInfo.ActivityTypeId == 5) && strings.Contains(permissionStr, "专家") {
- havePower = true
- }
- if activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 6 || activityInfo.ActivityTypeId == 7 {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName+"(主观)") {
- havePower = true
- }
- } else {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName+"(客观)") {
- havePower = true
- }
- }
- if (strings.Contains(activityInfo.ChartPermissionName, "研选") || activityInfo.ChartPermissionName == "策略") && strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- havePower = true
- }
-
- if activityInfo.YidongActivityId != "" && permissionStr != "" && strings.Contains(activityInfo.ChartPermissionName, utils.CHART_PERMISSION_NAME_YANXUAN) {
- havePower = true
- }
- if havePower && activityInfo.LimitPeopleNum > 0 {
-
- noPower, e := GetShareNoPowe(activityInfo, permissionStr, userType, user)
- if e != nil {
- err = errors.New("GetShareNoPowe, Err: " + e.Error())
- return
- }
- if noPower {
- havePower = false
- }
- }
- return
- }
- func GetShareNoPowe(activityInfo *models.ActivityDetail, permissionStr string, userType int, user *models.WxUserItem) (noPower bool, err error) {
-
- if user.CompanyId == utils.HZ_COMPANY_ID {
- return
- }
- if (userType == 1 || userType == 4 || userType == 5) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(userType)) {
- noPower = true
- }
-
- if userType == 2 && strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(2)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(4)) {
- noPower = true
- }
- if userType == 2 && !strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(2)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) {
- noPower = true
- }
- if userType == 3 && strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(4)) {
- noPower = true
- }
- if userType == 3 && !strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) {
- noPower = true
- }
- if !noPower {
- noPower, err = CheckUserPowerByActivityChoose(user, activityInfo)
- }
- return
- }
- func CheckUserPowerByActivityChoose(user *models.WxUserItem, activityInfo *models.ActivityDetail) (noPower bool, err error) {
-
- if activityInfo.VisibleRange == 1 {
- adminIds, errAdmin := models.GetSelleridWhichGroup(user.CompanyId, 2)
- if errAdmin != nil {
- err = errAdmin
- return
- }
- sliceAdminIds := strings.Split(adminIds, ",")
- var haveAdminId bool
- for _, v := range sliceAdminIds {
- if v == strconv.Itoa(activityInfo.AdminId) {
- haveAdminId = true
- }
- }
- if !haveAdminId {
- noPower = true
- }
- }
-
- if activityInfo.IsMakerShow == 1 {
- if user.IsMaker == 0 {
- noPower = true
- }
- }
- return
- }
- func IsShowAppointment(activityTypeId int, chartPermissionName string) (isShowAppointment bool) {
- if activityTypeId == 1 || activityTypeId == 2 || activityTypeId == 3 || activityTypeId == 4 {
- isShowAppointment = true
- }
- if activityTypeId == 5 && chartPermissionName == "医药" {
- isShowAppointment = true
- }
- return
- }
- func GetActivityVideoDetailById(user *models.WxUserItem, videoId int) (industryVideo *models.CygxActivityVideoDetailResp, AuthInfo *models.UserPermissionAuthInfo, err error) {
- total, e := models.GetActivityVideoByVideoIdCount(videoId)
- if e != nil {
- err = errors.New("获取活动的视频失败,GetActivityVideoByVideoIdCount " + e.Error())
- return
- }
- if total == 0 {
- err = errors.New("视频不存在,或已取消发布")
- return
- }
-
- authInfo, permissionArr, e := GetUserRaiPermissionInfo(user.UserId, user.CompanyId)
- if e != nil {
- err = errors.New("获取用户权限失败,GetUserRaiPermissionInfo " + e.Error())
- return
- }
- videoSimple := new(models.CygxActivityVideoDetailResp)
-
- var au *models.UserPermissionAuthInfo
- videoSimple, e = models.GetCygxActivityVideoById(videoId)
- if e != nil {
- err = errors.New("获取产业关联的视频失败,GetMicroRoadshowVideoByIndustryId " + e.Error())
- return
- } else {
-
-
-
-
-
-
- if videoSimple.BackgroundImg == "" {
-
- _, videoMap, _, _, e := GetMicroRoadShowDefaultImgConfig()
- if e != nil {
- err = errors.New("获取视频默认配置图失败,GetMicroRoadshowVideoByIndustryId " + e.Error())
- return
- }
- videoSimple.BackgroundImg = videoMap[videoSimple.ChartPermissionId]
- }
- au = new(models.UserPermissionAuthInfo)
- au.SellerName = authInfo.SellerName
- au.SellerMobile = authInfo.SellerMobile
- au.HasPermission = authInfo.HasPermission
- au.OperationMode = authInfo.OperationMode
- if au.HasPermission == 1 {
-
- if videoSimple.ChartPermissionId != utils.HONG_GUAN_ID && !utils.InArrayByStr(permissionArr, videoSimple.ChartPermissionName) {
- au.HasPermission = 2
- }
- }
-
- if au.HasPermission != 1 {
- if au.OperationMode == UserPermissionOperationModeCall {
- au.PopupMsg = UserPermissionPopupMsgCallMicroVideo
- } else {
- au.PopupMsg = UserPermissionPopupMsgApplyMicroVideo
- }
- videoSimple.ResourceUrl = ""
- }
- }
- industryVideo = videoSimple
- AuthInfo = au
- return
- }
|