es_comprehensive.go 56 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678
  1. package services
  2. import (
  3. "context"
  4. "encoding/json"
  5. "fmt"
  6. "github.com/PuerkitoBio/goquery"
  7. "github.com/olivere/elastic/v7"
  8. "strconv"
  9. //"go/doc"
  10. "hongze/hongze_cygx/models"
  11. "hongze/hongze_cygx/utils"
  12. "html"
  13. //"strconv"
  14. "errors"
  15. "strings"
  16. "time"
  17. )
  18. type SearchComprehensiveItem struct {
  19. SourceId int `description:"资源ID"`
  20. IsSummary int `description:"是否是纪要"`
  21. Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial 、 本周研究汇总: researchsummary 、 上周纪要汇总 :minutessummary 、晨会精华 :meetingreviewchapt 、 产品内测:productinterior"`
  22. Title string `description:"标题"`
  23. BodyText string `description:"内容"`
  24. PublishDate string `description:"发布时间"`
  25. Abstract string `description:"摘要"`
  26. Annotation string `description:"核心观点"`
  27. IndustryName string `description:"产业名称"`
  28. SubjectNames string `description:"标的名称"`
  29. Body []string
  30. }
  31. type ElasticComprehensiveDetail struct {
  32. SourceId int `description:"资源ID"`
  33. IsSummary int `description:"是否是纪要"`
  34. Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial 、 本周研究汇总: researchsummary 、 上周纪要汇总 :minutessummary 、晨会精华 :meetingreviewchapt 、 产品内测:productinterior 、 产业资源包:industrialsource"`
  35. Title string `description:"标题"`
  36. BodyText string `description:"内容"`
  37. PublishDate string `description:"发布时间"`
  38. Abstract string `description:"摘要"`
  39. Annotation string `description:"核心观点"`
  40. IndustryName string `description:"产业名称"`
  41. SubjectNames string `description:"标的名称"`
  42. }
  43. //func init() {
  44. // AddComprehensiveIndustrialSource("Hz", 0)
  45. // //AddComprehensiveChart(0)
  46. // // AddComprehensiveMeetingreviewchapt()
  47. //}
  48. // 添加文章:报告、纪要
  49. func AddComprehensiveArticle(articleId int) {
  50. var err error
  51. defer func() {
  52. if err != nil {
  53. fmt.Println(err)
  54. go utils.SendAlarmMsg("删除数据综合页面数据Es失败"+err.Error(), 2)
  55. }
  56. }()
  57. IndustrialManagementRespMap, _ := GetIndustrialManagementRespMap()
  58. IndustrialSubjectMap, _ := GetCygxIndustrialSubjectMap()
  59. var condition1 string
  60. var pars1 []interface{}
  61. mapActivityIndustrialManagement := make(map[int][]string)
  62. industrialgroupList, e := models.GetIndustrialArticleGroupManagementList(condition1, pars1)
  63. if e != nil {
  64. fmt.Println(e)
  65. return
  66. }
  67. for _, v := range industrialgroupList {
  68. if v.ArticleId == 0 {
  69. continue
  70. }
  71. mapActivityIndustrialManagement[v.ArticleId] = append(mapActivityIndustrialManagement[v.ArticleId], IndustrialManagementRespMap[v.IndustrialManagementId])
  72. }
  73. mapActivitySubject := make(map[int][]string)
  74. SubjectgroupList, e := models.GetSubjectArticleGroupManagementList(condition1, pars1)
  75. if e != nil {
  76. fmt.Println(e)
  77. return
  78. }
  79. for _, v := range SubjectgroupList {
  80. if v.ArticleId == 0 {
  81. continue
  82. }
  83. mapActivitySubject[v.ArticleId] = append(mapActivitySubject[v.ArticleId], IndustrialSubjectMap[v.IndustrialSubjectId])
  84. }
  85. var condition string
  86. var pars []interface{}
  87. condition += ` AND publish_status = 1 `
  88. if articleId > 0 {
  89. condition = ` AND article_id = ? `
  90. pars = append(pars, articleId)
  91. }
  92. articleList, e := models.GetArticleList(condition, pars)
  93. if e != nil {
  94. err = errors.New("GetArticleList, Err: " + e.Error())
  95. return
  96. }
  97. //indexName := utils.IndexNameComprehensive
  98. for _, v := range articleList {
  99. time.Sleep(200 * time.Millisecond)
  100. content := html.UnescapeString(v.Body)
  101. doc, err := goquery.NewDocumentFromReader(strings.NewReader(content))
  102. if err != nil {
  103. fmt.Println("create doc err:", err.Error())
  104. return
  105. }
  106. bodyText := doc.Text()
  107. item := new(ElasticComprehensiveDetail)
  108. item.SourceId = v.ArticleId
  109. item.IsSummary = v.IsSummary
  110. item.Source = "article"
  111. item.Title = v.Title
  112. item.PublishDate = v.PublishDate
  113. item.BodyText = bodyText
  114. if v.IsSummary == 0 {
  115. item.SubjectNames = strings.Join(mapActivitySubject[v.ArticleId], ",") + "," + v.FieldName
  116. item.IndustryName = strings.Join(mapActivityIndustrialManagement[v.ArticleId], ",")
  117. }
  118. item.Annotation, _ = GetReportContentTextSubNew(v.Annotation)
  119. item.Abstract, _ = GetReportContentTextSubNew(v.Abstract)
  120. EsAddOrEditComprehensiveData(item)
  121. fmt.Println(item.IndustryName)
  122. fmt.Println(item.SubjectNames)
  123. }
  124. }
  125. // 添加图表
  126. func AddComprehensiveChart(chartId int) {
  127. var err error
  128. defer func() {
  129. if err != nil {
  130. fmt.Println(err)
  131. go utils.SendAlarmMsg("AddComprehensiveChart Err"+err.Error()+fmt.Sprint(chartId), 2)
  132. }
  133. }()
  134. var condition string
  135. var pars []interface{}
  136. condition += ` AND publish_status = 1 `
  137. if chartId > 0 {
  138. condition = ` AND chart_id = ? `
  139. pars = append(pars, chartId)
  140. }
  141. list, e := models.GetChartList(condition, pars, 0, 1000000)
  142. if e != nil {
  143. err = errors.New("GetChartList, Err: " + e.Error())
  144. return
  145. }
  146. //indexName := utils.IndexNameComprehensive
  147. for _, v := range list {
  148. time.Sleep(200 * time.Millisecond)
  149. item := new(ElasticComprehensiveDetail)
  150. item.SourceId = v.ChartId
  151. item.Source = "newchart"
  152. item.Title = v.Title
  153. item.PublishDate = v.CreateDate
  154. EsAddOrEditComprehensiveData(item)
  155. fmt.Println(v.ChartId)
  156. }
  157. }
  158. //func init() {
  159. // AddComprehensiveIndustrialSource("Hz", 9433)
  160. //}
  161. // 添加产业资源包
  162. func AddComprehensiveIndustrialSource(sourceType string, articleId int) {
  163. var err error
  164. defer func() {
  165. if err != nil {
  166. fmt.Println(err)
  167. go utils.SendAlarmMsg("AddComprehensiveIndustrialSource"+err.Error(), 2)
  168. }
  169. }()
  170. var condition string
  171. var pars []interface{}
  172. mapActivitySubject := make(map[int][]string, 0)
  173. maplistMeetingTime := make(map[int]time.Time, 0)
  174. listMeeting, err := models.GetCygxMorningMeetingReviewChapterList(" GROUP BY c.industry_id ORDER BY r.publish_time DESC ", pars)
  175. for _, v := range listMeeting {
  176. resultTime := utils.StrTimeToTime(v.PublishTime)
  177. maplistMeetingTime[v.IndustryId] = resultTime
  178. }
  179. listsubject, e := models.GetCygxIndustrialSubjectListCondition(condition, pars)
  180. if e != nil {
  181. err = errors.New("GetIndustrialManagementRepList, Err: " + e.Error())
  182. return
  183. }
  184. for _, v := range listsubject {
  185. mapActivitySubject[v.IndustrialManagementId] = append(mapActivitySubject[v.IndustrialManagementId], v.SubjectName)
  186. }
  187. var industrialsource string
  188. if sourceType == "Hz" {
  189. condition = " AND a.article_type_id = 0 " // 弘则资源包
  190. industrialsource = "industrialsourceHz"
  191. } else {
  192. condition = " AND a.article_type_id > 0 " //研选资源包
  193. industrialsource = "industrialsourceYx"
  194. }
  195. if articleId > 0 {
  196. condition += " AND a.article_id = " + strconv.Itoa(articleId)
  197. }
  198. list, err := models.GetSearchResourceList(0, condition, 0, 0)
  199. if err != nil {
  200. fmt.Println(err)
  201. return
  202. }
  203. //indexName := utils.IndexNameComprehensive
  204. for _, v := range list {
  205. //time.Sleep(200 * time.Millisecond)
  206. item := new(ElasticComprehensiveDetail)
  207. item.SourceId = v.IndustrialManagementId
  208. item.Source = industrialsource
  209. item.IndustryName = v.IndustryName
  210. item.SubjectNames = strings.Join(mapActivitySubject[v.IndustrialManagementId], ",")
  211. item.PublishDate = v.PublishDate + " 00:00:00"
  212. if sourceType == "Hz" {
  213. //如果时间晚就进行替换
  214. resultTime := utils.StrTimeToTime(item.PublishDate)
  215. if maplistMeetingTime[v.IndustrialManagementId].After(resultTime) {
  216. item.PublishDate = maplistMeetingTime[v.IndustrialManagementId].Format(utils.FormatDateTime)
  217. }
  218. }
  219. fmt.Println(item)
  220. EsAddOrEditComprehensiveData(item)
  221. UpdateComprehensiveIndustrialResourceData(item)
  222. }
  223. }
  224. // 添加晨会精华
  225. func AddComprehensiveMeetingreviewchaptOld() {
  226. var condition string
  227. var pars []interface{}
  228. IndustrialManagementRespMap, _ := GetIndustrialManagementRespMap()
  229. list, err := models.GetCygxMorningMeetingReviewChapterList(condition, pars)
  230. if err != nil {
  231. fmt.Println(err)
  232. return
  233. }
  234. //indexName := utils.IndexNameComprehensive
  235. for _, v := range list {
  236. time.Sleep(200 * time.Millisecond)
  237. content := html.UnescapeString(v.Content)
  238. doc, err := goquery.NewDocumentFromReader(strings.NewReader(content))
  239. if err != nil {
  240. fmt.Println("create doc err:", err.Error())
  241. return
  242. }
  243. bodyText := doc.Text()
  244. item := new(ElasticComprehensiveDetail)
  245. item.SourceId = v.Id
  246. item.Source = "meetingreviewchapt"
  247. item.IndustryName = IndustrialManagementRespMap[v.IndustryId]
  248. item.PublishDate = v.PublishTime
  249. item.Abstract = bodyText
  250. EsAddOrEditComprehensiveData(item)
  251. fmt.Println(item)
  252. }
  253. }
  254. func AddComprehensiveMeetingreviewchapt(sourceId int) {
  255. time.Sleep(3 * time.Second) // 延迟三秒处理
  256. var err error
  257. defer func() {
  258. if err != nil {
  259. fmt.Println("err:", err)
  260. go utils.SendAlarmMsg("AddComprehensiveMeetingreviewchapt,Err:"+err.Error(), 3)
  261. }
  262. }()
  263. v, e := models.GetCygxMorningMeetingReviewChapterDetail(sourceId)
  264. if e != nil {
  265. err = errors.New("GetCygxMorningMeetingReviewChapterDetail" + e.Error())
  266. return
  267. }
  268. content := html.UnescapeString(v.Content)
  269. doc, e := goquery.NewDocumentFromReader(strings.NewReader(content))
  270. if e != nil {
  271. err = errors.New("goquery.NewDocumentFromReader" + e.Error())
  272. return
  273. }
  274. bodyText := doc.Text()
  275. item := new(ElasticComprehensiveDetail)
  276. item.SourceId = sourceId
  277. item.Source = utils.CYGX_OBJ_MEETINGREVIEWCHAPT
  278. item.IndustryName = v.IndustryName
  279. item.PublishDate = v.MeetingTime.Format(utils.FormatDateTime)
  280. item.Abstract = bodyText
  281. EsAddOrEditComprehensiveData(item) //如果发布了就新增
  282. return
  283. }
  284. // 添加活动
  285. func AddComprehensiveActivity() {
  286. var condition string
  287. var pars []interface{}
  288. condition = ` AND publish_status = 1 `
  289. //condition = ` AND publish_status = 1 AND activity_id = 2407 `
  290. list, err := models.GetCygxActivityList(condition, pars, 0, 100000)
  291. if err != nil {
  292. fmt.Println(err)
  293. return
  294. }
  295. IndustrialManagementRespMap, _ := GetIndustrialManagementRespMap()
  296. IndustrialSubjectMap, _ := GetCygxIndustrialSubjectMap()
  297. var condition1 string
  298. var pars1 []interface{}
  299. mapActivityIndustrialManagement := make(map[int][]string)
  300. industrialgroupList, e := models.GetCygxIndustrialActivityGroupManagementList(condition1+" AND source = 1 ", pars1)
  301. if e != nil {
  302. fmt.Println(e)
  303. return
  304. }
  305. for _, v := range industrialgroupList {
  306. if v.ActivityId == 0 {
  307. continue
  308. }
  309. mapActivityIndustrialManagement[v.ActivityId] = append(mapActivityIndustrialManagement[v.ActivityId], IndustrialManagementRespMap[v.IndustrialManagementId])
  310. }
  311. mapActivitySubject := make(map[int][]string)
  312. SubjectgroupList, e := models.GetCygxIndustrialActivityGroupSubjectList(condition1+" AND source = 1 ", pars1)
  313. if e != nil {
  314. fmt.Println(e)
  315. return
  316. }
  317. for _, v := range SubjectgroupList {
  318. if v.ActivityId == 0 {
  319. continue
  320. }
  321. mapActivitySubject[v.ActivityId] = append(mapActivitySubject[v.ActivityId], IndustrialSubjectMap[v.IndustrialSubjectId])
  322. }
  323. //return
  324. for _, v := range list {
  325. time.Sleep(200 * time.Millisecond)
  326. item := new(ElasticComprehensiveDetail)
  327. item.SourceId = v.ActivityId
  328. //item.IsSummary = v.IsSummary
  329. item.Source = "activity"
  330. //item.SubjectNames = json.Sprint(mapActivitySubject[v.ActivityId])
  331. item.SubjectNames = strings.Join(mapActivitySubject[v.ActivityId], ",")
  332. item.IndustryName = strings.Join(mapActivityIndustrialManagement[v.ActivityId], ",")
  333. item.Title = v.ActivityName
  334. item.PublishDate = v.ActivityTime
  335. //item.BodyText = bodyText
  336. //item.Annotation, _ = GetReportContentTextSubNew(v.Annotation)
  337. //item.Abstract, _ = GetReportContentTextSubNew(v.Abstract)
  338. //EsAddOrEditComprehensiveData(indexName, item)
  339. EsAddOrEditComprehensiveData(item)
  340. fmt.Println(item)
  341. }
  342. }
  343. // 添加专项调研活动
  344. func AddComprehensiveActivitySpecial() {
  345. var condition string
  346. var pars []interface{}
  347. condition = ` AND publish_status = 1 `
  348. list, err := models.GetActivitySpecialListAll(condition, pars, 0, 100000)
  349. if err != nil {
  350. fmt.Println(err)
  351. return
  352. }
  353. //indexName := utils.IndexNameComprehensive
  354. IndustrialManagementRespMap, _ := GetIndustrialManagementRespMap() // 产业标签
  355. IndustrialSubjectMap, _ := GetCygxIndustrialSubjectMap() // 标的标签
  356. var condition1 string
  357. var pars1 []interface{}
  358. mapActivityIndustrialManagement := make(map[int][]string)
  359. industrialgroupList, e := models.GetCygxIndustrialActivityGroupManagementList(condition1+" AND source = 2 ", pars1)
  360. if e != nil {
  361. fmt.Println(e)
  362. return
  363. }
  364. for _, v := range industrialgroupList {
  365. if v.ActivityId == 0 {
  366. continue
  367. }
  368. mapActivityIndustrialManagement[v.ActivityId] = append(mapActivityIndustrialManagement[v.ActivityId], IndustrialManagementRespMap[v.IndustrialManagementId])
  369. }
  370. mapActivitySubject := make(map[int][]string)
  371. SubjectgroupList, e := models.GetCygxIndustrialActivityGroupSubjectList(condition1+" AND source = 2 ", pars1)
  372. if e != nil {
  373. fmt.Println(e)
  374. return
  375. }
  376. for _, v := range SubjectgroupList {
  377. if v.ActivityId == 0 {
  378. continue
  379. }
  380. mapActivitySubject[v.ActivityId] = append(mapActivitySubject[v.ActivityId], IndustrialSubjectMap[v.IndustrialSubjectId])
  381. }
  382. for _, v := range list {
  383. time.Sleep(200 * time.Millisecond)
  384. item := new(ElasticComprehensiveDetail)
  385. item.SourceId = v.ActivityId
  386. item.Source = "activityspecial"
  387. item.Title = v.ResearchTheme
  388. item.PublishDate = v.ActivityTime
  389. if v.ActivityTime == utils.FormatDateTimeInit {
  390. item.PublishDate = v.LastUpdatedTime.Format(utils.FormatDateTime)
  391. } else {
  392. item.PublishDate = v.ActivityTime
  393. }
  394. item.SubjectNames = strings.Join(mapActivitySubject[v.ActivityId], ",")
  395. item.IndustryName = strings.Join(mapActivityIndustrialManagement[v.ActivityId], ",")
  396. EsAddOrEditComprehensiveData(item)
  397. }
  398. }
  399. // 添加活动视频
  400. func AddComprehensiveActivityVideo() {
  401. var err error
  402. defer func() {
  403. if err != nil {
  404. fmt.Println(err)
  405. go utils.SendAlarmMsg("添加活动视频综合页面数据Es失败"+err.Error(), 2)
  406. }
  407. }()
  408. var condition string
  409. var pars []interface{}
  410. list, e := models.GetActivityVideoListAll(condition, pars, 0, 100000)
  411. if e != nil {
  412. err = errors.New("GetActivityVideoListAll, Err: " + e.Error())
  413. return
  414. }
  415. if len(list) == 0 {
  416. return
  417. }
  418. var activityIds []int
  419. for _, v := range list {
  420. activityIds = append(activityIds, v.ActivityId)
  421. }
  422. pars = make([]interface{}, 0)
  423. condition = ` AND publish_status = 1 AND art.activity_id IN (` + utils.GetOrmInReplace(len(activityIds)) + `)`
  424. pars = append(pars, activityIds)
  425. listArt, e := models.GetCygxActivityList(condition, pars, 0, 100000)
  426. if e != nil {
  427. err = errors.New("GetCygxActivityList, Err: " + e.Error())
  428. return
  429. }
  430. mapActivity := make(map[int]string)
  431. for _, v := range listArt {
  432. mapActivity[v.ActivityId] = v.ActivityName
  433. }
  434. IndustrialManagementRespMap, _ := GetIndustrialManagementRespMap()
  435. IndustrialSubjectMap, _ := GetCygxIndustrialSubjectMap()
  436. var condition1 string
  437. var pars1 []interface{}
  438. mapActivityIndustrialManagement := make(map[int][]string)
  439. industrialgroupList, e := models.GetCygxIndustrialActivityGroupManagementList(condition1+" AND source = 1 ", pars1)
  440. if e != nil {
  441. fmt.Println(e)
  442. return
  443. }
  444. //产业名称
  445. for _, v := range industrialgroupList {
  446. if v.ActivityId == 0 {
  447. continue
  448. }
  449. mapActivityIndustrialManagement[v.ActivityId] = append(mapActivityIndustrialManagement[v.ActivityId], IndustrialManagementRespMap[v.IndustrialManagementId])
  450. }
  451. //标的名称
  452. mapActivitySubject := make(map[int][]string)
  453. SubjectgroupList, e := models.GetCygxIndustrialActivityGroupSubjectList(condition1+" AND source = 1 ", pars1)
  454. if e != nil {
  455. fmt.Println(e)
  456. return
  457. }
  458. for _, v := range SubjectgroupList {
  459. if v.ActivityId == 0 {
  460. continue
  461. }
  462. mapActivitySubject[v.ActivityId] = append(mapActivitySubject[v.ActivityId], IndustrialSubjectMap[v.IndustrialSubjectId])
  463. }
  464. //indexName := utils.IndexNameComprehensive
  465. for _, v := range list {
  466. time.Sleep(200 * time.Millisecond)
  467. item := new(ElasticComprehensiveDetail)
  468. item.SourceId = v.Id
  469. item.Source = "activityvideo"
  470. item.Title = v.Title
  471. item.PublishDate = v.ActivityTime
  472. item.BodyText = mapActivity[v.ActivityId]
  473. item.SubjectNames = strings.Join(mapActivitySubject[v.ActivityId], ",")
  474. item.IndustryName = strings.Join(mapActivityIndustrialManagement[v.ActivityId], ",")
  475. EsAddOrEditComprehensiveData(item)
  476. fmt.Println(item)
  477. }
  478. }
  479. // 添加活动音频
  480. func AddComprehensiveActivityVoice() {
  481. var err error
  482. defer func() {
  483. if err != nil {
  484. fmt.Println(err)
  485. go utils.SendAlarmMsg("AddComprehensiveActivityVoice"+err.Error(), 2)
  486. }
  487. }()
  488. var condition string
  489. var pars []interface{}
  490. list, err := models.GetActivityVoiceList(condition, pars, 0, 100000)
  491. if err != nil {
  492. fmt.Println(err)
  493. return
  494. }
  495. if len(list) == 0 {
  496. return
  497. }
  498. var activityIds []int
  499. for _, v := range list {
  500. activityIds = append(activityIds, v.ActivityId)
  501. }
  502. pars = make([]interface{}, 0)
  503. condition = ` AND publish_status = 1 AND art.activity_id IN (` + utils.GetOrmInReplace(len(activityIds)) + `)`
  504. pars = append(pars, activityIds)
  505. listArt, e := models.GetCygxActivityList(condition, pars, 0, 100000)
  506. if e != nil {
  507. err = errors.New("GetCygxActivityList, Err: " + e.Error())
  508. return
  509. }
  510. mapActivity := make(map[int]string)
  511. for _, v := range listArt {
  512. mapActivity[v.ActivityId] = v.ActivityName
  513. }
  514. IndustrialManagementRespMap, _ := GetIndustrialManagementRespMap()
  515. IndustrialSubjectMap, _ := GetCygxIndustrialSubjectMap()
  516. var condition1 string
  517. var pars1 []interface{}
  518. mapActivityIndustrialManagement := make(map[int][]string)
  519. industrialgroupList, e := models.GetCygxIndustrialActivityGroupManagementList(condition1+" AND source = 1 ", pars1)
  520. if e != nil {
  521. fmt.Println(e)
  522. return
  523. }
  524. //产业名称
  525. for _, v := range industrialgroupList {
  526. if v.ActivityId == 0 {
  527. continue
  528. }
  529. mapActivityIndustrialManagement[v.ActivityId] = append(mapActivityIndustrialManagement[v.ActivityId], IndustrialManagementRespMap[v.IndustrialManagementId])
  530. }
  531. //标的名称
  532. mapActivitySubject := make(map[int][]string)
  533. SubjectgroupList, e := models.GetCygxIndustrialActivityGroupSubjectList(condition1+" AND source = 1 ", pars1)
  534. if e != nil {
  535. fmt.Println(e)
  536. return
  537. }
  538. for _, v := range SubjectgroupList {
  539. if v.ActivityId == 0 {
  540. continue
  541. }
  542. mapActivitySubject[v.ActivityId] = append(mapActivitySubject[v.ActivityId], IndustrialSubjectMap[v.IndustrialSubjectId])
  543. }
  544. //indexName := utils.IndexNameComprehensive
  545. for _, v := range list {
  546. time.Sleep(200 * time.Millisecond)
  547. item := new(ElasticComprehensiveDetail)
  548. item.SourceId = v.ActivityVoiceId
  549. item.Source = "activityvoice"
  550. item.Title = v.VoiceName
  551. item.PublishDate = v.ActivityTime
  552. item.BodyText = mapActivity[v.ActivityId]
  553. item.SubjectNames = strings.Join(mapActivitySubject[v.ActivityId], ",")
  554. item.IndustryName = strings.Join(mapActivityIndustrialManagement[v.ActivityId], ",")
  555. EsAddOrEditComprehensiveData(item)
  556. fmt.Println(item)
  557. }
  558. }
  559. // 微路演
  560. func AddComprehensiveRoadshow() {
  561. var condition string
  562. var pars []interface{}
  563. IndustrialManagementRespMap, _ := GetIndustrialManagementRespMap()
  564. list, err := models.GetMicroRoadshowVideoListBycondition(condition, pars, 0, 100000)
  565. if err != nil {
  566. fmt.Println(err)
  567. return
  568. }
  569. //indexName := utils.IndexNameComprehensive
  570. for _, v := range list {
  571. time.Sleep(200 * time.Millisecond)
  572. item := new(ElasticComprehensiveDetail)
  573. item.SourceId = v.VideoId
  574. item.Source = "roadshow"
  575. item.IndustryName = IndustrialManagementRespMap[v.IndustryId]
  576. item.Title = v.VideoName
  577. item.PublishDate = v.PublishDate.Format(utils.FormatDateTime)
  578. EsAddOrEditComprehensiveData(item)
  579. fmt.Println(item)
  580. }
  581. }
  582. // Es研选专栏
  583. func EsAddYanxuanSpecial(sourceId int) {
  584. var err error
  585. defer func() {
  586. if err != nil {
  587. fmt.Println("err:", err)
  588. go utils.SendAlarmMsg(fmt.Sprint("更新研选专栏失败sourceId: ", sourceId), 2)
  589. }
  590. }()
  591. detail, e := models.GetYanxuanSpecialItemById(sourceId)
  592. if e != nil {
  593. err = errors.New("GetArticleInfoOtherByArticleId" + e.Error())
  594. return
  595. }
  596. content := html.UnescapeString(detail.Content)
  597. doc, e := goquery.NewDocumentFromReader(strings.NewReader(content))
  598. if e != nil {
  599. err = errors.New("goquery.NewDocumentFromReader" + e.Error())
  600. return
  601. }
  602. bodyText := doc.Text()
  603. item := new(ElasticComprehensiveDetail)
  604. item.SourceId = detail.Id
  605. item.Source = utils.CYGX_OBJ_YANXUANSPECIAL
  606. item.Title = detail.Title
  607. item.PublishDate = detail.PublishTime
  608. item.BodyText = bodyText
  609. item.Abstract = bodyText
  610. item.IndustryName = detail.IndustryTags
  611. item.SubjectNames = detail.CompanyTags + detail.Tags
  612. if detail.Status == 3 {
  613. EsAddOrEditComprehensiveData(item) //如果发布了就新增
  614. } else {
  615. EsDeleteComprehensiveData(item) // 没有发布就删除
  616. }
  617. return
  618. }
  619. // 新增和修改数据
  620. func EsAddOrEditComprehensiveData(item *ElasticComprehensiveDetail) (err error) {
  621. indexName := utils.IndexNameComprehensive
  622. //return
  623. defer func() {
  624. if err != nil {
  625. fmt.Println(err, item.SourceId)
  626. //go utils.SendAlarmMsg("更新综合页面数据Es失败"+err.Error()+fmt.Sprint(item), 2)
  627. }
  628. }()
  629. client := utils.Client
  630. mustMap := make([]interface{}, 0)
  631. mustMap = append(mustMap, map[string]interface{}{
  632. "term": map[string]interface{}{
  633. "SourceId": item.SourceId,
  634. },
  635. })
  636. mustMap = append(mustMap, map[string]interface{}{
  637. "term": map[string]interface{}{
  638. "Source": item.Source,
  639. },
  640. })
  641. queryMap := map[string]interface{}{
  642. "query": map[string]interface{}{
  643. "bool": map[string]interface{}{
  644. "must": mustMap,
  645. },
  646. },
  647. }
  648. requestTotalHits := client.Count(indexName).BodyJson(queryMap)
  649. total, e := requestTotalHits.Do(context.Background())
  650. if e != nil {
  651. err = errors.New("requestTotalHits.Do(context.Background()), Err: " + e.Error())
  652. return
  653. }
  654. //return
  655. //根据来源以及ID ,判断内容是否存在,如果存在就新增,如果不存在就修改
  656. if total == 0 {
  657. resp, e := client.Index().Index(indexName).BodyJson(item).Do(context.Background())
  658. if e != nil {
  659. err = errors.New("client.Index().Index(indexName).BodyJson(item).Do(context.Background()), Err: " + e.Error())
  660. return
  661. }
  662. if resp.Status == 0 && resp.Result == "created" {
  663. //fmt.Println("新增成功")
  664. //err = nil
  665. return
  666. } else {
  667. //err = errors.New(fmt.Sprint(resp))
  668. err = errors.New(fmt.Sprint("articleId", item.SourceId))
  669. return
  670. }
  671. } else {
  672. //拼接需要改动的前置条件
  673. bool_query := elastic.NewBoolQuery()
  674. bool_query.Must(elastic.NewTermQuery("SourceId", item.SourceId))
  675. bool_query.Must(elastic.NewTermQuery("Source", item.Source))
  676. //设置需要改动的内容
  677. var script string
  678. script += fmt.Sprint("ctx._source['SubjectNames'] = '", item.SubjectNames, "';")
  679. script += fmt.Sprint("ctx._source['PublishDate'] = '", item.PublishDate, "';")
  680. script += fmt.Sprint("ctx._source['IsSummary'] = ", item.IsSummary, ";")
  681. script += fmt.Sprint("ctx._source['Abstract'] = '", item.Abstract, "';")
  682. script += fmt.Sprint("ctx._source['Title'] = '", item.Title, "';")
  683. script += fmt.Sprint("ctx._source['BodyText'] = '", item.BodyText, "';")
  684. script += fmt.Sprint("ctx._source['Annotation'] = '", item.Annotation, "';")
  685. script += fmt.Sprint("ctx._source['IndustryName'] = '", item.IndustryName, "'")
  686. _, e = client.UpdateByQuery(indexName).
  687. Query(bool_query).
  688. Script(elastic.NewScriptInline(script)).
  689. Refresh("true").
  690. Do(context.Background())
  691. if e != nil && e.Error() != "elastic: Error 400 (Bad Request): compile error [type=script_exception]" {
  692. //文本内容过长的时候,修改会报 400 的错误,暂时先不处理
  693. //fmt.Println("err", e.Error())
  694. ////err = e
  695. //err = errors.New("client.UpdateByQuery(indexName), Err: " + e.Error())
  696. return
  697. }
  698. }
  699. return
  700. }
  701. // 删除数据
  702. func EsDeleteComprehensiveData(item *ElasticComprehensiveDetail) (err error) {
  703. defer func() {
  704. if err != nil {
  705. fmt.Println(err)
  706. go utils.SendAlarmMsg("删除数据综合页面数据Es失败"+err.Error()+fmt.Sprint(item), 2)
  707. }
  708. }()
  709. indexName := utils.IndexNameComprehensive
  710. client := utils.Client
  711. //拼接需要删除的前置条件
  712. bool_query := elastic.NewBoolQuery()
  713. bool_query.Must(elastic.NewTermQuery("SourceId", item.SourceId))
  714. bool_query.Must(elastic.NewTermQuery("Source", item.Source))
  715. _, e := client.DeleteByQuery(indexName).
  716. Query(bool_query).
  717. Do(context.Background())
  718. if e != nil {
  719. err = errors.New(" client.DeleteByQuery(indexName), Err: " + e.Error())
  720. return
  721. }
  722. return
  723. }
  724. func EsComprehensiveSearch(keyWord string, startSize, pageSize int) (result []*SearchComprehensiveItem, total int64, err error) {
  725. indexName := utils.IndexNameComprehensive
  726. client := utils.Client
  727. keyWordArr, err := GetIndustryMapNameSliceV3(keyWord)
  728. keyWordArr = RemoveDuplicatesAndEmpty(keyWordArr)
  729. keyWordLen := len(keyWordArr)
  730. if keyWordLen <= 0 {
  731. keyWordArr = append(keyWordArr, keyWord)
  732. keyWordLen = len(keyWordArr)
  733. }
  734. //Es 的高级查询有 自定义排序 文档一时半会儿撸不懂,先做多次查询手动过滤 2023.2.2
  735. //ikType 查询方式 ,0:查所有 、 1:查询键入词 、 2:查询除了查询键入词之外的联想词
  736. mustMap := make([]interface{}, 0)
  737. shouldMap := make(map[string]interface{}, 0)
  738. shouldMapquery := make([]interface{}, 0)
  739. mustNotMap := make([]interface{}, 0)
  740. shouldNotMap := make(map[string]interface{}, 0)
  741. shouldNotMapquery := make([]interface{}, 0)
  742. // @Param OrderColumn query int true "排序字段 ,Comprehensive综合 ,Matching匹配度 ,PublishDate 发布时间 "
  743. //keyWordWeight := GetWeight(keyWordLen)
  744. var boost int
  745. //lenkeyWordArr := len(keyWordArr)
  746. for k, v := range keyWordArr {
  747. if k > 0 {
  748. continue
  749. }
  750. if k == 0 {
  751. boost = 2 * 1000
  752. } else {
  753. boost = 1
  754. }
  755. if v != "" {
  756. shouldMapquery = append(shouldMapquery, map[string]interface{}{
  757. "function_score": map[string]interface{}{
  758. "query": map[string]interface{}{
  759. "multi_match": map[string]interface{}{
  760. //"boost": (lenkeyWordArr - k) * boost, //给查询的值赋予权重
  761. "boost": boost, //给查询的值赋予权重
  762. "fields": []interface{}{"Title"},
  763. "query": v,
  764. },
  765. },
  766. },
  767. })
  768. shouldMapquery = append(shouldMapquery, map[string]interface{}{
  769. "function_score": map[string]interface{}{
  770. "query": map[string]interface{}{
  771. "multi_match": map[string]interface{}{
  772. "boost": boost, //给查询的值赋予权重
  773. "fields": []interface{}{"Abstract"},
  774. "query": v,
  775. },
  776. },
  777. },
  778. })
  779. shouldMapquery = append(shouldMapquery, map[string]interface{}{
  780. "function_score": map[string]interface{}{
  781. "query": map[string]interface{}{
  782. "multi_match": map[string]interface{}{
  783. "boost": boost, //给查询的值赋予权重
  784. "fields": []interface{}{"Annotation"},
  785. "query": v,
  786. },
  787. },
  788. },
  789. })
  790. //shouldMapquery = append(shouldMapquery, map[string]interface{}{
  791. // "function_score": map[string]interface{}{
  792. // "query": map[string]interface{}{
  793. // "multi_match": map[string]interface{}{
  794. // //"boost": (lenkeyWordArr-k)*boost - 1, //给查询的值赋予权重
  795. // "boost": boost, //给查询的值赋予权重
  796. // "fields": []interface{}{"BodyText"},
  797. // "query": v,
  798. // },
  799. // },
  800. // },
  801. //})
  802. shouldMapquery = append(shouldMapquery, map[string]interface{}{
  803. "function_score": map[string]interface{}{
  804. "query": map[string]interface{}{
  805. "multi_match": map[string]interface{}{
  806. //"boost": (lenkeyWordArr-k)*boost - 1, //给查询的值赋予权重
  807. "boost": boost, //给查询的值赋予权重
  808. "fields": []interface{}{"IndustryName"},
  809. "query": v,
  810. },
  811. },
  812. },
  813. })
  814. shouldMapquery = append(shouldMapquery, map[string]interface{}{
  815. "function_score": map[string]interface{}{
  816. "query": map[string]interface{}{
  817. "multi_match": map[string]interface{}{
  818. //"boost": (lenkeyWordArr-k)*boost - 1, //给查询的值赋予权重
  819. "boost": boost, //给查询的值赋予权重
  820. "fields": []interface{}{"SubjectNames"},
  821. "query": v,
  822. },
  823. },
  824. },
  825. })
  826. }
  827. }
  828. shouldMap = map[string]interface{}{
  829. "should": shouldMapquery,
  830. }
  831. shouldNotMap = map[string]interface{}{
  832. "should": shouldNotMapquery,
  833. }
  834. //排序
  835. sortMap := make([]interface{}, 0)
  836. //时间
  837. sortMap = append(sortMap, map[string]interface{}{
  838. "PublishDate": map[string]interface{}{
  839. "order": "desc",
  840. },
  841. })
  842. //sortMap = append(sortMap, map[string]interface{}{
  843. // "_score": map[string]interface{}{
  844. // "order": "desc",
  845. // },
  846. //})
  847. //高亮
  848. highlightMap := make(map[string]interface{}, 0)
  849. highlightMap = map[string]interface{}{
  850. "fields": map[string]interface{}{
  851. //"BodyText": map[string]interface{}{},
  852. "Title": map[string]interface{}{},
  853. "Abstract": map[string]interface{}{},
  854. "Annotation": map[string]interface{}{},
  855. },
  856. //样式 红色
  857. "post_tags": []interface{}{"</font>"},
  858. "pre_tags": []interface{}{"<font color='red'>"},
  859. "fragment_size": 50,
  860. }
  861. mustMap = append(mustMap, map[string]interface{}{
  862. "bool": shouldMap,
  863. })
  864. mustNotMap = append(mustNotMap, map[string]interface{}{
  865. "bool": shouldNotMap,
  866. })
  867. queryMap := map[string]interface{}{
  868. "query": map[string]interface{}{
  869. "bool": map[string]interface{}{
  870. "must": mustMap,
  871. },
  872. },
  873. }
  874. queryMap["sort"] = sortMap
  875. queryMap["from"] = startSize
  876. queryMap["size"] = pageSize
  877. queryMap["highlight"] = highlightMap
  878. //jsonBytes, _ := json.Marshal(queryMap)
  879. //fmt.Println(string(jsonBytes))
  880. //utils.FileLog.Info(string(jsonBytes))
  881. request := client.Search(indexName).Source(queryMap) // sets the JSON request
  882. searchByMatch, err := request.Do(context.Background())
  883. if searchByMatch != nil {
  884. if searchByMatch.Hits != nil {
  885. for _, v := range searchByMatch.Hits.Hits {
  886. var isAppend bool
  887. articleJson, err := v.Source.MarshalJSON()
  888. if err != nil {
  889. return nil, 0, err
  890. }
  891. article := new(ElasticComprehensiveDetail)
  892. err = json.Unmarshal(articleJson, &article)
  893. if err != nil {
  894. return nil, 0, err
  895. }
  896. //fmt.Println(article.SourceId, article.Title, article.Source)
  897. searchItem := new(SearchComprehensiveItem)
  898. searchItem.SourceId = article.SourceId
  899. if len(v.Highlight["Annotation"]) > 0 {
  900. for _, vText := range v.Highlight["Annotation"] {
  901. searchItem.Body = append(searchItem.Body, vText)
  902. }
  903. }
  904. if len(v.Highlight["Abstract"]) > 0 {
  905. for _, vText := range v.Highlight["Abstract"] {
  906. searchItem.Body = append(searchItem.Body, vText)
  907. }
  908. }
  909. if len(v.Highlight["BodyText"]) > 0 {
  910. for _, vText := range v.Highlight["BodyText"] {
  911. searchItem.Body = append(searchItem.Body, vText)
  912. }
  913. }
  914. //searchItem.IsSummary = article.IsSummary
  915. //if len(searchItem.Body) == 0 {
  916. // bodyRune := []rune(article.BodyText)
  917. // bodyRuneLen := len(bodyRune)
  918. // if bodyRuneLen > 100 {
  919. // bodyRuneLen = 100
  920. // }
  921. // body := string(bodyRune[:bodyRuneLen])
  922. // searchItem.Body = []string{body}
  923. //}
  924. var title string
  925. if len(v.Highlight["Title"]) > 0 {
  926. title = v.Highlight["Title"][0]
  927. } else {
  928. title = article.Title
  929. }
  930. searchItem.Title = title
  931. searchItem.Source = article.Source
  932. searchItem.PublishDate = article.PublishDate
  933. if !isAppend {
  934. result = append(result, searchItem)
  935. }
  936. }
  937. }
  938. total = searchByMatch.Hits.TotalHits.Value
  939. }
  940. return
  941. }
  942. func GetResourceDataEsList(list []*SearchComprehensiveItem, user *models.WxUserItem) (items []*models.CygxResourceDataResp, err error) {
  943. var condition string
  944. var pars []interface{}
  945. uid := user.UserId
  946. titleHighlight := make(map[int]string)
  947. bodyHighlight := make(map[int][]string)
  948. yanXuanbodyHighlight := make(map[int][]string)
  949. //var bodyHighlight []string
  950. mapItems := make(map[string]*models.CygxResourceDataResp)
  951. for _, v := range list {
  952. //预处理文章
  953. item := new(models.CygxResourceDataResp)
  954. item.SourceId = v.SourceId
  955. item.Source = v.Source
  956. //if v.IsSummary == 1 {
  957. item.BodyHighlight = v.Body
  958. titleHighlight[v.SourceId] = v.Title
  959. bodyHighlight[v.SourceId] = v.Body
  960. //fmt.Println(v.Title)
  961. //} else {
  962. // item.BodyHighlight = make([]string, 0)
  963. //}
  964. item.PublishDate = utils.TimeRemoveHms2(v.PublishDate)
  965. mapItems[fmt.Sprint(v.Source, v.SourceId)] = item
  966. }
  967. var articleIds []int
  968. var newchartIds []int
  969. var roadshowIds []string
  970. var activityIds []int
  971. var activityvideoIds []string
  972. var activityvoiceIds []string
  973. var activityspecialIds []int
  974. var researchsummaryIds []int
  975. var minutessummaryIds []int
  976. var meetingreviewchaptIds []int
  977. var productinteriorIds []int
  978. var industrialResourceIdsHz []int // 弘则产业资源包
  979. var industrialResourceIdsYx []int // 研选产业资源包
  980. var yanxuanSpecialIds []int // 研选专栏
  981. var askserieVideoIds []string //问答系列视频
  982. var reportselectionIds []int //报告精选
  983. var ficcreporrtIds []string //FICC研报
  984. //Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial 、 本周研究汇总: researchsummary 、 上周纪要汇总 :minutessummary 、晨会精华 :meetingreviewchapt "`
  985. for _, v := range list {
  986. if v.Source == "article" {
  987. articleIds = append(articleIds, v.SourceId)
  988. } else if v.Source == "newchart" {
  989. newchartIds = append(newchartIds, v.SourceId)
  990. } else if v.Source == "roadshow" {
  991. roadshowIds = append(roadshowIds, strconv.Itoa(v.SourceId))
  992. } else if v.Source == "activity" {
  993. activityIds = append(activityIds, v.SourceId)
  994. } else if v.Source == "activityvideo" {
  995. activityvideoIds = append(activityvideoIds, strconv.Itoa(v.SourceId))
  996. } else if v.Source == "activityvoice" {
  997. activityvoiceIds = append(activityvoiceIds, strconv.Itoa(v.SourceId))
  998. } else if v.Source == "activityspecial" {
  999. activityspecialIds = append(activityspecialIds, v.SourceId)
  1000. } else if v.Source == "researchsummary" {
  1001. researchsummaryIds = append(researchsummaryIds, v.SourceId)
  1002. } else if v.Source == "minutessummary" {
  1003. minutessummaryIds = append(minutessummaryIds, v.SourceId)
  1004. } else if v.Source == "meetingreviewchapt" {
  1005. meetingreviewchaptIds = append(meetingreviewchaptIds, v.SourceId)
  1006. } else if v.Source == "productinterior" {
  1007. productinteriorIds = append(productinteriorIds, v.SourceId)
  1008. } else if v.Source == "industrialsourceHz" {
  1009. industrialResourceIdsHz = append(industrialResourceIdsHz, v.SourceId)
  1010. } else if v.Source == "industrialsourceYx" {
  1011. industrialResourceIdsYx = append(industrialResourceIdsYx, v.SourceId)
  1012. } else if v.Source == utils.CYGX_OBJ_YANXUANSPECIAL {
  1013. yanxuanSpecialIds = append(yanxuanSpecialIds, v.SourceId)
  1014. yanXuanbodyHighlight[v.SourceId] = v.Body
  1015. } else if v.Source == utils.CYGX_OBJ_ASKSERIEVIDEO {
  1016. askserieVideoIds = append(askserieVideoIds, strconv.Itoa(v.SourceId))
  1017. } else if v.Source == "reportselection" {
  1018. reportselectionIds = append(reportselectionIds, v.SourceId)
  1019. } else if v.Source == utils.CYGX_OBJ_FICC_REPORT {
  1020. ficcreporrtIds = append(ficcreporrtIds, strconv.Itoa(v.SourceId))
  1021. }
  1022. }
  1023. //处理文章
  1024. if len(articleIds) > 0 {
  1025. pars = make([]interface{}, 0)
  1026. condition = ` AND a.article_id IN (` + utils.GetOrmInReplace(len(articleIds)) + `)`
  1027. pars = append(pars, articleIds)
  1028. listArticle, e := models.GetHomeList(condition, pars, 0, len(articleIds))
  1029. if e != nil {
  1030. err = errors.New("GetResourceDataList, Err: " + e.Error())
  1031. return
  1032. }
  1033. listArticle, e = HandleArticleCategoryImg(listArticle)
  1034. if e != nil {
  1035. err = errors.New("HandleArticleCategoryImg, Err: " + e.Error())
  1036. return
  1037. }
  1038. for _, v := range listArticle {
  1039. v.Body = ""
  1040. v.BodyHtml = ""
  1041. if titleHighlight[v.ArticleId] != "" {
  1042. v.Title = titleHighlight[v.ArticleId]
  1043. }
  1044. if len(bodyHighlight[v.ArticleId]) > 0 {
  1045. v.Abstract = ""
  1046. v.Annotation = ""
  1047. v.BodyHighlight = bodyHighlight[v.ArticleId]
  1048. } else {
  1049. v.BodyHighlight = make([]string, 0)
  1050. }
  1051. mapItems[fmt.Sprint("article", v.ArticleId)].Article = v
  1052. }
  1053. }
  1054. //处理晨会精华
  1055. if len(meetingreviewchaptIds) > 0 {
  1056. //pars = make([]interface{}, 0)
  1057. //condition = ` AND c.id IN (` + utils.GetOrmInReplace(len(meetingreviewchaptIds)) + `)`
  1058. //pars = append(pars, meetingreviewchaptIds)
  1059. listrMeet, e := GetCygxMorningMeetingReviewChapterListByIds(meetingreviewchaptIds)
  1060. if e != nil {
  1061. err = errors.New("GetResourceDataList, Err: " + e.Error())
  1062. return
  1063. }
  1064. for _, v := range listrMeet {
  1065. v.Content = AnnotationHtml(v.Content)
  1066. v.PublishTime = utils.TimeRemoveHms2(v.PublishTime)
  1067. mapItems[fmt.Sprint("meetingreviewchapt", v.Id)].Meetingreviewchapt = v
  1068. }
  1069. }
  1070. //处理上周纪要汇总
  1071. if len(minutessummaryIds) > 0 {
  1072. pars = make([]interface{}, 0)
  1073. condition = ` AND article_id IN (` + utils.GetOrmInReplace(len(minutessummaryIds)) + `)`
  1074. pars = append(pars, minutessummaryIds)
  1075. listresearchsummary, e := models.GetReportSelectionListHome(condition, "cygx_minutes_summary", pars, 0, len(minutessummaryIds))
  1076. if e != nil {
  1077. err = errors.New("GetResourceDataList, Err: " + e.Error())
  1078. return
  1079. }
  1080. for _, v := range listresearchsummary {
  1081. v.PublishDate = utils.TimeRemoveHms2(v.PublishDate)
  1082. mapItems[fmt.Sprint("minutessummary", v.ArticleId)].Minutessummary = v
  1083. }
  1084. }
  1085. //处理本周纪要汇总
  1086. if len(researchsummaryIds) > 0 {
  1087. pars = make([]interface{}, 0)
  1088. condition = ` AND article_id IN (` + utils.GetOrmInReplace(len(researchsummaryIds)) + `)`
  1089. pars = append(pars, researchsummaryIds)
  1090. listresearchsummary, e := models.GetReportSelectionListHome(condition, "cygx_research_summary", pars, 0, len(researchsummaryIds))
  1091. if e != nil {
  1092. err = errors.New("GetReportSelectionListHome, Err: " + e.Error())
  1093. return
  1094. }
  1095. for _, v := range listresearchsummary {
  1096. v.PublishDate = utils.TimeRemoveHms2(v.PublishDate)
  1097. mapItems[fmt.Sprint("researchsummary", v.ArticleId)].Researchsummary = v
  1098. }
  1099. }
  1100. //处理产品内测
  1101. if len(productinteriorIds) > 0 {
  1102. pars = make([]interface{}, 0)
  1103. condition = ` AND art.status = 1 AND art.product_interior_id IN (` + utils.GetOrmInReplace(len(productinteriorIds)) + `)`
  1104. pars = append(pars, productinteriorIds)
  1105. listProductInterior, e := models.GetCygxProductInteriorList(condition, pars, 0, len(productinteriorIds))
  1106. if e != nil {
  1107. err = errors.New("GetCygxProductInteriorList, Err: " + e.Error())
  1108. return
  1109. }
  1110. for _, v := range listProductInterior {
  1111. v.Body = ProductInteriorHtml(v.Body)
  1112. v.PublishTime = utils.TimeRemoveHms2(v.PublishTime)
  1113. mapItems[fmt.Sprint("productinterior", v.ProductInteriorId)].ProductInterior = v
  1114. }
  1115. }
  1116. //处理报告精选
  1117. lenreportselectionIds := len(reportselectionIds)
  1118. if lenreportselectionIds > 0 {
  1119. pars = make([]interface{}, 0)
  1120. condition = ` AND article_id IN (` + utils.GetOrmInReplace(lenreportselectionIds) + `)`
  1121. pars = append(pars, reportselectionIds)
  1122. listreportselection, e := models.GetReportSelectionList(condition, pars, 0, lenreportselectionIds)
  1123. if e != nil {
  1124. err = errors.New("GetReportSelectionList, Err: " + e.Error())
  1125. return
  1126. }
  1127. mapPv := GetCygxReportHistoryRecordListMap(reportselectionIds, "bgjx")
  1128. for _, v := range listreportselection {
  1129. v.Title += "(第" + v.Periods + "期)"
  1130. v.MarketStrategy = AnnotationHtml(v.MarketStrategy)
  1131. v.PublishDate = utils.TimeRemoveHms2(v.PublishDate)
  1132. v.Pv = mapPv[v.ArticleId]
  1133. mapItems[fmt.Sprint("reportselection", v.ArticleId)].ReportSelection = v
  1134. }
  1135. }
  1136. detail, e := models.GetConfigByCode("city_img_url")
  1137. if e != nil {
  1138. err = errors.New("GetResourceDataList, Err: " + e.Error())
  1139. return
  1140. }
  1141. detailChart, e := models.GetConfigByCode("chart_img_url")
  1142. if e != nil {
  1143. err = errors.New("GetResourceDataList, Err: " + e.Error())
  1144. return
  1145. }
  1146. addressList := strings.Split(detail.ConfigValue, "{|}")
  1147. mapAddress := make(map[string]string)
  1148. chartList := strings.Split(detailChart.ConfigValue, "{|}")
  1149. mapChart := make(map[string]string)
  1150. var cityName string
  1151. var chartName string
  1152. var imgUrl string
  1153. var imgUrlChart string
  1154. for _, v := range addressList {
  1155. vslice := strings.Split(v, "_")
  1156. cityName = vslice[0]
  1157. imgUrl = vslice[len(vslice)-1]
  1158. mapAddress[cityName] = imgUrl
  1159. }
  1160. for _, v := range chartList {
  1161. vslice := strings.Split(v, "_")
  1162. chartName = vslice[0]
  1163. imgUrlChart = vslice[len(vslice)-1]
  1164. mapChart[chartName] = imgUrlChart
  1165. }
  1166. var imgUrlResp string
  1167. //处理活动
  1168. if len(activityIds) > 0 {
  1169. for _, vss := range activityIds {
  1170. imgUrlResp += strconv.Itoa(vss) + ","
  1171. }
  1172. pars = make([]interface{}, 0)
  1173. condition = ` AND art.activity_id IN (` + utils.GetOrmInReplace(len(activityIds)) + `)`
  1174. pars = append(pars, activityIds)
  1175. activityList, e := models.GetActivityListNew(condition, pars, uid, 0, len(activityIds), 0, 0, "")
  1176. if e != nil {
  1177. err = errors.New("GetResourceDataList, Err: " + e.Error())
  1178. return
  1179. }
  1180. //处理不同的报名方式按钮回显
  1181. mapActivitySignup, e := GetActivitySignupResp(activityIds, user)
  1182. if e != nil {
  1183. e = errors.New("GetActivitySignupResp, Err: " + e.Error())
  1184. return
  1185. }
  1186. activityTypeIdMap := GetActivityTypeIdMap()
  1187. var activityListRersp []*models.ActivityDetail
  1188. for _, v := range activityList {
  1189. v.SignupType = mapActivitySignup[v.ActivityId]
  1190. v.ActivityType = activityTypeIdMap[v.ActivityTypeId] // 线上还是线下
  1191. activityListRersp = append(activityListRersp, ActivityButtonShow(v))
  1192. }
  1193. for _, v := range activityListRersp {
  1194. if v == nil {
  1195. continue
  1196. }
  1197. if v.ActivityType == 0 {
  1198. if mapAddress[v.City] != "" {
  1199. imgUrlResp = mapAddress[v.City]
  1200. } else {
  1201. imgUrlResp = mapAddress["其它"]
  1202. }
  1203. } else {
  1204. if mapChart[v.ChartPermissionName] != "" {
  1205. imgUrlResp = mapChart[v.ChartPermissionName]
  1206. }
  1207. }
  1208. v.SourceType = 1
  1209. v.Expert, _ = GetReportContentTextSub(v.Expert)
  1210. mapItems[fmt.Sprint("activity", v.ActivityId)].Activity = v
  1211. }
  1212. }
  1213. //产业资源包
  1214. if len(industrialResourceIdsHz) > 0 {
  1215. pars = make([]interface{}, 0)
  1216. var industrialResourceIdstring []string
  1217. for _, v := range industrialResourceIdsHz {
  1218. industrialResourceIdstring = append(industrialResourceIdstring, strconv.Itoa(v))
  1219. }
  1220. industrialId := strings.Join(industrialResourceIdstring, ",")
  1221. condition = ` AND m.industrial_management_id IN (` + industrialId + `) AND a.article_type_id = 0 `
  1222. listIndustrialResourceIds, e := models.GetSearchResourceList(user.UserId, condition, 0, len(industrialResourceIdsHz))
  1223. if e != nil {
  1224. err = errors.New("GetSearchResourceList, Err: " + e.Error())
  1225. return
  1226. }
  1227. //合并产业关联的标的
  1228. listSubjcet, e := models.GetIndustrialSubjectAllByIndustrialId(industrialResourceIdsHz)
  1229. if e != nil {
  1230. e = errors.New("GetIndustrialSubjectAllByIndustrialId, Err: " + e.Error())
  1231. return
  1232. }
  1233. mapIndustrial := make(map[string]int)
  1234. for _, v := range listSubjcet {
  1235. for k2, v2 := range listIndustrialResourceIds {
  1236. if v2.IndustrialManagementId == v.IndustrialManagementId && mapIndustrial[fmt.Sprint(v2.IndustrialManagementId, "Hz", v.SubjectName)] == 0 {
  1237. listIndustrialResourceIds[k2].IndustrialSubjectList = append(listIndustrialResourceIds[k2].IndustrialSubjectList, v)
  1238. }
  1239. }
  1240. }
  1241. for _, v := range listIndustrialResourceIds {
  1242. if v.TimeLineData == "" {
  1243. v.ListTimeLine = make([]models.TimeLineReportResp, 0)
  1244. } else {
  1245. if err = json.Unmarshal([]byte(v.TimeLineData), &v.ListTimeLine); err != nil {
  1246. e = errors.New("Unmarshal, Err: " + e.Error())
  1247. //return
  1248. }
  1249. }
  1250. v.Source = 1
  1251. mapItems[fmt.Sprint("industrialsourceHz", v.IndustrialManagementId)].IndustrialResource = v
  1252. }
  1253. }
  1254. if len(industrialResourceIdsYx) > 0 {
  1255. pars = make([]interface{}, 0)
  1256. var industrialResourceIdstring []string
  1257. for _, v := range industrialResourceIdsYx {
  1258. industrialResourceIdstring = append(industrialResourceIdstring, strconv.Itoa(v))
  1259. }
  1260. industrialId := strings.Join(industrialResourceIdstring, ",")
  1261. condition = ` AND m.industrial_management_id IN (` + industrialId + `) AND a.article_type_id > 0 `
  1262. listIndustrialResourceIds, e := models.GetSearchResourceList(user.UserId, condition, 0, len(industrialResourceIdsYx))
  1263. if e != nil {
  1264. err = errors.New("GetSearchResourceList, Err: " + e.Error())
  1265. return
  1266. }
  1267. //合并产业关联的标的
  1268. listSubjcet, e := models.GetIndustrialSubjectAllByIndustrialId(industrialResourceIdsYx)
  1269. if e != nil {
  1270. e = errors.New("GetIndustrialSubjectAllByIndustrialId, Err: " + e.Error())
  1271. return
  1272. }
  1273. mapIndustrial := make(map[string]int)
  1274. for _, v := range listSubjcet {
  1275. for k2, v2 := range listIndustrialResourceIds {
  1276. if v2.IndustrialManagementId == v.IndustrialManagementId && mapIndustrial[fmt.Sprint(v2.IndustrialManagementId, "Yx", v.SubjectName)] == 0 {
  1277. listIndustrialResourceIds[k2].IndustrialSubjectList = append(listIndustrialResourceIds[k2].IndustrialSubjectList, v)
  1278. }
  1279. }
  1280. }
  1281. for _, v := range listIndustrialResourceIds {
  1282. v.Source = 2
  1283. mapItems[fmt.Sprint("industrialsourceYx", v.IndustrialManagementId)].IndustrialResource = v
  1284. }
  1285. }
  1286. //处理图表
  1287. if len(newchartIds) > 0 {
  1288. pars = make([]interface{}, 0)
  1289. condition = ` AND a.chart_id IN (` + utils.GetOrmInReplace(len(newchartIds)) + `)`
  1290. pars = append(pars, newchartIds)
  1291. chartDateList, e := models.GetChartListCollectionNew(condition, pars, uid, 0, len(newchartIds))
  1292. if e != nil {
  1293. err = errors.New("GetResourceDataList, Err: " + e.Error())
  1294. return
  1295. }
  1296. for _, v := range chartDateList {
  1297. mapItems[fmt.Sprint("newchart", v.ChartId)].Newchart = v
  1298. }
  1299. }
  1300. //处理专项调研
  1301. if len(activityspecialIds) > 0 {
  1302. pars = make([]interface{}, 0)
  1303. condition = ` AND art.activity_id IN (` + utils.GetOrmInReplace(len(activityspecialIds)) + `)`
  1304. pars = append(pars, activityspecialIds)
  1305. activitySpeciallist, e := models.GetCygxActivitySpecialDetailList(condition, pars, user.UserId, 0, len(activityspecialIds))
  1306. if e != nil {
  1307. err = errors.New("GetCygxActivitySpecialDetailList, Err: " + e.Error())
  1308. return
  1309. }
  1310. UserMap, e := GetSpecialTripUserMap(activityIds, user.UserId)
  1311. if e != nil {
  1312. err = errors.New("GetSpecialTripUserMap, Err: " + e.Error())
  1313. return
  1314. }
  1315. for _, v := range activitySpeciallist {
  1316. if mapChart[v.ChartPermissionName] != "" {
  1317. imgUrlResp = mapChart[v.ChartPermissionName]
  1318. }
  1319. if _, ok := UserMap[v.ActivityId]; ok {
  1320. v.IsTrip = 1
  1321. }
  1322. if v.Days == 0 {
  1323. v.TripStatus = 1
  1324. v.TripImgLink = v.TripImgLink
  1325. } else {
  1326. v.TripStatus = 2
  1327. v.TripImgLink = v.TripImgLinkFix
  1328. v.ActivityTimeText = v.ActivityTimeTextByDay
  1329. }
  1330. resultTimeStart := utils.StrTimeToTime(v.ActivityTime) //时间字符串格式转时间格式
  1331. resultTimeEnd := utils.StrTimeToTime(v.ActivityTimeEnd) //时间字符串格式转时间格式
  1332. if resultTimeStart.After(time.Now()) {
  1333. v.ActiveState = 1
  1334. } else if time.Now().After(resultTimeEnd) {
  1335. v.ActiveState = 3
  1336. } else {
  1337. v.ActiveState = 2
  1338. }
  1339. v.ImgUrl = imgUrlResp
  1340. mapItems[fmt.Sprint("activityspecial", v.ActivityId)].Activityspecial = v
  1341. }
  1342. }
  1343. if len(roadshowIds)+len(activityvideoIds)+len(activityvoiceIds)+len(askserieVideoIds) > 0 {
  1344. audioIdstr := strings.Join(activityvoiceIds, ",")
  1345. activityVideoIdsStr := strings.Join(activityvideoIds, ",")
  1346. roadshowIdsStr := strings.Join(roadshowIds, ",")
  1347. askserieVideoIdsStr := strings.Join(askserieVideoIds, ",")
  1348. list, _, e := GetMicroRoadShowMycollectV12(len(roadshowIds)+len(activityvideoIds)+len(activityvoiceIds)+len(askserieVideoIds), 0, audioIdstr, activityVideoIdsStr, roadshowIdsStr, askserieVideoIdsStr, user)
  1349. if e != nil {
  1350. err = errors.New("GetMicroRoadShowMycollectV12, Err: " + e.Error())
  1351. return
  1352. }
  1353. // 用户权限
  1354. authInfo, permissionArr, e := GetUserRaiPermissionInfo(user.UserId, user.CompanyId)
  1355. if e != nil {
  1356. err = errors.New("GetUserRaiPermissionInfo, Err: " + e.Error())
  1357. return
  1358. }
  1359. // 获取默认图配置
  1360. audioMap, videoMap, audioShareMap, videoShareMap, e := GetMicroRoadShowDefaultImgConfig()
  1361. if e != nil {
  1362. err = errors.New("GetMicroRoadShowDefaultImgConfig, Err: " + e.Error())
  1363. return
  1364. }
  1365. //Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial"`
  1366. for i := range list {
  1367. // 权限
  1368. au := new(models.UserPermissionAuthInfo)
  1369. au.SellerName = authInfo.SellerName
  1370. au.SellerMobile = authInfo.SellerMobile
  1371. au.HasPermission = authInfo.HasPermission
  1372. au.OperationMode = authInfo.OperationMode
  1373. if au.HasPermission == 1 {
  1374. // 非宏观权限进一步判断是否有权限
  1375. if list[i].ChartPermissionId != utils.HONG_GUAN_ID && !utils.InArrayByStr(permissionArr, list[i].ChartPermissionName) {
  1376. au.HasPermission = 2
  1377. }
  1378. }
  1379. // 无权限的弹框提示
  1380. if au.HasPermission != 1 {
  1381. if au.OperationMode == UserPermissionOperationModeCall {
  1382. if list[i].Type == 1 {
  1383. au.PopupMsg = UserPermissionPopupMsgCallActivity
  1384. } else {
  1385. au.PopupMsg = UserPermissionPopupMsgCallMicroVideo
  1386. }
  1387. } else {
  1388. if list[i].Type == 1 {
  1389. au.PopupMsg = UserPermissionPopupMsgApplyActivity
  1390. } else {
  1391. au.PopupMsg = UserPermissionPopupMsgApplyMicroVideo
  1392. }
  1393. }
  1394. }
  1395. list[i].AuthInfo = au
  1396. list[i].PublishTime = utils.StrTimeToTime(list[i].PublishTime).Format(utils.FormatDate)
  1397. // 默认图
  1398. if list[i].BackgroundImg == "" {
  1399. if list[i].Type == 1 {
  1400. list[i].BackgroundImg = audioMap[list[i].ChartPermissionId]
  1401. } else {
  1402. list[i].BackgroundImg = videoMap[list[i].ChartPermissionId]
  1403. }
  1404. }
  1405. // 分享图
  1406. if list[i].ShareImg == "" {
  1407. if list[i].Type == 1 {
  1408. list[i].ShareImg = audioShareMap[list[i].ChartPermissionId]
  1409. } else {
  1410. list[i].ShareImg = videoShareMap[list[i].ChartPermissionId]
  1411. }
  1412. }
  1413. }
  1414. //Type int `description:"类型: 1-音频; 2-活动视频; 3-产业视频"`
  1415. for _, item := range list {
  1416. if item.Type == 1 {
  1417. mapItems[fmt.Sprint("activityvoice", item.Id)].Activityvoice = item
  1418. } else if item.Type == 2 {
  1419. mapItems[fmt.Sprint("activityvideo", item.Id)].Activityvideo = item
  1420. } else if item.Type == 3 {
  1421. mapItems[fmt.Sprint("roadshow", item.Id)].Roadshow = item
  1422. } else if item.Type == 4 {
  1423. mapItems[fmt.Sprint(utils.CYGX_OBJ_ASKSERIEVIDEO, item.Id)].AskserieVideo = item
  1424. }
  1425. }
  1426. }
  1427. //处理研选专栏
  1428. lenyanxuanSpecialIds := len(yanxuanSpecialIds)
  1429. if lenyanxuanSpecialIds > 0 {
  1430. pars = make([]interface{}, 0)
  1431. condition = ` AND a.id IN (` + utils.GetOrmInReplace(lenyanxuanSpecialIds) + `) `
  1432. pars = append(pars, yanxuanSpecialIds)
  1433. listyanxuanSpecial, e := models.GetYanxuanSpecialList(user.UserId, condition, pars, 0, 0)
  1434. if e != nil {
  1435. err = errors.New("GetYanxuanSpecialList, Err: " + e.Error())
  1436. return
  1437. }
  1438. for _, v := range listyanxuanSpecial {
  1439. v.PublishTime = utils.TimeRemoveHms2(v.PublishTime)
  1440. v.Annotation, _ = GetReportContentTextSubNew(v.Content)
  1441. if len(yanXuanbodyHighlight[v.Id]) > 0 {
  1442. v.BodyHighlight = yanXuanbodyHighlight[v.Id]
  1443. } else {
  1444. v.BodyHighlight = append(v.BodyHighlight, v.Annotation)
  1445. }
  1446. v.Annotation = "" //强制置空,兼容前端优先级
  1447. // Source PublishDate 字段兼容前端样式
  1448. v.Source = utils.CYGX_OBJ_YANXUANSPECIAL
  1449. v.PublishDate = v.PublishTime
  1450. mapItems[fmt.Sprint(utils.CYGX_OBJ_YANXUANSPECIAL, v.Id)].YanxuanSpecial = v
  1451. }
  1452. }
  1453. //处理FICC研报
  1454. if len(ficcreporrtIds) > 0 {
  1455. pars = make([]interface{}, 0)
  1456. condition = ` AND a.report_id IN (` + utils.GetOrmInReplace(len(ficcreporrtIds)) + `)`
  1457. pars = append(pars, ficcreporrtIds)
  1458. listArticle, e := models.GetHomeList(condition, pars, 0, len(ficcreporrtIds))
  1459. if e != nil {
  1460. err = errors.New("GetHomeList, Err: " + e.Error())
  1461. return
  1462. }
  1463. listArticle, e = HandleArticleCategoryImg(listArticle)
  1464. if e != nil {
  1465. err = errors.New("HandleArticleCategoryImg, Err: " + e.Error())
  1466. return
  1467. }
  1468. for _, v := range listArticle {
  1469. //fmt.Println(v.ArticleId)
  1470. v.Body = ""
  1471. v.Source = 0 //配合前端这里强制改为 0
  1472. v.ArticleResponse = 0 //配合前端这里强制改为 0
  1473. //v.Source = utils.CYGX_OBJ_YANXUANSPECIAL
  1474. mapItems[fmt.Sprint("ficcreport", v.ReportId)].FiccReport = v
  1475. }
  1476. //listArticle, e = HandleArticleCategoryImg(listArticle)
  1477. //if e != nil {
  1478. // err = errors.New("HandleArticleCategoryImg, Err: " + e.Error())
  1479. // return
  1480. //}
  1481. //for _, v := range listArticle {
  1482. // //reportInfoItem := new(ficc_report.ReportDetail)
  1483. // //reportInfoItem.ReportInfo.ReportId = v.ReportId
  1484. // //reportInfoItem.ReportInfo.PublishTime = utils.StrTimeToTime(v.PublishDate)
  1485. // //reportInfoItem.ReportInfo.Title = v.Title
  1486. // mapItems[fmt.Sprint("ficcreport", v.ArticleId)].FiccReport = v
  1487. //
  1488. //}
  1489. }
  1490. for _, vList := range list {
  1491. for _, v := range mapItems {
  1492. //如果这些类型都为空,那么就不合并
  1493. if v.Article == nil && v.Newchart == nil && v.Roadshow == nil && v.Activity == nil && v.Activityvideo == nil && v.Activityvoice == nil && v.Activityspecial == nil && v.Researchsummary == nil && v.Minutessummary == nil && v.Meetingreviewchapt == nil && v.ProductInterior == nil && v.IndustrialResource == nil && v.YanxuanSpecial == nil && v.AskserieVideo == nil && v.ReportSelection == nil && v.FiccReport == nil {
  1494. continue
  1495. }
  1496. if v.SourceId == vList.SourceId && v.Source == vList.Source {
  1497. items = append(items, v)
  1498. }
  1499. }
  1500. }
  1501. for _, v := range items {
  1502. if v.IndustrialResource != nil {
  1503. v.Source = "industrialsource"
  1504. }
  1505. }
  1506. return
  1507. }
  1508. func SqlComprehensiveSearch(keyWord string, startSize, pageSize int) (result []*SearchComprehensiveItem, total int, err error) {
  1509. listListNoEnd, e := models.GetActivityIdListNoEnd()
  1510. var activityIds []string
  1511. for _, v := range listListNoEnd {
  1512. activityIds = append(activityIds, strconv.Itoa(v.ActivityId))
  1513. }
  1514. activityIds = append(activityIds, "0")
  1515. conditionActivity := " AND IF ( source IN('activity') , source_id IN (" + strings.Join(activityIds, ",") + ") ,1=1 )"
  1516. keyWord = "%" + keyWord + "%"
  1517. var conditionTitle string
  1518. var parsTitle []interface{}
  1519. conditionTitle = " AND is_hide = 0 AND search_title LIKE ? AND IF ( source IN('activityvoice','activityvideo') , chart_permission_id != 31 ,1=1 ) " + conditionActivity
  1520. parsTitle = append(parsTitle, keyWord)
  1521. totalTitle, e := models.GetResourceDataCount(conditionTitle, parsTitle)
  1522. if e != nil {
  1523. err = errors.New("GetResourceDataCount, Err: " + e.Error())
  1524. return
  1525. }
  1526. var conditionContent string
  1527. var parsContent []interface{}
  1528. conditionContent = " AND is_hide = 0 AND search_content LIKE ? AND search_title NOT LIKE ? AND IF ( source IN('activityvoice','activityvideo') , chart_permission_id != 31 ,1=1 ) " + conditionActivity
  1529. parsContent = append(parsContent, keyWord, keyWord)
  1530. totalContent, e := models.GetResourceDataCount(conditionContent, parsContent)
  1531. if e != nil {
  1532. err = errors.New("AddCygxArticleViewRecord, Err: " + e.Error())
  1533. return
  1534. }
  1535. var searchTotal int
  1536. searchTotal = (startSize/pageSize + 1) * pageSize
  1537. var list []*models.CygxResourceData
  1538. //fmt.Println("totalTitle", totalTitle)
  1539. //fmt.Println("totalContent", totalContent)
  1540. //fmt.Println(searchTotal)
  1541. if totalTitle >= searchTotal {
  1542. //全部都是标题搜索
  1543. list, e = models.GetResourceDataListCondition(conditionTitle, parsTitle, startSize, pageSize)
  1544. if e != nil && e.Error() != utils.ErrNoRow() {
  1545. err = errors.New("GetResourceDataListCondition, Err: " + e.Error())
  1546. return
  1547. }
  1548. } else if totalTitle <= searchTotal-pageSize {
  1549. //全部都是内容搜索
  1550. startSize = startSize - totalTitle
  1551. list, e = models.GetResourceDataListCondition(conditionContent, parsContent, startSize, pageSize)
  1552. if e != nil && e.Error() != utils.ErrNoRow() {
  1553. err = errors.New("GetResourceDataListCondition, Err: " + e.Error())
  1554. return
  1555. }
  1556. } else {
  1557. //一半标题搜索,一半内容搜索
  1558. list, e = models.GetResourceDataListCondition(conditionTitle, parsTitle, startSize, pageSize)
  1559. if e != nil && e.Error() != utils.ErrNoRow() {
  1560. err = errors.New("GetResourceDataListCondition, Err: " + e.Error())
  1561. return
  1562. }
  1563. listContent, e := models.GetResourceDataListCondition(conditionContent, parsContent, 0, pageSize-totalContent%pageSize)
  1564. if e != nil && e.Error() != utils.ErrNoRow() {
  1565. err = errors.New("GetResourceDataListCondition, Err: " + e.Error())
  1566. return
  1567. }
  1568. for _, v := range listContent {
  1569. list = append(list, v)
  1570. }
  1571. }
  1572. for _, v := range list {
  1573. item := new(SearchComprehensiveItem)
  1574. item.SourceId = v.SourceId
  1575. item.Source = v.Source
  1576. result = append(result, item)
  1577. }
  1578. total = totalTitle + totalContent
  1579. return
  1580. }