|
@@ -51,7 +51,7 @@ func CreatePosterFromSource(codePage, codeScene, source, version, pars string) (
|
|
|
}
|
|
|
path := fmt.Sprint(codePage, "?", codeScene)
|
|
|
// 非列表来源获取历史图片,无则生成
|
|
|
- if !strings.Contains(source, "list") {
|
|
|
+ if !strings.Contains(source, "list") && source != "price_driven" {
|
|
|
poster, tmpErr := yb_poster_resource.GetPosterByCondition(path, "poster", version)
|
|
|
if tmpErr != nil && tmpErr != utils.ErrNoRow {
|
|
|
err = tmpErr
|
|
@@ -72,6 +72,7 @@ func CreatePosterFromSource(codePage, codeScene, source, version, pars string) (
|
|
|
"chart_list": 1352,
|
|
|
"report_detail": 1420,
|
|
|
"report_list": 1344,
|
|
|
+ "price_driven": 1344,
|
|
|
}
|
|
|
widthMap := map[string]int{
|
|
|
"activity_detail": 1280,
|
|
@@ -82,6 +83,7 @@ func CreatePosterFromSource(codePage, codeScene, source, version, pars string) (
|
|
|
"chart_list": 1176,
|
|
|
"report_detail": 1176,
|
|
|
"report_list": 1176,
|
|
|
+ "price_driven": 1176,
|
|
|
}
|
|
|
width := widthMap[source]
|
|
|
height := heightMap[source]
|
|
@@ -245,37 +247,41 @@ func CreateAndUploadSunCode(page, scene, version string) (imgUrl string, err err
|
|
|
}
|
|
|
|
|
|
type PosterParsReq struct {
|
|
|
- ActivityTitle string `json:"activity_title"`
|
|
|
- ActivityAvatar string `json:"activity_avatar"`
|
|
|
- ActivitySpeaker string `json:"activity_speaker"`
|
|
|
- ActivityTime string `json:"activity_time"`
|
|
|
- ChartName string `json:"chart_name"`
|
|
|
- ChartImage string `json:"chart_image"`
|
|
|
- ReportType string `json:"report_type"`
|
|
|
- ReportAvatar string `json:"report_avatar"`
|
|
|
- ReportTitle string `json:"report_title"`
|
|
|
- ReportAbstract string `json:"report_abstract"`
|
|
|
- Stage1 string `json:"stage_1"`
|
|
|
- Avatar1 string `json:"avatar_1"`
|
|
|
- Title1 string `json:"title_1"`
|
|
|
- Author1 string `json:"author_1"`
|
|
|
- Tag1 string `json:"tag_1"`
|
|
|
- Img1 string `json:"img_1"`
|
|
|
- Time1 string `json:"time_1"`
|
|
|
- Abstract1 string `json:"abstract_1"`
|
|
|
- Status1 string `json:"status_1"`
|
|
|
- Speaker1 string `json:"speaker_1"`
|
|
|
- Stage2 string `json:"stage_2"`
|
|
|
- Avatar2 string `json:"avatar_2"`
|
|
|
- Title2 string `json:"title_2"`
|
|
|
- Author2 string `json:"author_2"`
|
|
|
- Tag2 string `json:"tag_2"`
|
|
|
- Img2 string `json:"img_2"`
|
|
|
- Abstract2 string `json:"abstract_2"`
|
|
|
- Time2 string `json:"time_2"`
|
|
|
- Status2 string `json:"status_2"`
|
|
|
- Speaker2 string `json:"speaker_2"`
|
|
|
- ListTitle string `json:"list_title"`
|
|
|
+ ActivityTitle string `json:"activity_title"`
|
|
|
+ ActivityAvatar string `json:"activity_avatar"`
|
|
|
+ ActivitySpeaker string `json:"activity_speaker"`
|
|
|
+ ActivityTime string `json:"activity_time"`
|
|
|
+ ChartName string `json:"chart_name"`
|
|
|
+ ChartImage string `json:"chart_image"`
|
|
|
+ ReportType string `json:"report_type"`
|
|
|
+ ReportAvatar string `json:"report_avatar"`
|
|
|
+ ReportTitle string `json:"report_title"`
|
|
|
+ ReportAbstract string `json:"report_abstract"`
|
|
|
+ Stage1 string `json:"stage_1"`
|
|
|
+ Avatar1 string `json:"avatar_1"`
|
|
|
+ Title1 string `json:"title_1"`
|
|
|
+ Author1 string `json:"author_1"`
|
|
|
+ Tag1 string `json:"tag_1"`
|
|
|
+ Img1 string `json:"img_1"`
|
|
|
+ Time1 string `json:"time_1"`
|
|
|
+ Abstract1 string `json:"abstract_1"`
|
|
|
+ Status1 string `json:"status_1"`
|
|
|
+ Speaker1 string `json:"speaker_1"`
|
|
|
+ Stage2 string `json:"stage_2"`
|
|
|
+ Avatar2 string `json:"avatar_2"`
|
|
|
+ Title2 string `json:"title_2"`
|
|
|
+ Author2 string `json:"author_2"`
|
|
|
+ Tag2 string `json:"tag_2"`
|
|
|
+ Img2 string `json:"img_2"`
|
|
|
+ Abstract2 string `json:"abstract_2"`
|
|
|
+ Time2 string `json:"time_2"`
|
|
|
+ Status2 string `json:"status_2"`
|
|
|
+ Speaker2 string `json:"speaker_2"`
|
|
|
+ ListTitle string `json:"list_title"`
|
|
|
+ CoreDrivenType string `json:"core_driven_type"`
|
|
|
+ CoreDrivenContent string `json:"core_driven_content"`
|
|
|
+ MainVariable string `json:"main_variable"`
|
|
|
+ UpdateTime string `json:"update_time"`
|
|
|
}
|
|
|
|
|
|
// fillContent2Html 填充HTML动态内容
|
|
@@ -382,12 +388,12 @@ func fillContent2Html(source, pars, sunCodeUrl string, height int) (contentStr s
|
|
|
contentStr = strings.Replace(contentStr, "{{REPORT_ABSTRACT}}", abstract, 1)
|
|
|
case "special_column_list":
|
|
|
contentStr = strings.Replace(contentStr, "{{LIST_TITLE}}", params.ListTitle, 1)
|
|
|
- contentStr = strings.Replace(contentStr, "{{STAGE_1}}", "第" + params.Stage1 + "期", 1)
|
|
|
+ contentStr = strings.Replace(contentStr, "{{STAGE_1}}", "第"+params.Stage1+"期", 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{AVATAR_1}}", params.Avatar1, 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{TITLE_1}}", params.Title1, 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{AUTHOR_1}}", params.Author1, 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{TAG_1}}", params.Tag1, 1)
|
|
|
- contentStr = strings.Replace(contentStr, "{{STAGE_2}}", "第" + params.Stage2 + "期", 1)
|
|
|
+ contentStr = strings.Replace(contentStr, "{{STAGE_2}}", "第"+params.Stage2+"期", 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{AVATAR_2}}", params.Avatar2, 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{TITLE_2}}", params.Title2, 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{AUTHOR_2}}", params.Author2, 1)
|
|
@@ -408,6 +414,12 @@ func fillContent2Html(source, pars, sunCodeUrl string, height int) (contentStr s
|
|
|
contentStr = strings.Replace(contentStr, "{{ABSTRACT_2}}", params.Abstract2, 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{IMG_2}}", params.Img2, 1)
|
|
|
contentStr = strings.Replace(contentStr, "{{TIME_2}}", params.Time2, 1)
|
|
|
+ case "price_driven":
|
|
|
+ contentStr = strings.Replace(contentStr, "{{LIST_TITLE}}", params.ListTitle, 1)
|
|
|
+ contentStr = strings.Replace(contentStr, "{{CORE_DRIVEN_TYPE}}", params.CoreDrivenType, 1)
|
|
|
+ contentStr = strings.Replace(contentStr, "{{CORE_DRIVEN_CONTENT}}", params.CoreDrivenContent, 1)
|
|
|
+ contentStr = strings.Replace(contentStr, "{{MAIN_VARIABLE}}", params.MainVariable, 1)
|
|
|
+ contentStr = strings.Replace(contentStr, "{{UPDATE_TIME}}", params.UpdateTime, 1)
|
|
|
case "activity_list":
|
|
|
bgColorMap := map[string]string{
|
|
|
"未开始": "#E3B377",
|
|
@@ -464,3 +476,33 @@ func fillContent2Html(source, pars, sunCodeUrl string, height int) (contentStr s
|
|
|
contentStr = strings.Replace(contentStr, "{{SUN_CODE}}", sunCodeUrl, 1)
|
|
|
return
|
|
|
}
|
|
|
+
|
|
|
+// GetRddpShareImg 获取日度点评分享图
|
|
|
+func GetRddpShareImg(title string) (imgUrl string, err error) {
|
|
|
+ if title == "" {
|
|
|
+ return
|
|
|
+ }
|
|
|
+ template := fmt.Sprint("static/htm2img/rddp-share.html")
|
|
|
+ contentByte, e := ioutil.ReadFile(template)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("读取模板失败, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ contentStr := string(contentByte)
|
|
|
+ contentStr = strings.Replace(contentStr, "{{TITLE}}", title, 1)
|
|
|
+ htm2ImgReq := make(map[string]interface{})
|
|
|
+ htm2ImgReq["html_content"] = contentStr
|
|
|
+ htm2ImgReq["width"] = 1000
|
|
|
+ htm2ImgReq["height"] = 800
|
|
|
+ res, e := postHtml2Img(htm2ImgReq)
|
|
|
+ if e != nil || res == nil {
|
|
|
+ err = errors.New("html转图片请求失败")
|
|
|
+ return
|
|
|
+ }
|
|
|
+ if res.Code != 200 {
|
|
|
+ err = errors.New("html转图片请求失败: " + res.Msg)
|
|
|
+ return
|
|
|
+ }
|
|
|
+ imgUrl = res.Data
|
|
|
+ return
|
|
|
+}
|