|
@@ -0,0 +1,1175 @@
|
|
|
+package services
|
|
|
+
|
|
|
+import (
|
|
|
+ "context"
|
|
|
+ "encoding/json"
|
|
|
+ "fmt"
|
|
|
+ "hongze/hongze_clpt/models"
|
|
|
+ "hongze/hongze_clpt/utils"
|
|
|
+ "strconv"
|
|
|
+
|
|
|
+ "errors"
|
|
|
+ "strings"
|
|
|
+ "time"
|
|
|
+)
|
|
|
+
|
|
|
+type SearchComprehensiveItem struct {
|
|
|
+ SourceId int `description:"资源ID"`
|
|
|
+ IsSummary int `description:"是否是纪要"`
|
|
|
+ Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial 、 本周研究汇总: researchsummary 、 上周纪要汇总 :minutessummary 、晨会精华 :meetingreviewchapt 、 产品内测:productinterior"`
|
|
|
+ Title string `description:"标题"`
|
|
|
+ BodyText string `description:"内容"`
|
|
|
+ PublishDate string `description:"发布时间"`
|
|
|
+ Abstract string `description:"摘要"`
|
|
|
+ Annotation string `description:"核心观点"`
|
|
|
+ IndustryName string `description:"产业名称"`
|
|
|
+ SubjectNames string `description:"标的名称"`
|
|
|
+ Body []string
|
|
|
+}
|
|
|
+
|
|
|
+type ElasticComprehensiveDetail struct {
|
|
|
+ SourceId int `description:"资源ID"`
|
|
|
+ IsSummary int `description:"是否是纪要"`
|
|
|
+ Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial 、 本周研究汇总: researchsummary 、 上周纪要汇总 :minutessummary 、晨会精华 :meetingreviewchapt 、 产品内测:productinterior 、 产业资源包:industrialsource"`
|
|
|
+ Title string `description:"标题"`
|
|
|
+ BodyText string `description:"内容"`
|
|
|
+ PublishDate string `description:"发布时间"`
|
|
|
+ Abstract string `description:"摘要"`
|
|
|
+ Annotation string `description:"核心观点"`
|
|
|
+ IndustryName string `description:"产业名称"`
|
|
|
+ SubjectNames string `description:"标的名称"`
|
|
|
+}
|
|
|
+
|
|
|
+func EsComprehensiveSearch(keyWord string, startSize, pageSize int) (result []*SearchComprehensiveItem, total int64, err error) {
|
|
|
+ indexName := utils.IndexNameComprehensive
|
|
|
+ client := utils.Client
|
|
|
+ keyWordArr, err := GetIndustryMapNameSliceV3(keyWord)
|
|
|
+ keyWordArr = RemoveDuplicatesAndEmpty(keyWordArr)
|
|
|
+ keyWordLen := len(keyWordArr)
|
|
|
+ if keyWordLen <= 0 {
|
|
|
+ keyWordArr = append(keyWordArr, keyWord)
|
|
|
+ keyWordLen = len(keyWordArr)
|
|
|
+ }
|
|
|
+ fmt.Println(keyWordArr)
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ mustMap := make([]interface{}, 0)
|
|
|
+ shouldMap := make(map[string]interface{}, 0)
|
|
|
+ shouldMapquery := make([]interface{}, 0)
|
|
|
+
|
|
|
+ mustNotMap := make([]interface{}, 0)
|
|
|
+ shouldNotMap := make(map[string]interface{}, 0)
|
|
|
+ shouldNotMapquery := make([]interface{}, 0)
|
|
|
+
|
|
|
+
|
|
|
+ var boost int
|
|
|
+
|
|
|
+ for k, v := range keyWordArr {
|
|
|
+ if k > 0 {
|
|
|
+ continue
|
|
|
+ }
|
|
|
+ if k == 0 {
|
|
|
+ boost = 2 * 1000
|
|
|
+ } else {
|
|
|
+ boost = 1
|
|
|
+ }
|
|
|
+
|
|
|
+ if v != "" {
|
|
|
+ shouldMapquery = append(shouldMapquery, map[string]interface{}{
|
|
|
+ "function_score": map[string]interface{}{
|
|
|
+ "query": map[string]interface{}{
|
|
|
+ "multi_match": map[string]interface{}{
|
|
|
+
|
|
|
+ "boost": boost,
|
|
|
+ "fields": []interface{}{"Title"},
|
|
|
+ "query": v,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ })
|
|
|
+ shouldMapquery = append(shouldMapquery, map[string]interface{}{
|
|
|
+ "function_score": map[string]interface{}{
|
|
|
+ "query": map[string]interface{}{
|
|
|
+ "multi_match": map[string]interface{}{
|
|
|
+ "boost": boost,
|
|
|
+ "fields": []interface{}{"Abstract"},
|
|
|
+ "query": v,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ })
|
|
|
+ shouldMapquery = append(shouldMapquery, map[string]interface{}{
|
|
|
+ "function_score": map[string]interface{}{
|
|
|
+ "query": map[string]interface{}{
|
|
|
+ "multi_match": map[string]interface{}{
|
|
|
+ "boost": boost,
|
|
|
+ "fields": []interface{}{"Annotation"},
|
|
|
+ "query": v,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ })
|
|
|
+
|
|
|
+ shouldMapquery = append(shouldMapquery, map[string]interface{}{
|
|
|
+ "function_score": map[string]interface{}{
|
|
|
+ "query": map[string]interface{}{
|
|
|
+ "multi_match": map[string]interface{}{
|
|
|
+
|
|
|
+ "boost": boost,
|
|
|
+ "fields": []interface{}{"BodyText"},
|
|
|
+ "query": v,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ })
|
|
|
+
|
|
|
+ shouldMapquery = append(shouldMapquery, map[string]interface{}{
|
|
|
+ "function_score": map[string]interface{}{
|
|
|
+ "query": map[string]interface{}{
|
|
|
+ "multi_match": map[string]interface{}{
|
|
|
+
|
|
|
+ "boost": boost,
|
|
|
+ "fields": []interface{}{"IndustryName"},
|
|
|
+ "query": v,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ })
|
|
|
+
|
|
|
+ shouldMapquery = append(shouldMapquery, map[string]interface{}{
|
|
|
+ "function_score": map[string]interface{}{
|
|
|
+ "query": map[string]interface{}{
|
|
|
+ "multi_match": map[string]interface{}{
|
|
|
+
|
|
|
+ "boost": boost,
|
|
|
+ "fields": []interface{}{"SubjectNames"},
|
|
|
+ "query": v,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ })
|
|
|
+ }
|
|
|
+ }
|
|
|
+ shouldMap = map[string]interface{}{
|
|
|
+ "should": shouldMapquery,
|
|
|
+ }
|
|
|
+
|
|
|
+ shouldNotMap = map[string]interface{}{
|
|
|
+ "should": shouldNotMapquery,
|
|
|
+ }
|
|
|
+
|
|
|
+ sortMap := make([]interface{}, 0)
|
|
|
+
|
|
|
+
|
|
|
+ sortMap = append(sortMap, map[string]interface{}{
|
|
|
+ "PublishDate": map[string]interface{}{
|
|
|
+ "order": "desc",
|
|
|
+ },
|
|
|
+ })
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ highlightMap := make(map[string]interface{}, 0)
|
|
|
+ highlightMap = map[string]interface{}{
|
|
|
+ "fields": map[string]interface{}{
|
|
|
+ "BodyText": map[string]interface{}{},
|
|
|
+ "Title": map[string]interface{}{},
|
|
|
+ "Abstract": map[string]interface{}{},
|
|
|
+ "Annotation": map[string]interface{}{},
|
|
|
+ },
|
|
|
+
|
|
|
+ "post_tags": []interface{}{"</font>"},
|
|
|
+ "pre_tags": []interface{}{"<font color='red'>"},
|
|
|
+ "fragment_size": 50,
|
|
|
+ }
|
|
|
+
|
|
|
+ mustMap = append(mustMap, map[string]interface{}{
|
|
|
+ "bool": shouldMap,
|
|
|
+ })
|
|
|
+ mustNotMap = append(mustNotMap, map[string]interface{}{
|
|
|
+ "bool": shouldNotMap,
|
|
|
+ })
|
|
|
+
|
|
|
+ queryMap := map[string]interface{}{
|
|
|
+ "query": map[string]interface{}{
|
|
|
+ "bool": map[string]interface{}{
|
|
|
+ "must": mustMap,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ }
|
|
|
+
|
|
|
+ queryMap["sort"] = sortMap
|
|
|
+ queryMap["from"] = startSize
|
|
|
+ queryMap["size"] = pageSize
|
|
|
+ queryMap["highlight"] = highlightMap
|
|
|
+ jsonBytes, _ := json.Marshal(queryMap)
|
|
|
+ fmt.Println(string(jsonBytes))
|
|
|
+
|
|
|
+ request := client.Search(indexName).Source(queryMap)
|
|
|
+ searchByMatch, err := request.Do(context.Background())
|
|
|
+ if searchByMatch != nil {
|
|
|
+ if searchByMatch.Hits != nil {
|
|
|
+ for _, v := range searchByMatch.Hits.Hits {
|
|
|
+ var isAppend bool
|
|
|
+ articleJson, err := v.Source.MarshalJSON()
|
|
|
+ if err != nil {
|
|
|
+ return nil, 0, err
|
|
|
+ }
|
|
|
+ article := new(ElasticComprehensiveDetail)
|
|
|
+ err = json.Unmarshal(articleJson, &article)
|
|
|
+ if err != nil {
|
|
|
+ return nil, 0, err
|
|
|
+ }
|
|
|
+ fmt.Println(article.SourceId, article.Title, article.Source)
|
|
|
+ searchItem := new(SearchComprehensiveItem)
|
|
|
+ searchItem.SourceId = article.SourceId
|
|
|
+ if len(v.Highlight["Annotation"]) > 0 {
|
|
|
+ for _, vText := range v.Highlight["Annotation"] {
|
|
|
+ searchItem.Body = append(searchItem.Body, vText)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if len(v.Highlight["Abstract"]) > 0 {
|
|
|
+ for _, vText := range v.Highlight["Abstract"] {
|
|
|
+ searchItem.Body = append(searchItem.Body, vText)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if len(v.Highlight["BodyText"]) > 0 {
|
|
|
+ for _, vText := range v.Highlight["BodyText"] {
|
|
|
+ searchItem.Body = append(searchItem.Body, vText)
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if len(searchItem.Body) == 0 {
|
|
|
+ bodyRune := []rune(article.BodyText)
|
|
|
+ bodyRuneLen := len(bodyRune)
|
|
|
+ if bodyRuneLen > 100 {
|
|
|
+ bodyRuneLen = 100
|
|
|
+ }
|
|
|
+ body := string(bodyRune[:bodyRuneLen])
|
|
|
+ searchItem.Body = []string{body}
|
|
|
+ }
|
|
|
+ var title string
|
|
|
+ if len(v.Highlight["Title"]) > 0 {
|
|
|
+ title = v.Highlight["Title"][0]
|
|
|
+ } else {
|
|
|
+ title = article.Title
|
|
|
+ }
|
|
|
+ searchItem.Title = title
|
|
|
+ searchItem.Source = article.Source
|
|
|
+ searchItem.PublishDate = article.PublishDate
|
|
|
+
|
|
|
+ if !isAppend {
|
|
|
+ result = append(result, searchItem)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ total = searchByMatch.Hits.TotalHits.Value
|
|
|
+ }
|
|
|
+ return
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+func GetResourceDataEsList(list []*SearchComprehensiveItem, user *models.WxUserItem) (items []*models.CygxResourceDataNewResp, err error) {
|
|
|
+ var condition string
|
|
|
+ var pars []interface{}
|
|
|
+ uid := user.UserId
|
|
|
+ mapItems := make(map[string]*models.CygxResourceDataNewResp)
|
|
|
+ for _, v := range list {
|
|
|
+
|
|
|
+ item := new(models.CygxResourceDataNewResp)
|
|
|
+ item.SourceId = v.SourceId
|
|
|
+ item.Source = v.Source
|
|
|
+ item.PublishDate = utils.TimeRemoveHms2(v.PublishDate)
|
|
|
+ mapItems[fmt.Sprint(v.Source, v.SourceId)] = item
|
|
|
+ }
|
|
|
+
|
|
|
+ var articleIds []int
|
|
|
+ var newchartIds []int
|
|
|
+ var roadshowIds []string
|
|
|
+ var activityIds []int
|
|
|
+ var activityvideoIds []string
|
|
|
+ var activityvoiceIds []string
|
|
|
+ var activityspecialIds []int
|
|
|
+ var researchsummaryIds []int
|
|
|
+ var minutessummaryIds []int
|
|
|
+ var meetingreviewchaptIds []int
|
|
|
+ var productinteriorIds []int
|
|
|
+ var industrialResourceIds []int
|
|
|
+
|
|
|
+ for _, v := range list {
|
|
|
+ if v.Source == "article" {
|
|
|
+ articleIds = append(articleIds, v.SourceId)
|
|
|
+ } else if v.Source == "newchart" {
|
|
|
+ newchartIds = append(newchartIds, v.SourceId)
|
|
|
+ } else if v.Source == "roadshow" {
|
|
|
+ roadshowIds = append(roadshowIds, strconv.Itoa(v.SourceId))
|
|
|
+ } else if v.Source == "activity" {
|
|
|
+ activityIds = append(activityIds, v.SourceId)
|
|
|
+ } else if v.Source == "activityvideo" {
|
|
|
+ activityvideoIds = append(activityvideoIds, strconv.Itoa(v.SourceId))
|
|
|
+ } else if v.Source == "activityvoice" {
|
|
|
+ activityvoiceIds = append(activityvoiceIds, strconv.Itoa(v.SourceId))
|
|
|
+ } else if v.Source == "activityspecial" {
|
|
|
+ activityspecialIds = append(activityspecialIds, v.SourceId)
|
|
|
+ } else if v.Source == "researchsummary" {
|
|
|
+ researchsummaryIds = append(researchsummaryIds, v.SourceId)
|
|
|
+ } else if v.Source == "minutessummary" {
|
|
|
+ minutessummaryIds = append(minutessummaryIds, v.SourceId)
|
|
|
+ } else if v.Source == "meetingreviewchapt" {
|
|
|
+ meetingreviewchaptIds = append(meetingreviewchaptIds, v.SourceId)
|
|
|
+ } else if v.Source == "productinterior" {
|
|
|
+ productinteriorIds = append(productinteriorIds, v.SourceId)
|
|
|
+ } else if v.Source == "industrialsource" {
|
|
|
+ industrialResourceIds = append(industrialResourceIds, v.SourceId)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ detail, e := models.GetConfigByCode("city_img_url")
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetResourceDataList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ detailChart, e := models.GetConfigByCode("chart_img_url")
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetResourceDataList, 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
|
|
|
+ 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
|
|
|
+ }
|
|
|
+ var imgUrlResp string
|
|
|
+
|
|
|
+
|
|
|
+ if len(articleIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND a.article_id IN (` + utils.GetOrmInReplace(len(articleIds)) + `)`
|
|
|
+ pars = append(pars, articleIds)
|
|
|
+ articleList, e := models.GetHomeListPublic(condition, pars, 0, len(articleIds))
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetResourceDataList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ articleList, e = HandleArticleCategoryImg(articleList, user)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("HandleArticleCategoryImg, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range articleList {
|
|
|
+ v.Body = ""
|
|
|
+ mapItems[fmt.Sprint("article", v.ArticleId)].Article = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(meetingreviewchaptIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND c.id IN (` + utils.GetOrmInReplace(len(meetingreviewchaptIds)) + `)`
|
|
|
+ pars = append(pars, meetingreviewchaptIds)
|
|
|
+
|
|
|
+ listrMeet, e := models.GetCygxMorningMeetingReviewChapterList(condition, pars)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetResourceDataList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range listrMeet {
|
|
|
+ v.Content = AnnotationHtml(v.Content)
|
|
|
+ v.PublishTime = utils.TimeRemoveHms2(v.PublishTime)
|
|
|
+ mapItems[fmt.Sprint("meetingreviewchapt", v.Id)].Meetingreviewchapt = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(minutessummaryIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND article_id IN (` + utils.GetOrmInReplace(len(minutessummaryIds)) + `)`
|
|
|
+ pars = append(pars, minutessummaryIds)
|
|
|
+
|
|
|
+ listresearchsummary, e := models.GetReportSelectionListHome(condition, "cygx_minutes_summary", pars, 0, len(minutessummaryIds))
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetResourceDataList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range listresearchsummary {
|
|
|
+ v.PublishDate = utils.TimeRemoveHms2(v.PublishDate)
|
|
|
+ mapItems[fmt.Sprint("minutessummary", v.ArticleId)].Minutessummary = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(researchsummaryIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND article_id IN (` + utils.GetOrmInReplace(len(researchsummaryIds)) + `)`
|
|
|
+ pars = append(pars, researchsummaryIds)
|
|
|
+
|
|
|
+ listresearchsummary, e := models.GetReportSelectionListHome(condition, "cygx_research_summary", pars, 0, len(researchsummaryIds))
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetReportSelectionListHome, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range listresearchsummary {
|
|
|
+ v.PublishDate = utils.TimeRemoveHms2(v.PublishDate)
|
|
|
+ mapItems[fmt.Sprint("researchsummary", v.ArticleId)].Researchsummary = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(productinteriorIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND art.status = 1 AND art.product_interior_id IN (` + utils.GetOrmInReplace(len(productinteriorIds)) + `)`
|
|
|
+ pars = append(pars, productinteriorIds)
|
|
|
+ listProductInterior, e := models.GetCygxProductInteriorList(condition, pars, 0, len(productinteriorIds))
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetCygxProductInteriorList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range listProductInterior {
|
|
|
+ v.Body = ProductInteriorHtml(v.Body)
|
|
|
+ v.PublishTime = utils.TimeRemoveHms2(v.PublishTime)
|
|
|
+ mapItems[fmt.Sprint("productinterior", v.ProductInteriorId)].ProductInterior = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(activityIds) > 0 {
|
|
|
+ for _, vss := range activityIds {
|
|
|
+ imgUrlResp += strconv.Itoa(vss) + ","
|
|
|
+ }
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND art.activity_id IN (` + utils.GetOrmInReplace(len(activityIds)) + `) `
|
|
|
+ pars = append(pars, activityIds)
|
|
|
+ activityList, e := models.GetActivityListNew(condition, pars, uid, 0, len(activityIds), 0, 0, "")
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetResourceDataList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ var activityListRersp []*models.ActivityListResp
|
|
|
+ for _, v := range activityList {
|
|
|
+ activityListRersp = append(activityListRersp, ActivityButtonShow(v, user, make([]string, 0)))
|
|
|
+ }
|
|
|
+
|
|
|
+ mapActivitySignup, e := GetActivitySignupResp(activityIds, user)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetActivitySignupResp, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range activityListRersp {
|
|
|
+ if v == nil {
|
|
|
+ continue
|
|
|
+ }
|
|
|
+ if v.ActivityType == 0 {
|
|
|
+ if mapAddress[v.City] != "" {
|
|
|
+ imgUrlResp = mapAddress[v.City]
|
|
|
+ } else {
|
|
|
+ imgUrlResp = mapAddress["其它"]
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if mapChart[v.ChartPermissionName] != "" {
|
|
|
+ imgUrlResp = mapChart[v.ChartPermissionName]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ v.ImgUrl = imgUrlResp
|
|
|
+ v.SourceType = mapActivitySignup[v.ActivityId]
|
|
|
+ mapItems[fmt.Sprint("activity", v.ActivityId)].Activity = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(industrialResourceIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+
|
|
|
+ var industrialResourceIdstring []string
|
|
|
+ for _, v := range industrialResourceIds {
|
|
|
+ industrialResourceIdstring = append(industrialResourceIdstring, strconv.Itoa(v))
|
|
|
+ }
|
|
|
+ industrialId := strings.Join(industrialResourceIdstring, ",")
|
|
|
+ condition = ` AND m.industrial_management_id IN (` + industrialId + `) `
|
|
|
+ listIndustrialResourceIds, e := models.GetSearchResourceList(condition)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetSearchResourceList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ conditionSubject := condition + ` AND m.industrial_management_id IN (` + utils.GetOrmInReplace(len(industrialResourceIds)) + `)`
|
|
|
+ pars = append(pars, industrialResourceIds)
|
|
|
+ listSubjcet, e := models.GetIndustrialSubjectAllByIndustrialId(pars, conditionSubject)
|
|
|
+
|
|
|
+ if e != nil {
|
|
|
+ e = errors.New("GetIndustrialSubjectAllByIndustrialId, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ mapIndustrial := make(map[string]int)
|
|
|
+ for _, v := range listSubjcet {
|
|
|
+ for k2, v2 := range listIndustrialResourceIds {
|
|
|
+ if v2.IndustrialManagementId == v.IndustrialManagementId && mapIndustrial[fmt.Sprint(v2.IndustrialManagementId, "Yx", v.SubjectName)] == 0 {
|
|
|
+ listIndustrialResourceIds[k2].IndustrialSubjectList = append(listIndustrialResourceIds[k2].IndustrialSubjectList, v)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ for _, v := range listIndustrialResourceIds {
|
|
|
+ mapItems[fmt.Sprint("industrialsource", v.IndustrialManagementId)].IndustrialResource = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(newchartIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND a.chart_id IN (` + utils.GetOrmInReplace(len(newchartIds)) + `)`
|
|
|
+ pars = append(pars, newchartIds)
|
|
|
+ chartDateList, e := models.GetChartListCollection(condition, pars, uid, 0, len(newchartIds))
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetResourceDataList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range chartDateList {
|
|
|
+ mapItems[fmt.Sprint("newchart", v.ChartId)].Newchart = v
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(activityspecialIds) > 0 {
|
|
|
+ pars = make([]interface{}, 0)
|
|
|
+ condition = ` AND art.activity_id IN (` + utils.GetOrmInReplace(len(activityspecialIds)) + `)`
|
|
|
+ pars = append(pars, activityspecialIds)
|
|
|
+ activitySpeciallist, e := models.GetCygxActivitySpecialDetailList(condition, pars, user.UserId, 0, len(activityspecialIds))
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetCygxActivitySpecialDetailList, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ UserMap, e := GetSpecialTripUserMap(activityspecialIds, user.UserId)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetSpecialTripUserMap, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ for _, v := range activitySpeciallist {
|
|
|
+ if mapChart[v.ChartPermissionName] != "" {
|
|
|
+ imgUrlResp = mapChart[v.ChartPermissionName]
|
|
|
+ }
|
|
|
+ if _, ok := UserMap[v.ActivityId]; ok {
|
|
|
+ v.IsTrip = 1
|
|
|
+ }
|
|
|
+ if v.Days == 0 {
|
|
|
+ v.TripStatus = 1
|
|
|
+ v.TripImgLink = v.TripImgLink
|
|
|
+ } else {
|
|
|
+ v.TripStatus = 2
|
|
|
+ v.TripImgLink = v.TripImgLinkFix
|
|
|
+ v.ActivityTimeText = v.ActivityTimeTextByDay
|
|
|
+ }
|
|
|
+ resultTimeStart := utils.StrTimeToTime(v.ActivityTime)
|
|
|
+ resultTimeEnd := utils.StrTimeToTime(v.ActivityTimeEnd)
|
|
|
+ if resultTimeStart.After(time.Now()) {
|
|
|
+ v.ActiveState = "1"
|
|
|
+ } else if time.Now().After(resultTimeEnd) {
|
|
|
+ v.ActiveState = "3"
|
|
|
+ } else {
|
|
|
+ v.ActiveState = "2"
|
|
|
+ }
|
|
|
+ v.ImgUrl = imgUrlResp
|
|
|
+ mapItems[fmt.Sprint("activityspecial", v.ActivityId)].Activityspecial = v
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if len(roadshowIds)+len(activityvideoIds)+len(activityvoiceIds) > 0 {
|
|
|
+
|
|
|
+ audioIdstr := strings.Join(activityvoiceIds, ",")
|
|
|
+ ideoIdsStr := strings.Join(roadshowIds, ",")
|
|
|
+ activityVideoIdsStr := strings.Join(activityvideoIds, ",")
|
|
|
+
|
|
|
+ list, _, e := GetMicroRoadShowMycollect(len(roadshowIds)+len(activityvideoIds)+len(activityvoiceIds), 0, audioIdstr, ideoIdsStr, activityVideoIdsStr)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetMicroRoadShowMycollect, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ for _, item := range list {
|
|
|
+ if item.Type == 1 {
|
|
|
+
|
|
|
+ count, e := models.GetVoiceCollectCount(user.UserId, item.Id)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetVoiceCollectCount, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ if count > 0 {
|
|
|
+ item.IsCollect = true
|
|
|
+ }
|
|
|
+ } else if item.Type == 2 {
|
|
|
+
|
|
|
+ count, e := models.GetActivityVideoCollectCount(user.UserId, item.Id)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetActivityVideoCollectCount, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ if count > 0 {
|
|
|
+ item.IsCollect = true
|
|
|
+ }
|
|
|
+ } else if item.Type == 3 {
|
|
|
+
|
|
|
+ count, e := models.GetVideoCollectCount(user.UserId, item.Id)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetVideoCollectCount, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ if count > 0 {
|
|
|
+ item.IsCollect = true
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ authInfo, permissionArr, e := GetUserRaiPermissionInfo(user.UserId, user.CompanyId)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetUserRaiPermissionInfo, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ audioMap, videoMap, audioShareMap, videoShareMap, e := GetMicroRoadShowDefaultImgConfig()
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetMicroRoadShowDefaultImgConfig, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ for i := range list {
|
|
|
+
|
|
|
+ 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 list[i].ChartPermissionId != utils.HONG_GUAN_ID && !utils.InArrayByStr(permissionArr, list[i].ChartPermissionName) {
|
|
|
+ au.HasPermission = 2
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if au.HasPermission != 1 {
|
|
|
+ if au.OperationMode == UserPermissionOperationModeCall {
|
|
|
+ if list[i].Type == 1 {
|
|
|
+ au.PopupMsg = UserPermissionPopupMsgCallActivity
|
|
|
+ } else {
|
|
|
+ au.PopupMsg = UserPermissionPopupMsgCallMicroVideo
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if list[i].Type == 1 {
|
|
|
+ au.PopupMsg = UserPermissionPopupMsgApplyActivity
|
|
|
+ } else {
|
|
|
+ au.PopupMsg = UserPermissionPopupMsgApplyMicroVideo
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ list[i].AuthInfo = au
|
|
|
+ list[i].PublishTime = utils.StrTimeToTime(list[i].PublishTime).Format(utils.FormatDate)
|
|
|
+
|
|
|
+ if list[i].BackgroundImg == "" {
|
|
|
+ if list[i].Type == 1 {
|
|
|
+ list[i].BackgroundImg = audioMap[list[i].ChartPermissionId]
|
|
|
+ } else {
|
|
|
+ list[i].BackgroundImg = videoMap[list[i].ChartPermissionId]
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if list[i].ShareImg == "" {
|
|
|
+ if list[i].Type == 1 {
|
|
|
+ list[i].ShareImg = audioShareMap[list[i].ChartPermissionId]
|
|
|
+ } else {
|
|
|
+ list[i].ShareImg = videoShareMap[list[i].ChartPermissionId]
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ for _, item := range list {
|
|
|
+ if item.Type == 1 {
|
|
|
+ mapItems[fmt.Sprint("activityvoice", item.Id)].Activityvoice = item
|
|
|
+ } else if item.Type == 2 {
|
|
|
+ mapItems[fmt.Sprint("activityvideo", item.Id)].Activityvideo = item
|
|
|
+ } else if item.Type == 3 {
|
|
|
+ mapItems[fmt.Sprint("roadshow", item.Id)].Roadshow = item
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ for _, vList := range list {
|
|
|
+ for _, v := range mapItems {
|
|
|
+ if v.SourceId == vList.SourceId {
|
|
|
+ items = append(items, v)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return
|
|
|
+}
|